@dxos/plugin-assistant 0.8.4-main.fcfe5033a5 → 0.8.4-staging.60fe92afc8

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.
Files changed (751) hide show
  1. package/LICENSE +102 -5
  2. package/PLUGIN.mdl +439 -0
  3. package/README.md +1 -1
  4. package/dist/lib/neutral/AgentArticle-K7XM46OQ.mjs +160 -0
  5. package/dist/lib/neutral/AgentArticle-K7XM46OQ.mjs.map +7 -0
  6. package/dist/lib/neutral/AgentProperties-LFTEYJ54.mjs +40 -0
  7. package/dist/lib/neutral/AgentProperties-LFTEYJ54.mjs.map +7 -0
  8. package/dist/lib/neutral/AssistantPlugin.mjs +10 -0
  9. package/dist/lib/neutral/AssistantPlugin.node.mjs +72 -0
  10. package/dist/lib/neutral/AssistantPlugin.node.mjs.map +7 -0
  11. package/dist/lib/neutral/AssistantPlugin.workerd.mjs +40 -0
  12. package/dist/lib/neutral/AssistantPlugin.workerd.mjs.map +7 -0
  13. package/dist/lib/neutral/AssistantSettings-GG52BLKS.mjs +40 -0
  14. package/dist/lib/neutral/AssistantSettings-GG52BLKS.mjs.map +7 -0
  15. package/dist/lib/neutral/BlueprintArticle-ZBOZNZM7.mjs +27 -0
  16. package/dist/lib/neutral/BlueprintArticle-ZBOZNZM7.mjs.map +7 -0
  17. package/dist/lib/neutral/ChatArticle-VNVZCDUR.mjs +8 -0
  18. package/dist/lib/neutral/ChatCompanion-LBUHYWQG.mjs +128 -0
  19. package/dist/lib/neutral/ChatCompanion-LBUHYWQG.mjs.map +7 -0
  20. package/dist/lib/neutral/ChatDialog-DCA6FLOV.mjs +73 -0
  21. package/dist/lib/neutral/ChatDialog-DCA6FLOV.mjs.map +7 -0
  22. package/dist/lib/neutral/PlanArticle-TS5ULWYS.mjs +28 -0
  23. package/dist/lib/neutral/PlanArticle-TS5ULWYS.mjs.map +7 -0
  24. package/dist/lib/neutral/RoutineArticle-5NYXHRG6.mjs +119 -0
  25. package/dist/lib/neutral/RoutineArticle-5NYXHRG6.mjs.map +7 -0
  26. package/dist/lib/neutral/RoutineList-SO5ETHNT.mjs +48 -0
  27. package/dist/lib/neutral/RoutineList-SO5ETHNT.mjs.map +7 -0
  28. package/dist/lib/neutral/RoutineProperties-FISLMW2R.mjs +17 -0
  29. package/dist/lib/neutral/RoutineProperties-FISLMW2R.mjs.map +7 -0
  30. package/dist/lib/neutral/TracePanel-KTZJ6JNR.mjs +167 -0
  31. package/dist/lib/neutral/TracePanel-KTZJ6JNR.mjs.map +7 -0
  32. package/dist/lib/neutral/TriggerStatus-X7Y5JFZJ.mjs +93 -0
  33. package/dist/lib/neutral/TriggerStatus-X7Y5JFZJ.mjs.map +7 -0
  34. package/dist/lib/neutral/agent-hydrator-PJBYVMBW.mjs +24 -0
  35. package/dist/lib/neutral/agent-hydrator-PJBYVMBW.mjs.map +7 -0
  36. package/dist/lib/neutral/agent-service-WCAP5MLI.mjs +32 -0
  37. package/dist/lib/neutral/agent-service-WCAP5MLI.mjs.map +7 -0
  38. package/dist/lib/neutral/ai-context-7WRHWYXY.mjs +42 -0
  39. package/dist/lib/neutral/ai-context-7WRHWYXY.mjs.map +7 -0
  40. package/dist/lib/neutral/ai-service-AADUIKBY.mjs +40 -0
  41. package/dist/lib/neutral/ai-service-AADUIKBY.mjs.map +7 -0
  42. package/dist/lib/neutral/app-graph-builder-WUFHQH3Y.mjs +232 -0
  43. package/dist/lib/neutral/app-graph-builder-WUFHQH3Y.mjs.map +7 -0
  44. package/dist/lib/neutral/automation-templates-M2XQWGR6.mjs +115 -0
  45. package/dist/lib/neutral/automation-templates-M2XQWGR6.mjs.map +7 -0
  46. package/dist/lib/neutral/blueprint-definition-MH2QLYQH.mjs +39 -0
  47. package/dist/lib/neutral/blueprint-definition-MH2QLYQH.mjs.map +7 -0
  48. package/dist/lib/{browser → neutral}/blueprints/index.mjs +1 -1
  49. package/dist/lib/neutral/capabilities/index.mjs +45 -0
  50. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  51. package/dist/lib/{browser/chunk-EZRS3J25.mjs → neutral/chunk-5H6UJHLF.mjs} +3 -3
  52. package/dist/lib/neutral/chunk-5H6UJHLF.mjs.map +7 -0
  53. package/dist/lib/neutral/chunk-HLANPOBA.mjs +10 -0
  54. package/dist/lib/neutral/chunk-HLANPOBA.mjs.map +7 -0
  55. package/dist/lib/neutral/chunk-KLYLW4WH.mjs +9 -0
  56. package/dist/lib/neutral/chunk-KLYLW4WH.mjs.map +7 -0
  57. package/dist/lib/neutral/chunk-QAZMOFPI.mjs +130 -0
  58. package/dist/lib/neutral/chunk-QAZMOFPI.mjs.map +7 -0
  59. package/dist/lib/neutral/chunk-RKVVK3R3.mjs +110 -0
  60. package/dist/lib/neutral/chunk-RKVVK3R3.mjs.map +7 -0
  61. package/dist/lib/neutral/chunk-SMFJD7BP.mjs +8 -0
  62. package/dist/lib/neutral/chunk-SMFJD7BP.mjs.map +7 -0
  63. package/dist/lib/neutral/chunk-VTK5R4H3.mjs +9 -0
  64. package/dist/lib/neutral/chunk-VTK5R4H3.mjs.map +7 -0
  65. package/dist/lib/neutral/chunk-XYHPOGTK.mjs +43 -0
  66. package/dist/lib/neutral/chunk-XYHPOGTK.mjs.map +7 -0
  67. package/dist/lib/neutral/chunk-YXRGZYYH.mjs +392 -0
  68. package/dist/lib/neutral/chunk-YXRGZYYH.mjs.map +7 -0
  69. package/dist/lib/neutral/companion-chat-provisioner-YZZ73P6E.mjs +120 -0
  70. package/dist/lib/neutral/companion-chat-provisioner-YZZ73P6E.mjs.map +7 -0
  71. package/dist/lib/neutral/components/index.mjs +2410 -0
  72. package/dist/lib/neutral/components/index.mjs.map +7 -0
  73. package/dist/lib/neutral/containers/index.mjs +29 -0
  74. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  75. package/dist/lib/neutral/create-chat-SGGQ6HVN.mjs +54 -0
  76. package/dist/lib/neutral/create-chat-SGGQ6HVN.mjs.map +7 -0
  77. package/dist/lib/neutral/create-object-U2SOFZLR.mjs +92 -0
  78. package/dist/lib/neutral/create-object-U2SOFZLR.mjs.map +7 -0
  79. package/dist/lib/neutral/edge-model-resolver-BBVOJBGJ.mjs +55 -0
  80. package/dist/lib/neutral/edge-model-resolver-BBVOJBGJ.mjs.map +7 -0
  81. package/dist/lib/{browser/ensure-companion-chat-ZEZA34MZ.mjs → neutral/ensure-companion-chat-AMOF3C66.mjs} +14 -21
  82. package/dist/lib/neutral/ensure-companion-chat-AMOF3C66.mjs.map +7 -0
  83. package/dist/lib/neutral/execution-graph/index.mjs +703 -0
  84. package/dist/lib/neutral/execution-graph/index.mjs.map +7 -0
  85. package/dist/lib/neutral/fork-chat-34KEF4ZJ.mjs +95 -0
  86. package/dist/lib/neutral/fork-chat-34KEF4ZJ.mjs.map +7 -0
  87. package/dist/lib/neutral/hooks/index.mjs +992 -0
  88. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  89. package/dist/lib/neutral/index.mjs +38 -0
  90. package/dist/lib/neutral/integration-provider-RBD3AFJU.mjs +71 -0
  91. package/dist/lib/neutral/integration-provider-RBD3AFJU.mjs.map +7 -0
  92. package/dist/lib/neutral/local-model-resolver-I2BENFFS.mjs +24 -0
  93. package/dist/lib/neutral/local-model-resolver-I2BENFFS.mjs.map +7 -0
  94. package/dist/lib/neutral/markdown-extension-YMIFDMYF.mjs +110 -0
  95. package/dist/lib/neutral/markdown-extension-YMIFDMYF.mjs.map +7 -0
  96. package/dist/lib/neutral/meta.json +1 -0
  97. package/dist/lib/neutral/meta.mjs +12 -0
  98. package/dist/lib/neutral/migrations-7DEMVBOG.mjs +28 -0
  99. package/dist/lib/neutral/migrations-7DEMVBOG.mjs.map +7 -0
  100. package/dist/lib/neutral/operation-handler-SF36MOB5.mjs +13 -0
  101. package/dist/lib/neutral/operation-handler-SF36MOB5.mjs.map +7 -0
  102. package/dist/lib/neutral/operations/index.mjs +8 -0
  103. package/dist/lib/neutral/operations/index.mjs.map +7 -0
  104. package/dist/lib/neutral/plugin.mjs +16 -0
  105. package/dist/lib/neutral/plugin.mjs.map +7 -0
  106. package/dist/lib/neutral/react-surface-XRTBW5OJ.mjs +174 -0
  107. package/dist/lib/neutral/react-surface-XRTBW5OJ.mjs.map +7 -0
  108. package/dist/lib/{browser/resolve-navigation-targets-NZOD66NY.mjs → neutral/resolve-navigation-targets-ZHIMMH7L.mjs} +6 -6
  109. package/dist/lib/neutral/resolve-navigation-targets-ZHIMMH7L.mjs.map +7 -0
  110. package/dist/lib/{browser/run-prompt-in-new-chat-THLK5YQC.mjs → neutral/run-prompt-in-new-chat-D5IIE2C7.mjs} +22 -56
  111. package/dist/lib/neutral/run-prompt-in-new-chat-D5IIE2C7.mjs.map +7 -0
  112. package/dist/lib/{browser/set-current-chat-LRS3VFSH.mjs → neutral/set-current-chat-VWBPSIMZ.mjs} +7 -13
  113. package/dist/lib/neutral/set-current-chat-VWBPSIMZ.mjs.map +7 -0
  114. package/dist/lib/neutral/settings-W4BLWQ53.mjs +28 -0
  115. package/dist/lib/neutral/settings-W4BLWQ53.mjs.map +7 -0
  116. package/dist/lib/neutral/state-H3G7QCU6.mjs +28 -0
  117. package/dist/lib/neutral/state-H3G7QCU6.mjs.map +7 -0
  118. package/dist/lib/neutral/testing.mjs +8 -0
  119. package/dist/lib/neutral/testing.mjs.map +7 -0
  120. package/dist/lib/neutral/toggle-trace-panel-debug-JGTB6KVJ.mjs +21 -0
  121. package/dist/lib/neutral/toggle-trace-panel-debug-JGTB6KVJ.mjs.map +7 -0
  122. package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs +14 -0
  123. package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs.map +7 -0
  124. package/dist/lib/neutral/translations.mjs +179 -0
  125. package/dist/lib/neutral/translations.mjs.map +7 -0
  126. package/dist/lib/neutral/types/index.mjs +20 -0
  127. package/dist/lib/neutral/types/index.mjs.map +7 -0
  128. package/dist/lib/{browser/update-chat-name-3Y36KFAS.mjs → neutral/update-chat-name-Y7JWIP64.mjs} +26 -36
  129. package/dist/lib/neutral/update-chat-name-Y7JWIP64.mjs.map +7 -0
  130. package/dist/types/src/AssistantPlugin.d.ts +3 -1
  131. package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
  132. package/dist/types/src/AssistantPlugin.node.d.ts +5 -0
  133. package/dist/types/src/AssistantPlugin.node.d.ts.map +1 -0
  134. package/dist/types/src/AssistantPlugin.test.d.ts +2 -0
  135. package/dist/types/src/AssistantPlugin.test.d.ts.map +1 -0
  136. package/dist/types/src/AssistantPlugin.workerd.d.ts +4 -0
  137. package/dist/types/src/AssistantPlugin.workerd.d.ts.map +1 -0
  138. package/dist/types/src/blueprints/assistant/blueprint.d.ts +2 -2
  139. package/dist/types/src/blueprints/assistant/blueprint.d.ts.map +1 -1
  140. package/dist/types/src/blueprints/assistant/blueprint.node.test.d.ts +2 -0
  141. package/dist/types/src/blueprints/assistant/blueprint.node.test.d.ts.map +1 -0
  142. package/dist/types/src/capabilities/agent-hydrator.d.ts +5 -0
  143. package/dist/types/src/capabilities/agent-hydrator.d.ts.map +1 -0
  144. package/dist/types/src/capabilities/agent-service.d.ts +6 -0
  145. package/dist/types/src/capabilities/agent-service.d.ts.map +1 -0
  146. package/dist/types/src/capabilities/ai-context.d.ts +6 -0
  147. package/dist/types/src/capabilities/ai-context.d.ts.map +1 -0
  148. package/dist/types/src/capabilities/ai-service.d.ts +2 -2
  149. package/dist/types/src/capabilities/ai-service.d.ts.map +1 -1
  150. package/dist/types/src/capabilities/app-graph-builder.d.ts +2 -1
  151. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  152. package/dist/types/src/capabilities/automation-templates.d.ts +6 -0
  153. package/dist/types/src/capabilities/automation-templates.d.ts.map +1 -0
  154. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -1
  155. package/dist/types/src/capabilities/companion-chat-provisioner.d.ts.map +1 -1
  156. package/dist/types/src/capabilities/create-object.d.ts +31 -0
  157. package/dist/types/src/capabilities/create-object.d.ts.map +1 -0
  158. package/dist/types/src/capabilities/edge-model-resolver.d.ts +1 -1
  159. package/dist/types/src/capabilities/edge-model-resolver.d.ts.map +1 -1
  160. package/dist/types/src/capabilities/index.d.ts +36 -3
  161. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  162. package/dist/types/src/capabilities/integration-provider.d.ts +5 -0
  163. package/dist/types/src/capabilities/integration-provider.d.ts.map +1 -0
  164. package/dist/types/src/capabilities/local-model-resolver.d.ts.map +1 -1
  165. package/dist/types/src/capabilities/{markdown.d.ts → markdown-extension.d.ts} +1 -1
  166. package/dist/types/src/capabilities/markdown-extension.d.ts.map +1 -0
  167. package/dist/types/src/capabilities/migrations.d.ts +2 -1
  168. package/dist/types/src/capabilities/migrations.d.ts.map +1 -1
  169. package/dist/types/src/capabilities/operation-handler.d.ts +1 -1
  170. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -1
  171. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  172. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  173. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  174. package/dist/types/src/capabilities/toolkit.d.ts.map +1 -1
  175. package/dist/types/src/components/AgentProperties/AgentProperties.d.ts +7 -0
  176. package/dist/types/src/components/AgentProperties/AgentProperties.d.ts.map +1 -0
  177. package/dist/types/src/{containers → components}/AgentProperties/AgentProperties.stories.d.ts +1 -2
  178. package/dist/types/src/components/AgentProperties/AgentProperties.stories.d.ts.map +1 -0
  179. package/dist/types/src/components/AgentProperties/index.d.ts +2 -0
  180. package/dist/types/src/components/AgentProperties/index.d.ts.map +1 -0
  181. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts +1 -1
  182. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
  183. package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts.map +1 -1
  184. package/dist/types/src/components/Chat/Chat.d.ts +44 -42
  185. package/dist/types/src/components/Chat/Chat.d.ts.map +1 -1
  186. package/dist/types/src/components/Chat/context.d.ts +29 -0
  187. package/dist/types/src/components/Chat/context.d.ts.map +1 -0
  188. package/dist/types/src/components/Chat/events.d.ts +3 -0
  189. package/dist/types/src/components/Chat/events.d.ts.map +1 -1
  190. package/dist/types/src/components/ChatPrompt/ChatActions.d.ts +1 -1
  191. package/dist/types/src/components/ChatPrompt/ChatActions.d.ts.map +1 -1
  192. package/dist/types/src/components/ChatPrompt/ChatMcpErrors.d.ts +12 -0
  193. package/dist/types/src/components/ChatPrompt/ChatMcpErrors.d.ts.map +1 -0
  194. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts +10 -14
  195. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts.map +1 -1
  196. package/dist/types/src/components/ChatPrompt/ChatOptions.stories.d.ts +1 -1
  197. package/dist/types/src/components/ChatPrompt/ChatOptions.stories.d.ts.map +1 -1
  198. package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts +2 -9
  199. package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts.map +1 -1
  200. package/dist/types/src/components/ChatPrompt/ChatPrompt.d.ts +27 -0
  201. package/dist/types/src/components/ChatPrompt/ChatPrompt.d.ts.map +1 -0
  202. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +2 -2
  203. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
  204. package/dist/types/src/components/ChatPrompt/ChatStatus.d.ts +20 -0
  205. package/dist/types/src/components/ChatPrompt/ChatStatus.d.ts.map +1 -0
  206. package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts +1 -1
  207. package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts.map +1 -1
  208. package/dist/types/src/components/ChatPrompt/index.d.ts +3 -0
  209. package/dist/types/src/components/ChatPrompt/index.d.ts.map +1 -1
  210. package/dist/types/src/components/ChatThread/Anchor.stories.d.ts +14 -0
  211. package/dist/types/src/components/ChatThread/Anchor.stories.d.ts.map +1 -0
  212. package/dist/types/src/components/ChatThread/ChatThread.d.ts +6 -3
  213. package/dist/types/src/components/ChatThread/ChatThread.d.ts.map +1 -1
  214. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +5 -5
  215. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
  216. package/dist/types/src/components/ChatThread/Link.d.ts +2 -2
  217. package/dist/types/src/components/ChatThread/Link.d.ts.map +1 -1
  218. package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts +8 -1
  219. package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts.map +1 -1
  220. package/dist/types/src/components/ChatThread/registry.d.ts +18 -0
  221. package/dist/types/src/components/ChatThread/registry.d.ts.map +1 -1
  222. package/dist/types/src/components/ChatThread/sync.d.ts +42 -16
  223. package/dist/types/src/components/ChatThread/sync.d.ts.map +1 -1
  224. package/dist/types/src/components/ChatThread/tool-widget-state.d.ts.map +1 -1
  225. package/dist/types/src/components/ChatThread/widgets/FallbackWidget.d.ts +4 -4
  226. package/dist/types/src/components/ChatThread/widgets/FallbackWidget.d.ts.map +1 -1
  227. package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.d.ts.map +1 -1
  228. package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.stories.d.ts.map +1 -1
  229. package/dist/types/src/components/ChatThread/widgets/ReferenceWidget.d.ts.map +1 -1
  230. package/dist/types/src/components/ChatThread/widgets/SelectWidget.d.ts.map +1 -1
  231. package/dist/types/src/components/ChatThread/widgets/StatsWidget.d.ts.map +1 -1
  232. package/dist/types/src/components/ChatThread/widgets/StatusWidget.d.ts +2 -15
  233. package/dist/types/src/components/ChatThread/widgets/StatusWidget.d.ts.map +1 -1
  234. package/dist/types/src/components/ChatThread/widgets/SuggestionWidget.d.ts.map +1 -1
  235. package/dist/types/src/components/ChatThread/widgets/SummaryWidget.d.ts.map +1 -1
  236. package/dist/types/src/components/ChatThread/widgets/ToolWidget.d.ts.map +1 -1
  237. package/dist/types/src/components/ChatThread/widgets/ToolWidget.stories.d.ts.map +1 -1
  238. package/dist/types/src/components/ChatThread/widgets/defaults.d.ts +5 -0
  239. package/dist/types/src/components/ChatThread/widgets/defaults.d.ts.map +1 -0
  240. package/dist/types/src/components/ChatThread/widgets/index.d.ts +1 -2
  241. package/dist/types/src/components/ChatThread/widgets/index.d.ts.map +1 -1
  242. package/dist/types/src/components/ProcessTree/ProcessTree.d.ts +4 -3
  243. package/dist/types/src/components/ProcessTree/ProcessTree.d.ts.map +1 -1
  244. package/dist/types/src/components/ProcessTree/ProcessTree.stories.d.ts +0 -1
  245. package/dist/types/src/components/ProcessTree/ProcessTree.stories.d.ts.map +1 -1
  246. package/dist/types/src/components/RoutineProperties/RoutineProperties.d.ts +7 -0
  247. package/dist/types/src/components/RoutineProperties/RoutineProperties.d.ts.map +1 -0
  248. package/dist/types/src/components/RoutineProperties/RoutineProperties.stories.d.ts +15 -0
  249. package/dist/types/src/components/RoutineProperties/RoutineProperties.stories.d.ts.map +1 -0
  250. package/dist/types/src/components/RoutineProperties/index.d.ts +2 -0
  251. package/dist/types/src/components/RoutineProperties/index.d.ts.map +1 -0
  252. package/dist/types/src/components/TaskList/TaskList.d.ts +10 -0
  253. package/dist/types/src/components/TaskList/TaskList.d.ts.map +1 -0
  254. package/dist/types/src/components/TaskList/TaskList.stories.d.ts +16 -0
  255. package/dist/types/src/components/TaskList/TaskList.stories.d.ts.map +1 -0
  256. package/dist/types/src/components/TaskList/index.d.ts +2 -0
  257. package/dist/types/src/components/TaskList/index.d.ts.map +1 -0
  258. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts +5 -3
  259. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
  260. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
  261. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +4 -5
  262. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
  263. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +1 -1
  264. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -1
  265. package/dist/types/src/components/TemplateEditor/extensions/handlebars-extension.d.ts.map +1 -1
  266. package/dist/types/src/components/TemplateEditor/extensions/xml-extension.d.ts.map +1 -1
  267. package/dist/types/src/components/ToolBlock/ToolBlock.d.ts +4 -4
  268. package/dist/types/src/components/ToolBlock/ToolBlock.d.ts.map +1 -1
  269. package/dist/types/src/components/Toolbox/Toolbox.d.ts +3 -3
  270. package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
  271. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
  272. package/dist/types/src/components/index.d.ts +4 -0
  273. package/dist/types/src/components/index.d.ts.map +1 -1
  274. package/dist/types/src/constants.d.ts +5 -0
  275. package/dist/types/src/constants.d.ts.map +1 -0
  276. package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts.map +1 -1
  277. package/dist/types/src/containers/AgentArticle/AgentArticle.stories.d.ts +0 -2
  278. package/dist/types/src/containers/AgentArticle/AgentArticle.stories.d.ts.map +1 -1
  279. package/dist/types/src/containers/AgentProperties/AgentProperties.d.ts.map +1 -1
  280. package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts +1 -1
  281. package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts.map +1 -1
  282. package/dist/types/src/containers/ChatArticle/ChatArticle.d.ts +25 -0
  283. package/dist/types/src/containers/ChatArticle/ChatArticle.d.ts.map +1 -0
  284. package/dist/types/src/containers/ChatArticle/ChatArticle.stories.d.ts +15 -0
  285. package/dist/types/src/containers/ChatArticle/ChatArticle.stories.d.ts.map +1 -0
  286. package/dist/types/src/containers/ChatArticle/index.d.ts +2 -0
  287. package/dist/types/src/containers/ChatArticle/index.d.ts.map +1 -0
  288. package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts +11 -3
  289. package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts.map +1 -1
  290. package/dist/types/src/containers/ChatDialog/ChatDialog.d.ts.map +1 -1
  291. package/dist/types/src/containers/PlanArticle/PlanArticle.d.ts +6 -0
  292. package/dist/types/src/containers/PlanArticle/PlanArticle.d.ts.map +1 -0
  293. package/dist/types/src/containers/PlanArticle/index.d.ts +2 -0
  294. package/dist/types/src/containers/PlanArticle/index.d.ts.map +1 -0
  295. package/dist/types/src/containers/RoutineArticle/RoutineArticle.d.ts +6 -0
  296. package/dist/types/src/containers/RoutineArticle/RoutineArticle.d.ts.map +1 -0
  297. package/dist/types/src/containers/RoutineArticle/RoutineArticle.stories.d.ts +15 -0
  298. package/dist/types/src/containers/RoutineArticle/RoutineArticle.stories.d.ts.map +1 -0
  299. package/dist/types/src/containers/RoutineArticle/index.d.ts +2 -0
  300. package/dist/types/src/containers/RoutineArticle/index.d.ts.map +1 -0
  301. package/dist/types/src/containers/RoutineList/RoutineList.d.ts +6 -0
  302. package/dist/types/src/containers/RoutineList/RoutineList.d.ts.map +1 -0
  303. package/dist/types/src/containers/{PromptList/PromptList.stories.d.ts → RoutineList/RoutineList.stories.d.ts} +1 -1
  304. package/dist/types/src/containers/RoutineList/RoutineList.stories.d.ts.map +1 -0
  305. package/dist/types/src/containers/RoutineList/index.d.ts +2 -0
  306. package/dist/types/src/containers/RoutineList/index.d.ts.map +1 -0
  307. package/dist/types/src/containers/TracePanel/TracePanel.d.ts +4 -5
  308. package/dist/types/src/containers/TracePanel/TracePanel.d.ts.map +1 -1
  309. package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts +4 -3
  310. package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts.map +1 -1
  311. package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts +6 -6
  312. package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts.map +1 -1
  313. package/dist/types/src/containers/TracePanel/index.d.ts.map +1 -1
  314. package/dist/types/src/containers/TracePanel/testing/index.d.ts +3 -0
  315. package/dist/types/src/containers/TracePanel/testing/index.d.ts.map +1 -0
  316. package/dist/types/src/containers/TracePanel/testing/simulated-agent.d.ts +14 -0
  317. package/dist/types/src/containers/TracePanel/testing/simulated-agent.d.ts.map +1 -0
  318. package/dist/types/src/containers/TracePanel/testing/snapshot-playback.d.ts +12 -0
  319. package/dist/types/src/containers/TracePanel/testing/snapshot-playback.d.ts.map +1 -0
  320. package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts +3 -2
  321. package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts.map +1 -1
  322. package/dist/types/src/containers/TriggerStatus/index.d.ts +1 -1
  323. package/dist/types/src/containers/TriggerStatus/index.d.ts.map +1 -1
  324. package/dist/types/src/containers/index.d.ts +6 -5
  325. package/dist/types/src/containers/index.d.ts.map +1 -1
  326. package/dist/types/src/execution-graph/execution-graph.d.ts +108 -0
  327. package/dist/types/src/execution-graph/execution-graph.d.ts.map +1 -0
  328. package/dist/types/src/execution-graph/execution-graph.test.d.ts +2 -0
  329. package/dist/types/src/execution-graph/execution-graph.test.d.ts.map +1 -0
  330. package/dist/types/src/execution-graph/index.d.ts +3 -0
  331. package/dist/types/src/execution-graph/index.d.ts.map +1 -0
  332. package/dist/types/src/execution-graph/remote-snapshot.test.d.ts +2 -0
  333. package/dist/types/src/execution-graph/remote-snapshot.test.d.ts.map +1 -0
  334. package/dist/types/src/execution-graph/span-tree.d.ts +76 -0
  335. package/dist/types/src/execution-graph/span-tree.d.ts.map +1 -0
  336. package/dist/types/src/execution-graph/span-tree.test.d.ts +2 -0
  337. package/dist/types/src/execution-graph/span-tree.test.d.ts.map +1 -0
  338. package/dist/types/src/execution-graph/sub-agent-delegation.test.d.ts +2 -0
  339. package/dist/types/src/execution-graph/sub-agent-delegation.test.d.ts.map +1 -0
  340. package/dist/types/src/execution-graph/testing/collect-trace-events.d.ts +40 -0
  341. package/dist/types/src/execution-graph/testing/collect-trace-events.d.ts.map +1 -0
  342. package/dist/types/src/execution-graph/testing/index.d.ts +2 -0
  343. package/dist/types/src/execution-graph/testing/index.d.ts.map +1 -0
  344. package/dist/types/src/extensions/prompt-extension.d.ts.map +1 -1
  345. package/dist/types/src/feed-logger.d.ts +13 -0
  346. package/dist/types/src/feed-logger.d.ts.map +1 -0
  347. package/dist/types/src/functions/services.test.d.ts +2 -0
  348. package/dist/types/src/functions/services.test.d.ts.map +1 -0
  349. package/dist/types/src/hooks/index.d.ts +3 -0
  350. package/dist/types/src/hooks/index.d.ts.map +1 -1
  351. package/dist/types/src/hooks/useBlueprintRegistry.d.ts +56 -15
  352. package/dist/types/src/hooks/useBlueprintRegistry.d.ts.map +1 -1
  353. package/dist/types/src/hooks/useChatKeymap.d.ts +12 -0
  354. package/dist/types/src/hooks/useChatKeymap.d.ts.map +1 -0
  355. package/dist/types/src/hooks/useChatProcessor.d.ts +5 -5
  356. package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
  357. package/dist/types/src/hooks/useChatServices.d.ts +7 -3
  358. package/dist/types/src/hooks/useChatServices.d.ts.map +1 -1
  359. package/dist/types/src/hooks/useChatToolbarActions.d.ts.map +1 -1
  360. package/dist/types/src/hooks/useContextBinder.d.ts +2 -2
  361. package/dist/types/src/hooks/useContextBinder.d.ts.map +1 -1
  362. package/dist/types/src/hooks/useContextObjects.d.ts +5 -4
  363. package/dist/types/src/hooks/useContextObjects.d.ts.map +1 -1
  364. package/dist/types/src/hooks/useDebug.d.ts +10 -0
  365. package/dist/types/src/hooks/useDebug.d.ts.map +1 -0
  366. package/dist/types/src/hooks/useFilteredTypes.d.ts +1 -1
  367. package/dist/types/src/hooks/useFilteredTypes.d.ts.map +1 -1
  368. package/dist/types/src/hooks/useFlush.d.ts +1 -1
  369. package/dist/types/src/hooks/useFlush.d.ts.map +1 -1
  370. package/dist/types/src/hooks/usePresets.d.ts +2 -2
  371. package/dist/types/src/hooks/usePresets.d.ts.map +1 -1
  372. package/dist/types/src/hooks/useReferencesProvider.d.ts.map +1 -1
  373. package/dist/types/src/index.d.ts +1 -4
  374. package/dist/types/src/index.d.ts.map +1 -1
  375. package/dist/types/src/meta.d.ts +3 -2
  376. package/dist/types/src/meta.d.ts.map +1 -1
  377. package/dist/types/src/operations/create-chat.d.ts +3 -3
  378. package/dist/types/src/operations/create-chat.d.ts.map +1 -1
  379. package/dist/types/src/operations/ensure-companion-chat.d.ts +3 -3
  380. package/dist/types/src/operations/ensure-companion-chat.d.ts.map +1 -1
  381. package/dist/types/src/operations/fork-chat.d.ts +5 -0
  382. package/dist/types/src/operations/fork-chat.d.ts.map +1 -0
  383. package/dist/types/src/operations/index.d.ts +1 -2
  384. package/dist/types/src/operations/index.d.ts.map +1 -1
  385. package/dist/types/src/operations/prompt.node.test.d.ts +2 -0
  386. package/dist/types/src/operations/prompt.node.test.d.ts.map +1 -0
  387. package/dist/types/src/operations/resolve-navigation-targets.d.ts +4 -2
  388. package/dist/types/src/operations/resolve-navigation-targets.d.ts.map +1 -1
  389. package/dist/types/src/operations/run-prompt-in-new-chat.d.ts +3 -3
  390. package/dist/types/src/operations/run-prompt-in-new-chat.d.ts.map +1 -1
  391. package/dist/types/src/operations/set-current-chat.d.ts +3 -3
  392. package/dist/types/src/operations/set-current-chat.d.ts.map +1 -1
  393. package/dist/types/src/operations/toggle-trace-panel-debug.d.ts +5 -0
  394. package/dist/types/src/operations/toggle-trace-panel-debug.d.ts.map +1 -0
  395. package/dist/types/src/operations/update-chat-name.d.ts +3 -3
  396. package/dist/types/src/operations/update-chat-name.d.ts.map +1 -1
  397. package/dist/types/src/paths.d.ts +3 -0
  398. package/dist/types/src/paths.d.ts.map +1 -0
  399. package/dist/types/src/plugin.d.ts +4 -0
  400. package/dist/types/src/plugin.d.ts.map +1 -0
  401. package/dist/types/src/processor/presets.d.ts.map +1 -1
  402. package/dist/types/src/processor/processor.d.ts +263 -26
  403. package/dist/types/src/processor/processor.d.ts.map +1 -1
  404. package/dist/types/src/processor/processor.node.test.d.ts +2 -0
  405. package/dist/types/src/processor/processor.node.test.d.ts.map +1 -0
  406. package/dist/types/src/templates/automation-templates.test.d.ts +2 -0
  407. package/dist/types/src/templates/automation-templates.test.d.ts.map +1 -0
  408. package/dist/types/src/templates/daily-digest.d.ts +3 -0
  409. package/dist/types/src/templates/daily-digest.d.ts.map +1 -0
  410. package/dist/types/src/templates/index.d.ts +4 -0
  411. package/dist/types/src/templates/index.d.ts.map +1 -0
  412. package/dist/types/src/templates/research-brief.d.ts +3 -0
  413. package/dist/types/src/templates/research-brief.d.ts.map +1 -0
  414. package/dist/types/src/templates/scaffold.d.ts +17 -0
  415. package/dist/types/src/templates/scaffold.d.ts.map +1 -0
  416. package/dist/types/src/testing/index.d.ts +2 -0
  417. package/dist/types/src/testing/index.d.ts.map +1 -1
  418. package/dist/types/src/testing/snapshot.d.ts +21 -0
  419. package/dist/types/src/testing/snapshot.d.ts.map +1 -0
  420. package/dist/types/src/testing/test-generator.d.ts +2 -3
  421. package/dist/types/src/testing/test-generator.d.ts.map +1 -1
  422. package/dist/types/src/testing/test-generator.test.d.ts +2 -0
  423. package/dist/types/src/testing/test-generator.test.d.ts.map +1 -0
  424. package/dist/types/src/testing/test-sequence.d.ts +10 -3
  425. package/dist/types/src/testing/test-sequence.d.ts.map +1 -1
  426. package/dist/types/src/testing/test-services.d.ts.map +1 -1
  427. package/dist/types/src/testing/test-trace.d.ts +5 -0
  428. package/dist/types/src/testing/test-trace.d.ts.map +1 -0
  429. package/dist/types/src/testing/trace-timeline.node.test.d.ts +2 -0
  430. package/dist/types/src/testing/trace-timeline.node.test.d.ts.map +1 -0
  431. package/dist/types/src/testing.d.ts +2 -0
  432. package/dist/types/src/testing.d.ts.map +1 -0
  433. package/dist/types/src/translations.d.ts.map +1 -1
  434. package/dist/types/src/types/Assistant.d.ts +25 -8
  435. package/dist/types/src/types/Assistant.d.ts.map +1 -1
  436. package/dist/types/src/types/AssistantCapabilities.d.ts +30 -0
  437. package/dist/types/src/types/AssistantCapabilities.d.ts.map +1 -0
  438. package/dist/types/src/types/AssistantEvents.d.ts +3 -0
  439. package/dist/types/src/types/AssistantEvents.d.ts.map +1 -0
  440. package/dist/types/src/types/AssistantOperation.d.ts +153 -0
  441. package/dist/types/src/types/AssistantOperation.d.ts.map +1 -0
  442. package/dist/types/src/types/Settings.d.ts +21 -5
  443. package/dist/types/src/types/Settings.d.ts.map +1 -1
  444. package/dist/types/src/types/index.d.ts +8 -3
  445. package/dist/types/src/types/index.d.ts.map +1 -1
  446. package/dist/types/src/types/preset.d.ts +12 -0
  447. package/dist/types/src/types/preset.d.ts.map +1 -0
  448. package/dist/types/src/types/service.d.ts +2 -3
  449. package/dist/types/src/types/service.d.ts.map +1 -1
  450. package/dist/types/src/util/suggestions.d.ts +9 -0
  451. package/dist/types/src/util/suggestions.d.ts.map +1 -0
  452. package/dist/types/src/util/suggestions.test.d.ts +2 -0
  453. package/dist/types/src/util/suggestions.test.d.ts.map +1 -0
  454. package/dist/types/tsconfig.tsbuildinfo +1 -1
  455. package/package.json +177 -146
  456. package/src/AssistantPlugin.conversations.json +1 -0
  457. package/src/AssistantPlugin.node.ts +90 -0
  458. package/src/AssistantPlugin.test.ts +213 -0
  459. package/src/AssistantPlugin.ts +158 -0
  460. package/src/AssistantPlugin.workerd.ts +41 -0
  461. package/src/blueprints/assistant/{blueprint.test.ts → blueprint.node.test.ts} +5 -5
  462. package/src/blueprints/assistant/blueprint.ts +4 -4
  463. package/src/capabilities/agent-hydrator.ts +37 -0
  464. package/src/capabilities/agent-service.ts +38 -0
  465. package/src/capabilities/ai-context.ts +48 -0
  466. package/src/capabilities/ai-service.ts +31 -11
  467. package/src/capabilities/app-graph-builder.ts +106 -86
  468. package/src/capabilities/automation-templates.ts +16 -0
  469. package/src/capabilities/blueprint-definition.ts +15 -8
  470. package/src/capabilities/companion-chat-provisioner.ts +5 -5
  471. package/src/capabilities/create-object.ts +100 -0
  472. package/src/capabilities/edge-model-resolver.ts +53 -16
  473. package/src/capabilities/index.ts +23 -3
  474. package/src/capabilities/integration-provider.ts +86 -0
  475. package/src/capabilities/{markdown.ts → markdown-extension.ts} +3 -3
  476. package/src/capabilities/migrations.ts +4 -11
  477. package/src/capabilities/operation-handler.ts +1 -1
  478. package/src/capabilities/react-surface.tsx +41 -21
  479. package/src/components/AgentProperties/AgentProperties.stories.tsx +74 -0
  480. package/src/components/AgentProperties/AgentProperties.tsx +103 -0
  481. package/src/components/AgentProperties/index.ts +5 -0
  482. package/src/components/AssistantSettings/AssistantSettings.stories.tsx +3 -2
  483. package/src/components/AssistantSettings/AssistantSettings.tsx +22 -111
  484. package/src/components/Chat/Chat.tsx +145 -277
  485. package/src/components/Chat/context.ts +39 -0
  486. package/src/components/Chat/events.ts +7 -0
  487. package/src/components/ChatPrompt/ChatActions.tsx +11 -11
  488. package/src/components/ChatPrompt/ChatMcpErrors.tsx +50 -0
  489. package/src/components/ChatPrompt/ChatOptions.stories.tsx +32 -18
  490. package/src/components/ChatPrompt/ChatOptions.tsx +121 -103
  491. package/src/components/ChatPrompt/ChatPresets.tsx +3 -7
  492. package/src/components/ChatPrompt/ChatPrompt.tsx +180 -0
  493. package/src/components/ChatPrompt/ChatReferences.tsx +9 -13
  494. package/src/components/ChatPrompt/ChatStatus.tsx +123 -0
  495. package/src/components/ChatPrompt/ChatStatusIndicator.tsx +2 -2
  496. package/src/components/ChatPrompt/index.ts +3 -0
  497. package/src/components/ChatThread/Anchor.stories.tsx +95 -0
  498. package/src/components/ChatThread/ChatThread.stories.tsx +33 -37
  499. package/src/components/ChatThread/ChatThread.tsx +47 -23
  500. package/src/components/ChatThread/DEBUG.md +41 -0
  501. package/src/components/ChatThread/Link.tsx +5 -5
  502. package/src/components/ChatThread/MarkdownStream.stories.tsx +43 -5
  503. package/src/components/ChatThread/registry.tsx +80 -28
  504. package/src/components/ChatThread/sync.test.ts +180 -22
  505. package/src/components/ChatThread/sync.ts +89 -104
  506. package/src/components/ChatThread/testing/reasoning.md +25 -0
  507. package/src/components/ChatThread/widgets/FallbackWidget.tsx +8 -6
  508. package/src/components/ChatThread/widgets/ReasoningWidget.ts +13 -7
  509. package/src/components/ChatThread/widgets/ReferenceWidget.ts +3 -1
  510. package/src/components/ChatThread/widgets/SelectWidget.ts +4 -2
  511. package/src/components/ChatThread/widgets/StatsWidget.ts +3 -1
  512. package/src/components/ChatThread/widgets/StatusWidget.ts +6 -86
  513. package/src/components/ChatThread/widgets/SuggestionWidget.ts +2 -2
  514. package/src/components/ChatThread/widgets/SummaryWidget.tsx +7 -6
  515. package/src/components/ChatThread/widgets/ToolWidget.stories.tsx +2 -1
  516. package/src/components/ChatThread/widgets/ToolWidget.tsx +42 -25
  517. package/src/components/ChatThread/widgets/defaults.ts +8 -0
  518. package/src/components/ChatThread/widgets/index.ts +1 -2
  519. package/src/components/ProcessTree/ProcessTree.stories.tsx +13 -39
  520. package/src/components/ProcessTree/ProcessTree.tsx +101 -67
  521. package/src/components/RoutineProperties/RoutineProperties.stories.tsx +59 -0
  522. package/src/components/RoutineProperties/RoutineProperties.tsx +23 -0
  523. package/src/components/RoutineProperties/index.ts +5 -0
  524. package/src/components/TaskList/TaskList.stories.tsx +44 -0
  525. package/src/components/TaskList/TaskList.tsx +45 -0
  526. package/src/components/TaskList/index.ts +5 -0
  527. package/src/components/TemplateEditor/TemplateEditor.stories.tsx +6 -5
  528. package/src/components/TemplateEditor/TemplateEditor.tsx +12 -10
  529. package/src/components/TemplateEditor/TemplateForm.stories.tsx +6 -9
  530. package/src/components/TemplateEditor/TemplateForm.tsx +52 -73
  531. package/src/components/TemplateEditor/extensions/handlebars-extension.ts +2 -2
  532. package/src/components/ToolBlock/ToolBlock.tsx +25 -17
  533. package/src/components/Toolbox/Toolbox.stories.tsx +6 -5
  534. package/src/components/Toolbox/Toolbox.tsx +6 -5
  535. package/src/components/index.ts +6 -0
  536. package/src/constants.ts +9 -0
  537. package/src/containers/AgentArticle/AgentArticle.stories.tsx +19 -15
  538. package/src/containers/AgentArticle/AgentArticle.tsx +47 -53
  539. package/src/containers/AgentProperties/AgentProperties.tsx +20 -135
  540. package/src/containers/BlueprintArticle/BlueprintArticle.tsx +2 -2
  541. package/src/containers/ChatArticle/ChatArticle.stories.tsx +78 -0
  542. package/src/containers/ChatArticle/ChatArticle.tsx +112 -0
  543. package/src/containers/ChatArticle/index.ts +5 -0
  544. package/src/containers/ChatCompanion/ChatCompanion.tsx +94 -109
  545. package/src/containers/ChatDialog/ChatDialog.tsx +6 -11
  546. package/src/containers/PlanArticle/PlanArticle.tsx +33 -0
  547. package/src/containers/PlanArticle/index.ts +5 -0
  548. package/src/containers/RoutineArticle/RoutineArticle.stories.tsx +75 -0
  549. package/src/containers/RoutineArticle/RoutineArticle.tsx +109 -0
  550. package/src/containers/RoutineArticle/index.ts +5 -0
  551. package/src/containers/{PromptList/PromptList.stories.tsx → RoutineList/RoutineList.stories.tsx} +14 -13
  552. package/src/containers/{PromptList/PromptList.tsx → RoutineList/RoutineList.tsx} +9 -8
  553. package/src/containers/RoutineList/index.ts +5 -0
  554. package/src/containers/TracePanel/TracePanel.stories.tsx +285 -168
  555. package/src/containers/TracePanel/TracePanel.tsx +220 -77
  556. package/src/containers/TracePanel/dxn-extractor.test.ts +32 -32
  557. package/src/containers/TracePanel/dxn-extractor.ts +52 -64
  558. package/src/containers/TracePanel/testing/index.ts +6 -0
  559. package/src/containers/TracePanel/testing/simulated-agent.ts +114 -0
  560. package/src/containers/TracePanel/testing/snapshot-playback.ts +45 -0
  561. package/src/containers/TriggerStatus/TriggerStatus.tsx +20 -34
  562. package/src/containers/TriggerStatus/index.ts +1 -1
  563. package/src/containers/index.ts +6 -5
  564. package/src/execution-graph/SPEC.md +690 -0
  565. package/src/execution-graph/execution-graph.test.ts +891 -0
  566. package/src/execution-graph/execution-graph.ts +777 -0
  567. package/src/execution-graph/index.ts +24 -0
  568. package/src/execution-graph/remote-snapshot.test.ts +116 -0
  569. package/src/execution-graph/span-tree.test.ts +249 -0
  570. package/src/execution-graph/span-tree.ts +269 -0
  571. package/src/execution-graph/sub-agent-delegation.test.ts +50 -0
  572. package/src/execution-graph/testing/collect-trace-events.ts +74 -0
  573. package/src/execution-graph/testing/index.ts +5 -0
  574. package/src/execution-graph/testing/sub-agent-delegation.json +1285 -0
  575. package/src/{queue-logger.ts → feed-logger.ts} +39 -25
  576. package/src/functions/services.test.ts +53 -0
  577. package/src/hooks/index.ts +5 -0
  578. package/src/hooks/useBlueprintRegistry.ts +62 -46
  579. package/src/hooks/useChatKeymap.ts +52 -0
  580. package/src/hooks/useChatProcessor.ts +33 -17
  581. package/src/hooks/useChatServices.ts +8 -6
  582. package/src/hooks/useChatToolbarActions.ts +98 -96
  583. package/src/hooks/useContextBinder.ts +7 -7
  584. package/src/hooks/useContextObjects.ts +6 -5
  585. package/src/hooks/useDebug.ts +38 -0
  586. package/src/hooks/useFilteredTypes.ts +18 -16
  587. package/src/hooks/usePresets.ts +5 -3
  588. package/src/hooks/useReferencesProvider.ts +7 -15
  589. package/src/index.ts +1 -5
  590. package/src/meta.ts +27 -8
  591. package/src/operations/create-chat.ts +15 -38
  592. package/src/operations/ensure-companion-chat.ts +49 -47
  593. package/src/operations/fork-chat.ts +112 -0
  594. package/src/operations/index.ts +3 -4
  595. package/src/operations/prompt.node.test.ts +82 -0
  596. package/src/operations/resolve-navigation-targets.ts +8 -3
  597. package/src/operations/run-prompt-in-new-chat.ts +87 -87
  598. package/src/operations/set-current-chat.ts +6 -7
  599. package/src/operations/toggle-trace-panel-debug.ts +27 -0
  600. package/src/operations/update-chat-name.ts +24 -20
  601. package/src/paths.ts +10 -0
  602. package/src/plugin.ts +11 -0
  603. package/src/processor/presets.ts +15 -11
  604. package/src/processor/{processor.test.ts → processor.node.test.ts} +7 -7
  605. package/src/processor/processor.ts +160 -58
  606. package/src/templates/automation-templates.test.ts +66 -0
  607. package/src/templates/daily-digest.ts +37 -0
  608. package/src/templates/index.ts +11 -0
  609. package/src/templates/research-brief.ts +40 -0
  610. package/src/templates/scaffold.ts +74 -0
  611. package/src/testing/data/trace-timeline-multiple.dx.json +1 -0
  612. package/src/testing/data/trace-timeline-remote.dx.json +1 -0
  613. package/src/testing/data/trace-timeline.dx.json +4657 -0
  614. package/src/testing/index.ts +2 -0
  615. package/src/testing/snapshot.ts +35 -0
  616. package/src/testing/test-generator.test.ts +71 -0
  617. package/src/testing/test-generator.ts +196 -205
  618. package/src/testing/test-sequence.ts +3 -3
  619. package/src/testing/test-services.ts +1 -1
  620. package/src/testing/test-trace.ts +20 -0
  621. package/src/testing/trace-timeline.node.conversations.json +1 -0
  622. package/src/testing/{trace-timeline.test.ts → trace-timeline.node.test.ts} +45 -50
  623. package/src/testing.ts +9 -0
  624. package/src/translations.ts +40 -38
  625. package/src/types/Assistant.ts +13 -1
  626. package/src/types/AssistantCapabilities.ts +35 -0
  627. package/src/types/AssistantEvents.ts +11 -0
  628. package/src/{operations/definitions.ts → types/AssistantOperation.ts} +66 -29
  629. package/src/types/Settings.ts +68 -7
  630. package/src/types/index.ts +12 -3
  631. package/src/types/preset.ts +16 -0
  632. package/src/types/service.ts +5 -10
  633. package/src/util/suggestions.test.ts +52 -0
  634. package/src/util/suggestions.ts +42 -0
  635. package/src/vite-env.d.ts +5 -0
  636. package/dist/lib/browser/AssistantSettings-7QMO3LGF.mjs +0 -97
  637. package/dist/lib/browser/AssistantSettings-7QMO3LGF.mjs.map +0 -7
  638. package/dist/lib/browser/chunk-ATHYBVGN.mjs +0 -176
  639. package/dist/lib/browser/chunk-ATHYBVGN.mjs.map +0 -7
  640. package/dist/lib/browser/chunk-EZRS3J25.mjs.map +0 -7
  641. package/dist/lib/browser/chunk-LMVTXH54.mjs +0 -154
  642. package/dist/lib/browser/chunk-LMVTXH54.mjs.map +0 -7
  643. package/dist/lib/browser/create-chat-LBZHGVSN.mjs +0 -82
  644. package/dist/lib/browser/create-chat-LBZHGVSN.mjs.map +0 -7
  645. package/dist/lib/browser/ensure-companion-chat-ZEZA34MZ.mjs.map +0 -7
  646. package/dist/lib/browser/index.mjs +0 -3452
  647. package/dist/lib/browser/index.mjs.map +0 -7
  648. package/dist/lib/browser/meta.json +0 -1
  649. package/dist/lib/browser/on-create-space-54RNX5JI.mjs +0 -22
  650. package/dist/lib/browser/on-create-space-54RNX5JI.mjs.map +0 -7
  651. package/dist/lib/browser/operations/index.mjs +0 -13
  652. package/dist/lib/browser/operations/index.mjs.map +0 -7
  653. package/dist/lib/browser/resolve-navigation-targets-NZOD66NY.mjs.map +0 -7
  654. package/dist/lib/browser/run-prompt-in-new-chat-THLK5YQC.mjs.map +0 -7
  655. package/dist/lib/browser/set-current-chat-LRS3VFSH.mjs.map +0 -7
  656. package/dist/lib/browser/types/index.mjs +0 -20
  657. package/dist/lib/browser/update-chat-name-3Y36KFAS.mjs.map +0 -7
  658. package/dist/lib/node-esm/AssistantSettings-UVUTKO7E.mjs +0 -98
  659. package/dist/lib/node-esm/AssistantSettings-UVUTKO7E.mjs.map +0 -7
  660. package/dist/lib/node-esm/blueprints/index.mjs +0 -9
  661. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +0 -11
  662. package/dist/lib/node-esm/chunk-NZIKC7AN.mjs +0 -32
  663. package/dist/lib/node-esm/chunk-NZIKC7AN.mjs.map +0 -7
  664. package/dist/lib/node-esm/chunk-PXAJSTGZ.mjs +0 -177
  665. package/dist/lib/node-esm/chunk-PXAJSTGZ.mjs.map +0 -7
  666. package/dist/lib/node-esm/chunk-W3JZ2F4T.mjs +0 -155
  667. package/dist/lib/node-esm/chunk-W3JZ2F4T.mjs.map +0 -7
  668. package/dist/lib/node-esm/create-chat-3BEG4R6J.mjs +0 -83
  669. package/dist/lib/node-esm/create-chat-3BEG4R6J.mjs.map +0 -7
  670. package/dist/lib/node-esm/ensure-companion-chat-6K2WEWFP.mjs +0 -66
  671. package/dist/lib/node-esm/ensure-companion-chat-6K2WEWFP.mjs.map +0 -7
  672. package/dist/lib/node-esm/index.mjs +0 -3453
  673. package/dist/lib/node-esm/index.mjs.map +0 -7
  674. package/dist/lib/node-esm/meta.json +0 -1
  675. package/dist/lib/node-esm/on-create-space-YRPZ6HZY.mjs +0 -23
  676. package/dist/lib/node-esm/on-create-space-YRPZ6HZY.mjs.map +0 -7
  677. package/dist/lib/node-esm/operations/index.mjs +0 -14
  678. package/dist/lib/node-esm/operations/index.mjs.map +0 -7
  679. package/dist/lib/node-esm/resolve-navigation-targets-3PPK7XLH.mjs +0 -23
  680. package/dist/lib/node-esm/resolve-navigation-targets-3PPK7XLH.mjs.map +0 -7
  681. package/dist/lib/node-esm/run-prompt-in-new-chat-OUYKCMQ7.mjs +0 -137
  682. package/dist/lib/node-esm/run-prompt-in-new-chat-OUYKCMQ7.mjs.map +0 -7
  683. package/dist/lib/node-esm/set-current-chat-SMXZJD3F.mjs +0 -55
  684. package/dist/lib/node-esm/set-current-chat-SMXZJD3F.mjs.map +0 -7
  685. package/dist/lib/node-esm/types/index.mjs +0 -21
  686. package/dist/lib/node-esm/update-chat-name-HM2P4NSI.mjs +0 -72
  687. package/dist/lib/node-esm/update-chat-name-HM2P4NSI.mjs.map +0 -7
  688. package/dist/types/src/blueprints/assistant/blueprint.test.d.ts +0 -2
  689. package/dist/types/src/blueprints/assistant/blueprint.test.d.ts.map +0 -1
  690. package/dist/types/src/capabilities/markdown.d.ts.map +0 -1
  691. package/dist/types/src/components/ChatProgress/ChatProgress.d.ts +0 -10
  692. package/dist/types/src/components/ChatProgress/ChatProgress.d.ts.map +0 -1
  693. package/dist/types/src/components/ChatProgress/index.d.ts +0 -2
  694. package/dist/types/src/components/ChatProgress/index.d.ts.map +0 -1
  695. package/dist/types/src/components/ChatThread/widgets/PromptWidget.d.ts +0 -14
  696. package/dist/types/src/components/ChatThread/widgets/PromptWidget.d.ts.map +0 -1
  697. package/dist/types/src/containers/AgentProperties/AgentProperties.stories.d.ts.map +0 -1
  698. package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts +0 -12
  699. package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts.map +0 -1
  700. package/dist/types/src/containers/ChatContainer/index.d.ts +0 -2
  701. package/dist/types/src/containers/ChatContainer/index.d.ts.map +0 -1
  702. package/dist/types/src/containers/PromptArticle/PromptArticle.d.ts +0 -6
  703. package/dist/types/src/containers/PromptArticle/PromptArticle.d.ts.map +0 -1
  704. package/dist/types/src/containers/PromptArticle/index.d.ts +0 -2
  705. package/dist/types/src/containers/PromptArticle/index.d.ts.map +0 -1
  706. package/dist/types/src/containers/PromptList/PromptList.d.ts +0 -6
  707. package/dist/types/src/containers/PromptList/PromptList.d.ts.map +0 -1
  708. package/dist/types/src/containers/PromptList/PromptList.stories.d.ts.map +0 -1
  709. package/dist/types/src/containers/PromptList/index.d.ts +0 -2
  710. package/dist/types/src/containers/PromptList/index.d.ts.map +0 -1
  711. package/dist/types/src/containers/TracePanel/execution-graph.d.ts +0 -17
  712. package/dist/types/src/containers/TracePanel/execution-graph.d.ts.map +0 -1
  713. package/dist/types/src/operations/definitions.d.ts +0 -135
  714. package/dist/types/src/operations/definitions.d.ts.map +0 -1
  715. package/dist/types/src/operations/on-create-space.d.ts +0 -5
  716. package/dist/types/src/operations/on-create-space.d.ts.map +0 -1
  717. package/dist/types/src/processor/processor.test.d.ts +0 -2
  718. package/dist/types/src/processor/processor.test.d.ts.map +0 -1
  719. package/dist/types/src/queue-logger.d.ts +0 -11
  720. package/dist/types/src/queue-logger.d.ts.map +0 -1
  721. package/dist/types/src/testing/trace-timeline.test.d.ts +0 -2
  722. package/dist/types/src/testing/trace-timeline.test.d.ts.map +0 -1
  723. package/dist/types/src/types/capabilities.d.ts +0 -32
  724. package/dist/types/src/types/capabilities.d.ts.map +0 -1
  725. package/dist/types/src/types/defs.d.ts +0 -2
  726. package/dist/types/src/types/defs.d.ts.map +0 -1
  727. package/dist/types/src/types/events.d.ts +0 -5
  728. package/dist/types/src/types/events.d.ts.map +0 -1
  729. package/src/AssistantPlugin.tsx +0 -233
  730. package/src/components/ChatProgress/ChatProgress.tsx +0 -56
  731. package/src/components/ChatProgress/index.ts +0 -5
  732. package/src/components/ChatThread/widgets/PromptWidget.ts +0 -28
  733. package/src/containers/AgentProperties/AgentProperties.stories.tsx +0 -100
  734. package/src/containers/ChatContainer/ChatContainer.tsx +0 -95
  735. package/src/containers/ChatContainer/index.ts +0 -5
  736. package/src/containers/PromptArticle/PromptArticle.tsx +0 -59
  737. package/src/containers/PromptArticle/index.ts +0 -5
  738. package/src/containers/PromptList/index.ts +0 -5
  739. package/src/containers/TracePanel/execution-graph.ts +0 -425
  740. package/src/operations/on-create-space.ts +0 -24
  741. package/src/testing/trace-timeline.conversations.json +0 -1
  742. package/src/types/capabilities.ts +0 -35
  743. package/src/types/defs.ts +0 -5
  744. package/src/types/events.ts +0 -11
  745. /package/dist/lib/{browser/blueprints/index.mjs.map → neutral/AssistantPlugin.mjs.map} +0 -0
  746. /package/dist/lib/{browser/chunk-J5LGTIGS.mjs.map → neutral/ChatArticle-VNVZCDUR.mjs.map} +0 -0
  747. /package/dist/lib/{browser/types → neutral/blueprints}/index.mjs.map +0 -0
  748. /package/dist/lib/{browser → neutral}/chunk-J5LGTIGS.mjs +0 -0
  749. /package/dist/lib/{node-esm/blueprints/index.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
  750. /package/dist/lib/{node-esm/types → neutral}/index.mjs.map +0 -0
  751. /package/dist/lib/{node-esm/chunk-HSLMI22Q.mjs.map → neutral/meta.mjs.map} +0 -0
@@ -0,0 +1,891 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+ import { describe, test } from 'vitest';
7
+
8
+ import { AgentRequestBegin, AgentRequestEnd, CompleteBlock } from '@dxos/assistant';
9
+ import { Trace } from '@dxos/compute';
10
+ import { EntityId } from '@dxos/keys';
11
+ import { LogLevel } from '@dxos/log';
12
+ import { type Commit, renderTimelineAscii } from '@dxos/react-ui-components';
13
+
14
+ import { CommitSelector, buildExecutionGraph } from './execution-graph';
15
+ import { collectTraceEvents, withMeta } from './testing';
16
+
17
+ EntityId.dangerouslyDisableRandomness();
18
+
19
+ const makeCommit = (id: string, opts: Partial<Commit> = {}): Commit => ({
20
+ id,
21
+ branch: opts.branch ?? 'main',
22
+ message: opts.message ?? id,
23
+ ...opts,
24
+ });
25
+
26
+ const ids = (commits: Commit[]) => commits.map((commit) => commit.id);
27
+
28
+ const renderGraph = (messages: Trace.Message[]) => {
29
+ const { commits, branches } = buildExecutionGraph({ traceMessages: messages });
30
+ return renderTimelineAscii(commits, branches);
31
+ };
32
+
33
+ describe('CommitSelector', () => {
34
+ describe('make', () => {
35
+ test('wraps a select function', ({ expect }) => {
36
+ const selector = CommitSelector.make((commits) => commits);
37
+ const a = makeCommit('a');
38
+ expect(selector.select([a])).toEqual([a]);
39
+ });
40
+
41
+ test('returns a pipeable selector', ({ expect }) => {
42
+ const selector = CommitSelector.make((commits) => commits);
43
+ expect(typeof selector.pipe).toBe('function');
44
+ });
45
+
46
+ test('does not mutate the input array', ({ expect }) => {
47
+ const input = [makeCommit('a'), makeCommit('b')];
48
+ const before = [...input];
49
+ CommitSelector.identity().select(input);
50
+ expect(input).toEqual(before);
51
+ });
52
+ });
53
+
54
+ describe('identity', () => {
55
+ test('returns all commits', ({ expect }) => {
56
+ const a = makeCommit('a');
57
+ const b = makeCommit('b');
58
+ expect(CommitSelector.identity().select([a, b])).toEqual([a, b]);
59
+ });
60
+
61
+ test('returns empty for empty input', ({ expect }) => {
62
+ expect(CommitSelector.identity().select([])).toEqual([]);
63
+ });
64
+ });
65
+
66
+ describe('filter', () => {
67
+ test('keeps commits matching predicate', ({ expect }) => {
68
+ const a = makeCommit('a', { tags: ['x'] });
69
+ const b = makeCommit('b');
70
+ const selector = CommitSelector.filter((commit) => commit.tags?.includes('x'));
71
+ expect(selector.select([a, b])).toEqual([a]);
72
+ });
73
+
74
+ test('returns empty array on no match', ({ expect }) => {
75
+ const a = makeCommit('a');
76
+ expect(CommitSelector.filter(() => false).select([a])).toEqual([]);
77
+ });
78
+ });
79
+
80
+ describe('id', () => {
81
+ test('matches a single commit by id', ({ expect }) => {
82
+ const a = makeCommit('a');
83
+ const b = makeCommit('b');
84
+ expect(CommitSelector.id('b').select([a, b])).toEqual([b]);
85
+ });
86
+
87
+ test('returns empty when id is missing', ({ expect }) => {
88
+ expect(CommitSelector.id('missing').select([makeCommit('a')])).toEqual([]);
89
+ });
90
+ });
91
+
92
+ describe('tag', () => {
93
+ test('matches commits whose tags include the tag', ({ expect }) => {
94
+ const a = makeCommit('a', { tags: ['x'] });
95
+ const b = makeCommit('b', { tags: ['y'] });
96
+ expect(CommitSelector.tag('x').select([a, b])).toEqual([a]);
97
+ });
98
+
99
+ test('returns empty for falsy tag (undefined / null / false)', ({ expect }) => {
100
+ const a = makeCommit('a', { tags: ['x'] });
101
+ expect(CommitSelector.tag(undefined).select([a])).toEqual([]);
102
+ expect(CommitSelector.tag(null).select([a])).toEqual([]);
103
+ expect(CommitSelector.tag(false).select([a])).toEqual([]);
104
+ });
105
+
106
+ test('returns empty when commit has no tags', ({ expect }) => {
107
+ expect(CommitSelector.tag('x').select([makeCommit('a')])).toEqual([]);
108
+ });
109
+ });
110
+
111
+ describe('branch', () => {
112
+ test('matches commits by branch', ({ expect }) => {
113
+ const a = makeCommit('a', { branch: 'main' });
114
+ const b = makeCommit('b', { branch: 'feature' });
115
+ expect(CommitSelector.branch('feature').select([a, b])).toEqual([b]);
116
+ });
117
+ });
118
+
119
+ describe('compose', () => {
120
+ test('applies next selector after prev', ({ expect }) => {
121
+ const a = makeCommit('a', { branch: 'main', tags: ['keep'] });
122
+ const b = makeCommit('b', { branch: 'main' });
123
+ const c = makeCommit('c', { branch: 'feature', tags: ['keep'] });
124
+ const selector = CommitSelector.branch('main').pipe(CommitSelector.compose(CommitSelector.tag('keep')));
125
+ expect(selector.select([a, b, c])).toEqual([a]);
126
+ });
127
+ });
128
+
129
+ describe('orElse', () => {
130
+ test('returns prev result when prev is non-empty', ({ expect }) => {
131
+ const a = makeCommit('a', { branch: 'main' });
132
+ const b = makeCommit('b', { branch: 'feature' });
133
+ const selector = CommitSelector.branch('main').pipe(CommitSelector.orElse(CommitSelector.branch('feature')));
134
+ expect(selector.select([a, b])).toEqual([a]);
135
+ });
136
+
137
+ test('returns next result when prev is empty', ({ expect }) => {
138
+ const b = makeCommit('b', { branch: 'feature' });
139
+ const selector = CommitSelector.branch('main').pipe(CommitSelector.orElse(CommitSelector.branch('feature')));
140
+ expect(selector.select([b])).toEqual([b]);
141
+ });
142
+ });
143
+
144
+ describe('last', () => {
145
+ test('returns the last commit by default', ({ expect }) => {
146
+ const a = makeCommit('a');
147
+ const b = makeCommit('b');
148
+ const c = makeCommit('c');
149
+ expect(ids(CommitSelector.last().select([a, b, c]))).toEqual(['c']);
150
+ });
151
+
152
+ test('produces the most recent commit on a branch when composed', ({ expect }) => {
153
+ const a = makeCommit('a', { branch: 'main' });
154
+ const b = makeCommit('b', { branch: 'main' });
155
+ const c = makeCommit('c', { branch: 'main' });
156
+ const selector = CommitSelector.branch('main').pipe(CommitSelector.compose(CommitSelector.last()));
157
+ expect(ids(selector.select([a, b, c]))).toEqual(['c']);
158
+ });
159
+ });
160
+
161
+ describe('unionAll', () => {
162
+ test('combines results from multiple selectors', ({ expect }) => {
163
+ const a = makeCommit('a', { branch: 'main' });
164
+ const b = makeCommit('b', { branch: 'feature' });
165
+ const selector = CommitSelector.unionAll(CommitSelector.branch('main'), CommitSelector.branch('feature'));
166
+ expect(ids(selector.select([a, b])).toSorted()).toEqual(['a', 'b']);
167
+ });
168
+
169
+ test('dedupes by id', ({ expect }) => {
170
+ const a = makeCommit('a', { branch: 'main', tags: ['x'] });
171
+ const selector = CommitSelector.unionAll(CommitSelector.branch('main'), CommitSelector.tag('x'));
172
+ expect(selector.select([a])).toHaveLength(1);
173
+ });
174
+ });
175
+ });
176
+
177
+ const MESSAGE_ID = '01HQ0000000000000000000000';
178
+
179
+ describe('buildExecutionGraph (span-tree based)', () => {
180
+ test('empty input → no commits', ({ expect }) => {
181
+ const { commits, branches } = buildExecutionGraph({ traceMessages: [] });
182
+ expect(commits).toEqual([]);
183
+ expect(branches).toEqual(['main']);
184
+ });
185
+
186
+ test('top-level operation with no inner events → collapsed to single end commit on main', ({ expect }) => {
187
+ const messages = collectTraceEvents(
188
+ withMeta(
189
+ { pid: 'op-1' },
190
+ Effect.gen(function* () {
191
+ yield* Trace.write(Trace.OperationStart, { key: 'reply', name: 'Reply' });
192
+ yield* Trace.write(Trace.OperationEnd, { key: 'reply', name: 'Reply', outcome: 'success' });
193
+ }),
194
+ ),
195
+ );
196
+ const { commits, branches } = buildExecutionGraph({ traceMessages: messages });
197
+ expect(branches).toEqual(['main']);
198
+ expect(commits).toHaveLength(1);
199
+ expect(commits[0].branch).toBe('main');
200
+ expect(`\n${renderTimelineAscii(commits, branches)}\n`).toMatchInlineSnapshot(`
201
+ "
202
+ ● [function] Reply - Success
203
+ "
204
+ `);
205
+ });
206
+
207
+ test('nested operation under an agent → collapsed to a single end commit', ({ expect }) => {
208
+ const messages = collectTraceEvents(
209
+ Effect.gen(function* () {
210
+ yield* withMeta(
211
+ { pid: 'agent-1' },
212
+ Effect.gen(function* () {
213
+ yield* Trace.write(AgentRequestBegin, {});
214
+ yield* Trace.write(CompleteBlock, {
215
+ messageId: MESSAGE_ID,
216
+ role: 'user',
217
+ block: { _tag: 'text', text: 'hello', pending: false },
218
+ });
219
+ }),
220
+ );
221
+ yield* withMeta(
222
+ { pid: 'op-1', parentPid: 'agent-1' },
223
+ Effect.gen(function* () {
224
+ yield* Trace.write(Trace.OperationStart, { key: 'lookup', name: 'Lookup' });
225
+ yield* Trace.write(Trace.OperationEnd, { key: 'lookup', name: 'Lookup', outcome: 'success' });
226
+ }),
227
+ );
228
+ yield* withMeta({ pid: 'agent-1' }, Trace.write(AgentRequestEnd, { status: 'success' }));
229
+ }),
230
+ );
231
+ const { commits, branches } = buildExecutionGraph({ traceMessages: messages });
232
+ expect(branches).toEqual(['main', 'agent-1']);
233
+ expect(`\n${renderTimelineAscii(commits, branches)}\n`).toMatchInlineSnapshot(`
234
+ "
235
+ ● [atom] Agent processing request...
236
+ ├──● [user] hello
237
+ │ ● [function] Lookup - Success
238
+ ◆──╯ [atom] Agent completed request
239
+ "
240
+ `);
241
+ });
242
+
243
+ test('nested operation with its own inner status message → expanded fork/merge', ({ expect }) => {
244
+ const messages = collectTraceEvents(
245
+ withMeta(
246
+ { pid: 'op-1' },
247
+ Effect.gen(function* () {
248
+ yield* Trace.write(Trace.OperationStart, { key: 'work', name: 'Work' });
249
+ yield* Trace.write(CompleteBlock, {
250
+ messageId: MESSAGE_ID,
251
+ role: 'assistant',
252
+ block: { _tag: 'status', statusText: 'thinking', pending: false },
253
+ });
254
+ yield* Trace.write(Trace.OperationEnd, { key: 'work', name: 'Work', outcome: 'success' });
255
+ }),
256
+ ),
257
+ );
258
+ const { commits } = buildExecutionGraph({ traceMessages: messages });
259
+ // Three commits: begin on main, status on op-1 branch, end on main as merge.
260
+ expect(commits).toHaveLength(3);
261
+ expect(commits[0].branch).toBe('main');
262
+ expect(commits[1].branch).toBe('op-1');
263
+ expect(commits[2].branch).toBe('main');
264
+ expect(commits[2].parents?.length).toBe(2);
265
+ });
266
+
267
+ test('child process (sub-agent) forks onto its own branch from its first event', ({ expect }) => {
268
+ const messages = collectTraceEvents(
269
+ Effect.gen(function* () {
270
+ yield* withMeta({ pid: 'supervisor' }, Trace.write(AgentRequestBegin, {}));
271
+ // A delegated sub-agent runs as a separate process: its own pid, parented to the supervisor.
272
+ // With an inner status event the span is non-collapsible, so its begin event is emitted as a
273
+ // real fork — and because it crosses a process boundary it forks onto its OWN branch.
274
+ yield* withMeta(
275
+ { pid: 'sub', parentPid: 'supervisor' },
276
+ Effect.gen(function* () {
277
+ yield* Trace.write(Trace.OperationStart, { key: 'routine', name: 'Run Routine' });
278
+ yield* Trace.write(CompleteBlock, {
279
+ messageId: MESSAGE_ID,
280
+ role: 'assistant',
281
+ block: { _tag: 'status', statusText: 'working', pending: false },
282
+ });
283
+ yield* Trace.write(Trace.OperationEnd, { key: 'routine', name: 'Run Routine', outcome: 'success' });
284
+ }),
285
+ );
286
+ yield* withMeta({ pid: 'supervisor' }, Trace.write(AgentRequestEnd, { status: 'success' }));
287
+ }),
288
+ );
289
+ const { commits } = buildExecutionGraph({ traceMessages: messages });
290
+ // The sub-agent's begin ("Run Routine") lands on its OWN branch ('sub'), not the supervisor's —
291
+ // so a concurrent sub-agent gets its own lane from its first event rather than sharing the
292
+ // parent lane until its first middle commit.
293
+ const begin = commits.find((commit) => commit.message === 'Run Routine');
294
+ expect(begin?.branch).toBe('sub');
295
+ });
296
+
297
+ test('pending span with user message → user lands on own branch, not parent', ({ expect }) => {
298
+ const messages = collectTraceEvents(
299
+ // Agent has begun and emitted a user message, but has NOT yet completed.
300
+ withMeta(
301
+ { pid: 'agent-1' },
302
+ Effect.gen(function* () {
303
+ yield* Trace.write(AgentRequestBegin, {});
304
+ yield* Trace.write(CompleteBlock, {
305
+ messageId: MESSAGE_ID,
306
+ role: 'user',
307
+ block: { _tag: 'text', text: 'hello', pending: false },
308
+ });
309
+ }),
310
+ ),
311
+ );
312
+ const { commits, branches } = buildExecutionGraph({ traceMessages: messages });
313
+ // Two commits: AgentBegin on main (fork), user "hello" on agent-1 branch (middle).
314
+ // No end commit yet — the span is pending.
315
+ expect(commits).toHaveLength(2);
316
+ expect(commits[0].branch).toBe('main');
317
+ expect(commits[0].message).toBe('Agent processing request...');
318
+ expect(commits[1].branch).toBe('agent-1');
319
+ expect(commits[1].message).toBe('hello');
320
+ expect(`\n${renderTimelineAscii(commits, branches)}\n`).toMatchInlineSnapshot(`
321
+ "
322
+ ● [atom] Agent processing request...
323
+ ├──● [user] hello
324
+ "
325
+ `);
326
+ });
327
+
328
+ test('pending span with collapsed sub-span then user message → user on own branch', ({ expect }) => {
329
+ const messages = collectTraceEvents(
330
+ Effect.gen(function* () {
331
+ yield* withMeta({ pid: 'agent-1' }, Trace.write(AgentRequestBegin, {}));
332
+ // Sub-span completes (will be collapsed).
333
+ yield* withMeta(
334
+ { pid: 'op-1', parentPid: 'agent-1' },
335
+ Effect.gen(function* () {
336
+ yield* Trace.write(Trace.OperationStart, { key: 'lookup', name: 'Lookup' });
337
+ yield* Trace.write(Trace.OperationEnd, { key: 'lookup', name: 'Lookup', outcome: 'success' });
338
+ }),
339
+ );
340
+ // User message arrives after the sub-span; agent is still pending.
341
+ yield* withMeta(
342
+ { pid: 'agent-1' },
343
+ Trace.write(CompleteBlock, {
344
+ messageId: '01HQ0000000000000000000001',
345
+ role: 'user',
346
+ block: { _tag: 'text', text: 'hello', pending: false },
347
+ }),
348
+ );
349
+ }),
350
+ );
351
+ const { commits } = buildExecutionGraph({ traceMessages: messages });
352
+ // AgentBegin on main, Lookup-Success on agent branch, user "hello" on agent branch.
353
+ expect(commits).toHaveLength(3);
354
+ expect(commits[0].branch).toBe('main');
355
+ expect(commits[1].branch).toBe('agent-1');
356
+ expect(commits[2].branch).toBe('agent-1');
357
+ expect(commits[2].message).toBe('hello');
358
+ });
359
+
360
+ test('orders sub-spans chronologically under their parent', ({ expect }) => {
361
+ const messages = collectTraceEvents(
362
+ Effect.gen(function* () {
363
+ yield* withMeta({ pid: 'agent-1' }, Trace.write(AgentRequestBegin, {}));
364
+ yield* withMeta(
365
+ { pid: 'op-1', parentPid: 'agent-1' },
366
+ Effect.gen(function* () {
367
+ yield* Trace.write(Trace.OperationStart, { key: 'a', name: 'A' });
368
+ yield* Trace.write(Trace.OperationEnd, { key: 'a', name: 'A', outcome: 'success' });
369
+ }),
370
+ );
371
+ yield* withMeta(
372
+ { pid: 'op-2', parentPid: 'agent-1' },
373
+ Effect.gen(function* () {
374
+ yield* Trace.write(Trace.OperationStart, { key: 'b', name: 'B' });
375
+ yield* Trace.write(Trace.OperationEnd, { key: 'b', name: 'B', outcome: 'success' });
376
+ }),
377
+ );
378
+ yield* withMeta({ pid: 'agent-1' }, Trace.write(AgentRequestEnd, { status: 'success' }));
379
+ }),
380
+ );
381
+ const { commits } = buildExecutionGraph({ traceMessages: messages });
382
+ // After collapsing, expect: AgentBegin, Op1.End, Op2.End, AgentEnd → 4 commits.
383
+ expect(commits.map((commit) => commit.message)).toEqual([
384
+ 'Agent processing request...',
385
+ 'A - Success',
386
+ 'B - Success',
387
+ 'Agent completed request',
388
+ ]);
389
+ });
390
+ });
391
+
392
+ describe('buildExecutionGraph scenarios', () => {
393
+ /**
394
+ * Single top-level operation invocation. With no inner activity the span is collapsible
395
+ * and renders as a single end commit on `main`.
396
+ */
397
+ test('single top-level operation collapses to one commit on main', ({ expect }) => {
398
+ const messages = collectTraceEvents(
399
+ withMeta(
400
+ { pid: 'op-1' },
401
+ Effect.gen(function* () {
402
+ yield* Trace.write(Trace.OperationStart, { key: 'reply', name: 'Reply' });
403
+ yield* Trace.write(Trace.OperationEnd, { key: 'reply', name: 'Reply', outcome: 'success' });
404
+ }),
405
+ ),
406
+ );
407
+
408
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
409
+ "
410
+ ● [function] Reply - Success
411
+ "
412
+ `);
413
+ });
414
+
415
+ /**
416
+ * Top-level operation containing one nested operation. The parent has a child so it cannot
417
+ * collapse — it forks to its own branch on begin and merges back on end. The nested op is
418
+ * still collapsible so it emits a single end commit on the parent's branch.
419
+ */
420
+ test('top-level operation with one child forks then merges', ({ expect }) => {
421
+ const messages = collectTraceEvents(
422
+ Effect.gen(function* () {
423
+ yield* withMeta({ pid: 'parent-1' }, Trace.write(Trace.OperationStart, { key: 'parent', name: 'Parent' }));
424
+ yield* withMeta(
425
+ { pid: 'child-1', parentPid: 'parent-1' },
426
+ Effect.gen(function* () {
427
+ yield* Trace.write(Trace.OperationStart, { key: 'child', name: 'Child' });
428
+ yield* Trace.write(Trace.OperationEnd, { key: 'child', name: 'Child', outcome: 'success' });
429
+ }),
430
+ );
431
+ yield* withMeta(
432
+ { pid: 'parent-1' },
433
+ Trace.write(Trace.OperationEnd, { key: 'parent', name: 'Parent', outcome: 'success' }),
434
+ );
435
+ }),
436
+ );
437
+
438
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
439
+ "
440
+ ● [function] Parent
441
+ ├──● [function] Child - Success
442
+ ◆──╯ [function] Parent - Success
443
+ "
444
+ `);
445
+ });
446
+
447
+ /**
448
+ * Top-level operation with three sequential collapsible children. Each child renders one
449
+ * commit on the parent's own branch in chronological order, then the parent merges back.
450
+ */
451
+ test('top-level operation with N sequential children renders one commit per child', ({ expect }) => {
452
+ const messages = collectTraceEvents(
453
+ Effect.gen(function* () {
454
+ yield* withMeta({ pid: 'parent-1' }, Trace.write(Trace.OperationStart, { key: 'parent', name: 'Parent' }));
455
+ for (const name of ['Alpha', 'Beta', 'Gamma']) {
456
+ yield* withMeta(
457
+ { pid: `child-${name}`, parentPid: 'parent-1' },
458
+ Effect.gen(function* () {
459
+ yield* Trace.write(Trace.OperationStart, { key: name.toLowerCase(), name });
460
+ yield* Trace.write(Trace.OperationEnd, { key: name.toLowerCase(), name, outcome: 'success' });
461
+ }),
462
+ );
463
+ }
464
+ yield* withMeta(
465
+ { pid: 'parent-1' },
466
+ Trace.write(Trace.OperationEnd, { key: 'parent', name: 'Parent', outcome: 'success' }),
467
+ );
468
+ }),
469
+ );
470
+
471
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
472
+ "
473
+ ● [function] Parent
474
+ ├──● [function] Alpha - Success
475
+ │ ● [function] Beta - Success
476
+ │ ● [function] Gamma - Success
477
+ ◆──╯ [function] Parent - Success
478
+ "
479
+ `);
480
+ });
481
+
482
+ /**
483
+ * Two overlapping top-level operations (different pids, both parented at root). R2 starts
484
+ * before R1 ends. Each routine has a nested sub-operation so they cannot collapse — they
485
+ * occupy their own branches off main. Regression: end commits must anchor to the immediate
486
+ * predecessor on main rather than skipping back to their matching begin commit.
487
+ */
488
+ test('two overlapping top-level operations stay on independent branches without skip-back edges', ({ expect }) => {
489
+ const messages = collectTraceEvents(
490
+ Effect.gen(function* () {
491
+ yield* withMeta({ pid: 'r1' }, Trace.write(Trace.OperationStart, { key: 'routine', name: 'Run Routine 1' }));
492
+ yield* withMeta({ pid: 'r2' }, Trace.write(Trace.OperationStart, { key: 'routine', name: 'Run Routine 2' }));
493
+ yield* withMeta(
494
+ { pid: 'lookup-1', parentPid: 'r1' },
495
+ Effect.gen(function* () {
496
+ yield* Trace.write(Trace.OperationStart, { key: 'lookup', name: 'Lookup A' });
497
+ yield* Trace.write(Trace.OperationEnd, { key: 'lookup', name: 'Lookup A', outcome: 'success' });
498
+ }),
499
+ );
500
+ yield* withMeta(
501
+ { pid: 'lookup-2', parentPid: 'r2' },
502
+ Effect.gen(function* () {
503
+ yield* Trace.write(Trace.OperationStart, { key: 'lookup', name: 'Lookup B' });
504
+ yield* Trace.write(Trace.OperationEnd, { key: 'lookup', name: 'Lookup B', outcome: 'success' });
505
+ }),
506
+ );
507
+ yield* withMeta(
508
+ { pid: 'r1' },
509
+ Trace.write(Trace.OperationEnd, { key: 'routine', name: 'Run Routine 1', outcome: 'success' }),
510
+ );
511
+ yield* withMeta(
512
+ { pid: 'r2' },
513
+ Trace.write(Trace.OperationEnd, { key: 'routine', name: 'Run Routine 2', outcome: 'success' }),
514
+ );
515
+ }),
516
+ );
517
+
518
+ const { commits, branches } = buildExecutionGraph({ traceMessages: messages });
519
+ // Sanity check the regression invariant: every parent edge on main connects to the
520
+ // immediate predecessor on main, never to an older commit (which would render as a
521
+ // skip-back edge crossing intervening commits).
522
+ const mainCommits = commits.filter((commit) => commit.branch === 'main');
523
+ const mainIndexById = new Map(mainCommits.map((commit, index) => [commit.id, index]));
524
+ for (let index = 1; index < mainCommits.length; index += 1) {
525
+ const onMainParents = (mainCommits[index].parents ?? []).filter((id) => mainIndexById.has(id));
526
+ expect(onMainParents.length).toBeGreaterThan(0);
527
+ for (const parentId of onMainParents) {
528
+ expect(mainIndexById.get(parentId)).toBe(index - 1);
529
+ }
530
+ }
531
+
532
+ expect(`\n${renderTimelineAscii(commits, branches)}\n`).toMatchInlineSnapshot(`
533
+ "
534
+ ● [function] Run Routine 1
535
+ ● [function] Run Routine 2
536
+ ├──● [function] Lookup A - Success
537
+ ├──┼──● [function] Lookup B - Success
538
+ ◆──╯ │ [function] Run Routine 1 - Success
539
+ ◆─────╯ [function] Run Routine 2 - Success
540
+ "
541
+ `);
542
+ });
543
+
544
+ /**
545
+ * Two sequential agent sessions sharing the same pid. Each request is an independent span
546
+ * but they share a branch (both pid="session-1"), so middle events chain across the gap
547
+ * between sessions. Matches the existing `'sequential prompts in a session'` ASCII snapshot
548
+ * style produced by real conversations.
549
+ */
550
+ test('two sequential agent sessions sharing a pid chain on the same branch', ({ expect }) => {
551
+ const messages = collectTraceEvents(
552
+ withMeta(
553
+ { pid: 'session-1' },
554
+ Effect.gen(function* () {
555
+ yield* Trace.write(AgentRequestBegin, {});
556
+ yield* Trace.write(CompleteBlock, {
557
+ messageId: MESSAGE_ID,
558
+ role: 'user',
559
+ block: { _tag: 'text', text: 'First question', pending: false },
560
+ });
561
+ yield* Trace.write(AgentRequestEnd, { status: 'success' });
562
+ yield* Trace.write(AgentRequestBegin, {});
563
+ yield* Trace.write(CompleteBlock, {
564
+ messageId: MESSAGE_ID,
565
+ role: 'user',
566
+ block: { _tag: 'text', text: 'Follow-up question', pending: false },
567
+ });
568
+ yield* Trace.write(AgentRequestEnd, { status: 'success' });
569
+ }),
570
+ ),
571
+ );
572
+
573
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
574
+ "
575
+ ● [atom] Agent processing request...
576
+ ├──● [user] First question
577
+ ◆──╯ [atom] Agent completed request
578
+ ● │ [atom] Agent processing request...
579
+ │ ● [user] Follow-up question
580
+ ◆──╯ [atom] Agent completed request
581
+ "
582
+ `);
583
+ });
584
+
585
+ /**
586
+ * Top-level operation interleaved with several status updates between begin and end.
587
+ * Status events are middle events: they render on the operation's own branch and the end
588
+ * commit merges them back into main.
589
+ */
590
+ test('mixed boundary and status events keep statuses on the op branch and merge at end', ({ expect }) => {
591
+ const messages = collectTraceEvents(
592
+ withMeta(
593
+ { pid: 'op-1' },
594
+ Effect.gen(function* () {
595
+ yield* Trace.write(Trace.OperationStart, { key: 'work', name: 'Work' });
596
+ yield* Trace.write(CompleteBlock, {
597
+ messageId: MESSAGE_ID,
598
+ role: 'assistant',
599
+ block: { _tag: 'status', statusText: 'thinking', pending: false },
600
+ });
601
+ yield* Trace.write(CompleteBlock, {
602
+ messageId: MESSAGE_ID,
603
+ role: 'assistant',
604
+ block: { _tag: 'status', statusText: 'searching', pending: false },
605
+ });
606
+ yield* Trace.write(CompleteBlock, {
607
+ messageId: MESSAGE_ID,
608
+ role: 'assistant',
609
+ block: { _tag: 'status', statusText: 'writing', pending: false },
610
+ });
611
+ yield* Trace.write(Trace.OperationEnd, { key: 'work', name: 'Work', outcome: 'success' });
612
+ }),
613
+ ),
614
+ );
615
+
616
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
617
+ "
618
+ ● [function] Work
619
+ ├──● [info] thinking
620
+ │ ● [info] searching
621
+ │ ● [info] writing
622
+ ◆──╯ [function] Work - Success
623
+ "
624
+ `);
625
+ });
626
+
627
+ /**
628
+ * Plain (non-operation) tool calls — e.g. a toolkit handler or an MCP tool — render as a
629
+ * single auto-collapsed commit on the agent's branch so the timeline shows that work
630
+ * happened without forking a dedicated routine span.
631
+ */
632
+ test('non-operation tool call renders as a single commit on the agent branch', ({ expect }) => {
633
+ const messages = collectTraceEvents(
634
+ withMeta(
635
+ { pid: 'agent-1' },
636
+ Effect.gen(function* () {
637
+ yield* Trace.write(AgentRequestBegin, {});
638
+ yield* Trace.write(CompleteBlock, {
639
+ messageId: MESSAGE_ID,
640
+ role: 'assistant',
641
+ block: {
642
+ _tag: 'toolCall',
643
+ toolCallId: 'call-1',
644
+ name: 'web-search',
645
+ input: '{"query":"hello"}',
646
+ providerExecuted: false,
647
+ pending: false,
648
+ },
649
+ });
650
+ yield* Trace.write(AgentRequestEnd, { status: 'success' });
651
+ }),
652
+ ),
653
+ );
654
+
655
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
656
+ "
657
+ ● [atom] Agent processing request...
658
+ ├──● [wrench] web-search
659
+ ◆──╯ [atom] Agent completed request
660
+ "
661
+ `);
662
+ });
663
+
664
+ /**
665
+ * Completed (toolCall + toolResult) pair collapses to a single result commit, mirroring how
666
+ * an operation begin/end span with no inner activity collapses to its end commit. The
667
+ * pending toolCall is suppressed once the result arrives because the result commit carries
668
+ * the final success/error state.
669
+ */
670
+ test('tool call + tool result pair collapses to a single result commit', ({ expect }) => {
671
+ const messages = collectTraceEvents(
672
+ withMeta(
673
+ { pid: 'agent-1' },
674
+ Effect.gen(function* () {
675
+ yield* Trace.write(AgentRequestBegin, {});
676
+ yield* Trace.write(CompleteBlock, {
677
+ messageId: MESSAGE_ID,
678
+ role: 'assistant',
679
+ block: {
680
+ _tag: 'toolCall',
681
+ toolCallId: 'call-1',
682
+ name: 'web-search',
683
+ input: '{"query":"hello"}',
684
+ providerExecuted: false,
685
+ pending: false,
686
+ },
687
+ });
688
+ yield* Trace.write(CompleteBlock, {
689
+ messageId: MESSAGE_ID,
690
+ role: 'tool',
691
+ block: {
692
+ _tag: 'toolResult',
693
+ toolCallId: 'call-1',
694
+ name: 'web-search',
695
+ result: '"ok"',
696
+ providerExecuted: false,
697
+ pending: false,
698
+ },
699
+ });
700
+ yield* Trace.write(AgentRequestEnd, { status: 'success' });
701
+ }),
702
+ ),
703
+ );
704
+
705
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
706
+ "
707
+ ● [atom] Agent processing request...
708
+ ├──● [wrench] web-search - Success
709
+ ◆──╯ [atom] Agent completed request
710
+ "
711
+ `);
712
+ });
713
+
714
+ /**
715
+ * Error results render as a single commit with an error level and an " - Error" suffix —
716
+ * matches the operation-end error convention.
717
+ */
718
+ test('tool call with failing tool result renders as a single error commit', ({ expect }) => {
719
+ const messages = collectTraceEvents(
720
+ withMeta(
721
+ { pid: 'agent-1' },
722
+ Effect.gen(function* () {
723
+ yield* Trace.write(AgentRequestBegin, {});
724
+ yield* Trace.write(CompleteBlock, {
725
+ messageId: MESSAGE_ID,
726
+ role: 'assistant',
727
+ block: {
728
+ _tag: 'toolCall',
729
+ toolCallId: 'call-1',
730
+ name: 'flaky',
731
+ input: '{}',
732
+ providerExecuted: false,
733
+ pending: false,
734
+ },
735
+ });
736
+ yield* Trace.write(CompleteBlock, {
737
+ messageId: MESSAGE_ID,
738
+ role: 'tool',
739
+ block: {
740
+ _tag: 'toolResult',
741
+ toolCallId: 'call-1',
742
+ name: 'flaky',
743
+ error: 'boom',
744
+ providerExecuted: false,
745
+ pending: false,
746
+ },
747
+ });
748
+ yield* Trace.write(AgentRequestEnd, { status: 'success' });
749
+ }),
750
+ ),
751
+ );
752
+
753
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
754
+ "
755
+ ● [atom] Agent processing request...
756
+ ├──● [wrench] flaky - Error
757
+ ◆──╯ [atom] Agent completed request
758
+ "
759
+ `);
760
+ });
761
+
762
+ /**
763
+ * Operation-backed tool calls (those carrying an `operationKey`) are suppressed in the
764
+ * timeline because the surrounding `Trace.OperationStart` / `Trace.OperationEnd` span
765
+ * already produces a routine commit. Otherwise the user would see two entries for the
766
+ * same logical invocation.
767
+ */
768
+ test('operation-backed tool call is suppressed in favor of the routine span', ({ expect }) => {
769
+ const messages = collectTraceEvents(
770
+ Effect.gen(function* () {
771
+ yield* withMeta(
772
+ { pid: 'agent-1' },
773
+ Effect.gen(function* () {
774
+ yield* Trace.write(AgentRequestBegin, {});
775
+ yield* Trace.write(CompleteBlock, {
776
+ messageId: MESSAGE_ID,
777
+ role: 'assistant',
778
+ block: {
779
+ _tag: 'toolCall',
780
+ toolCallId: 'call-1',
781
+ name: 'lookup-something',
782
+ input: '{}',
783
+ providerExecuted: false,
784
+ pending: false,
785
+ operationKey: 'lookup',
786
+ operationName: 'Lookup',
787
+ },
788
+ });
789
+ }),
790
+ );
791
+ yield* withMeta(
792
+ { pid: 'op-1', parentPid: 'agent-1' },
793
+ Effect.gen(function* () {
794
+ yield* Trace.write(Trace.OperationStart, { key: 'lookup', name: 'Lookup' });
795
+ yield* Trace.write(Trace.OperationEnd, { key: 'lookup', name: 'Lookup', outcome: 'success' });
796
+ }),
797
+ );
798
+ yield* withMeta({ pid: 'agent-1' }, Trace.write(AgentRequestEnd, { status: 'success' }));
799
+ }),
800
+ );
801
+
802
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
803
+ "
804
+ ● [atom] Agent processing request...
805
+ ├──● [function] Lookup - Success
806
+ ◆──╯ [atom] Agent completed request
807
+ "
808
+ `);
809
+ });
810
+
811
+ /**
812
+ * Failed agent requests surface as an error-level end commit with the failure message.
813
+ */
814
+ test('agent request end with error status renders as error commit', ({ expect }) => {
815
+ const messages = collectTraceEvents(
816
+ withMeta(
817
+ { pid: 'agent-1' },
818
+ Effect.gen(function* () {
819
+ yield* Trace.write(AgentRequestBegin, {});
820
+ yield* Trace.write(CompleteBlock, {
821
+ messageId: MESSAGE_ID,
822
+ role: 'user',
823
+ block: { _tag: 'text', text: 'hello', pending: false },
824
+ });
825
+ yield* Trace.write(AgentRequestEnd, {
826
+ status: 'error',
827
+ error: 'Unsupported schema AST: UnknownKeyword',
828
+ });
829
+ }),
830
+ ),
831
+ );
832
+
833
+ const { commits } = buildExecutionGraph({ traceMessages: messages });
834
+ const endCommit = commits.at(-1);
835
+ expect(endCommit?.message).toBe('Agent request failed: Unsupported schema AST: UnknownKeyword');
836
+ expect(endCommit?.level).toBe(LogLevel.ERROR);
837
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
838
+ "
839
+ ● [atom] Agent processing request...
840
+ ├──● [user] hello
841
+ ◆──╯ [atom] Agent request failed: Unsupported schema AST: UnknownKeyword
842
+ "
843
+ `);
844
+ });
845
+
846
+ /**
847
+ * Interrupted agent requests surface as a warning-level end commit.
848
+ */
849
+ test('agent request end with interrupted status renders as interrupted commit', ({ expect }) => {
850
+ const messages = collectTraceEvents(
851
+ withMeta(
852
+ { pid: 'agent-1' },
853
+ Effect.gen(function* () {
854
+ yield* Trace.write(AgentRequestBegin, {});
855
+ yield* Trace.write(AgentRequestEnd, { status: 'interrupted' });
856
+ }),
857
+ ),
858
+ );
859
+
860
+ const { commits } = buildExecutionGraph({ traceMessages: messages });
861
+ const endCommit = commits.at(-1);
862
+ expect(endCommit?.message).toBe('Agent request interrupted');
863
+ expect(endCommit?.level).toBe(LogLevel.WARN);
864
+ // Begin/end only — collapsible span renders a single end commit on main.
865
+ expect(`\n${renderGraph(messages)}\n`).toMatchInlineSnapshot(`
866
+ "
867
+ ● [atom] Agent request interrupted
868
+ "
869
+ `);
870
+ });
871
+
872
+ /**
873
+ * Orphan `OperationEnd` event — no matching `OperationStart` was captured. The span tree
874
+ * attaches it to the synthetic root rather than crashing, so the renderer produces a
875
+ * single commit on main.
876
+ */
877
+ test('orphan end event without a matching begin attaches to root without crashing', ({ expect }) => {
878
+ const messages = collectTraceEvents(
879
+ withMeta({ pid: 'ghost' }, Trace.write(Trace.OperationEnd, { key: 'lost', name: 'Lost', outcome: 'failure' })),
880
+ );
881
+
882
+ const { commits, branches } = buildExecutionGraph({ traceMessages: messages });
883
+ expect(commits).toHaveLength(1);
884
+ expect(commits[0].branch).toBe('main');
885
+ expect(`\n${renderTimelineAscii(commits, branches)}\n`).toMatchInlineSnapshot(`
886
+ "
887
+ ● [function] Lost - Error
888
+ "
889
+ `);
890
+ });
891
+ });