@dxos/plugin-assistant 0.8.4-main.abd8ff62ef → 0.8.4-main.bc2380dfbc

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 (414) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/neutral/AgentArticle-5XDDEXMP.mjs +169 -0
  4. package/dist/lib/neutral/AgentArticle-5XDDEXMP.mjs.map +7 -0
  5. package/dist/lib/neutral/AgentProperties-CNH4JMDZ.mjs +100 -0
  6. package/dist/lib/neutral/AgentProperties-CNH4JMDZ.mjs.map +7 -0
  7. package/dist/lib/neutral/AssistantPlugin.mjs +10 -0
  8. package/dist/lib/neutral/AssistantPlugin.node.mjs +46 -0
  9. package/dist/lib/neutral/AssistantPlugin.node.mjs.map +7 -0
  10. package/dist/lib/neutral/AssistantPlugin.workerd.mjs +40 -0
  11. package/dist/lib/neutral/AssistantPlugin.workerd.mjs.map +7 -0
  12. package/dist/lib/neutral/BlueprintArticle-U7LUBFOS.mjs +27 -0
  13. package/dist/lib/neutral/BlueprintArticle-U7LUBFOS.mjs.map +7 -0
  14. package/dist/lib/neutral/ChatArticle-WVAFZPVI.mjs +8 -0
  15. package/dist/lib/neutral/ChatCompanion-DFRMRUK3.mjs +133 -0
  16. package/dist/lib/neutral/ChatCompanion-DFRMRUK3.mjs.map +7 -0
  17. package/dist/lib/neutral/ChatDialog-QKZLG7SQ.mjs +72 -0
  18. package/dist/lib/neutral/ChatDialog-QKZLG7SQ.mjs.map +7 -0
  19. package/dist/lib/neutral/PlanArticle-TS5ULWYS.mjs +28 -0
  20. package/dist/lib/neutral/PlanArticle-TS5ULWYS.mjs.map +7 -0
  21. package/dist/lib/neutral/RoutineArticle-H7ECM7AH.mjs +116 -0
  22. package/dist/lib/neutral/RoutineArticle-H7ECM7AH.mjs.map +7 -0
  23. package/dist/lib/neutral/RoutineList-CLDXGQUD.mjs +48 -0
  24. package/dist/lib/neutral/RoutineList-CLDXGQUD.mjs.map +7 -0
  25. package/dist/lib/neutral/TracePanel-C77SPEIS.mjs +672 -0
  26. package/dist/lib/neutral/TracePanel-C77SPEIS.mjs.map +7 -0
  27. package/dist/lib/neutral/TriggerStatus-WTFYUIG5.mjs +92 -0
  28. package/dist/lib/neutral/TriggerStatus-WTFYUIG5.mjs.map +7 -0
  29. package/dist/lib/neutral/ai-service-GJXMI5OI.mjs +22 -0
  30. package/dist/lib/neutral/ai-service-GJXMI5OI.mjs.map +7 -0
  31. package/dist/lib/neutral/app-graph-builder-5QBICPYP.mjs +200 -0
  32. package/dist/lib/neutral/app-graph-builder-5QBICPYP.mjs.map +7 -0
  33. package/dist/lib/neutral/blueprint-definition-VXJYQ5AE.mjs +32 -0
  34. package/dist/lib/neutral/blueprint-definition-VXJYQ5AE.mjs.map +7 -0
  35. package/dist/lib/neutral/blueprints/index.mjs +8 -0
  36. package/dist/lib/neutral/capabilities/index.mjs +35 -0
  37. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  38. package/dist/lib/neutral/chunk-3FIV362Z.mjs +8 -0
  39. package/dist/lib/neutral/chunk-3FIV362Z.mjs.map +7 -0
  40. package/dist/lib/neutral/chunk-4CQZCMRP.mjs +25 -0
  41. package/dist/lib/neutral/chunk-4CQZCMRP.mjs.map +7 -0
  42. package/dist/lib/{browser/blueprints/index.mjs → neutral/chunk-5H6UJHLF.mjs} +4 -5
  43. package/dist/lib/neutral/chunk-5H6UJHLF.mjs.map +7 -0
  44. package/dist/lib/neutral/chunk-ITJX2YZZ.mjs +98 -0
  45. package/dist/lib/neutral/chunk-ITJX2YZZ.mjs.map +7 -0
  46. package/dist/lib/neutral/chunk-IZQWGJNG.mjs +380 -0
  47. package/dist/lib/neutral/chunk-IZQWGJNG.mjs.map +7 -0
  48. package/dist/lib/neutral/chunk-SLIPV6NN.mjs +106 -0
  49. package/dist/lib/neutral/chunk-SLIPV6NN.mjs.map +7 -0
  50. package/dist/lib/neutral/companion-chat-provisioner-2Y6PRSDK.mjs +116 -0
  51. package/dist/lib/neutral/companion-chat-provisioner-2Y6PRSDK.mjs.map +7 -0
  52. package/dist/lib/{browser/chunk-VK53MITK.mjs → neutral/components/index.mjs} +139 -141
  53. package/dist/lib/neutral/components/index.mjs.map +7 -0
  54. package/dist/lib/neutral/containers/index.mjs +29 -0
  55. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  56. package/dist/lib/{browser/create-chat-E2ZLVTLP.mjs → neutral/create-chat-QQZURUBW.mjs} +10 -12
  57. package/dist/lib/neutral/create-chat-QQZURUBW.mjs.map +7 -0
  58. package/dist/lib/neutral/create-object-UZCJCPWM.mjs +93 -0
  59. package/dist/lib/neutral/create-object-UZCJCPWM.mjs.map +7 -0
  60. package/dist/lib/neutral/edge-model-resolver-XDNBZ3US.mjs +21 -0
  61. package/dist/lib/neutral/edge-model-resolver-XDNBZ3US.mjs.map +7 -0
  62. package/dist/lib/{browser/ensure-companion-chat-7GDMXSQW.mjs → neutral/ensure-companion-chat-5S4LZM2H.mjs} +9 -16
  63. package/dist/lib/neutral/ensure-companion-chat-5S4LZM2H.mjs.map +7 -0
  64. package/dist/lib/{browser/chunk-M55MBYG7.mjs → neutral/hooks/index.mjs} +106 -111
  65. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  66. package/dist/lib/neutral/index.mjs +32 -0
  67. package/dist/lib/neutral/local-model-resolver-I2BENFFS.mjs +24 -0
  68. package/dist/lib/neutral/local-model-resolver-I2BENFFS.mjs.map +7 -0
  69. package/dist/lib/neutral/markdown-KTBFOMFM.mjs +110 -0
  70. package/dist/lib/neutral/markdown-KTBFOMFM.mjs.map +7 -0
  71. package/dist/lib/neutral/meta.json +1 -0
  72. package/dist/lib/neutral/meta.mjs +12 -0
  73. package/dist/lib/neutral/migrations-7DEMVBOG.mjs +28 -0
  74. package/dist/lib/neutral/migrations-7DEMVBOG.mjs.map +7 -0
  75. package/dist/lib/{browser/on-create-space-4J3KTNAJ.mjs → neutral/on-create-space-Q2R7OSP6.mjs} +4 -7
  76. package/dist/lib/neutral/on-create-space-Q2R7OSP6.mjs.map +7 -0
  77. package/dist/lib/neutral/operation-handler-SF36MOB5.mjs +13 -0
  78. package/dist/lib/neutral/operation-handler-SF36MOB5.mjs.map +7 -0
  79. package/dist/lib/neutral/operations/index.mjs +8 -0
  80. package/dist/lib/neutral/plugin.mjs +16 -0
  81. package/dist/lib/neutral/plugin.mjs.map +7 -0
  82. package/dist/lib/neutral/react-surface-T4R65UJU.mjs +174 -0
  83. package/dist/lib/neutral/react-surface-T4R65UJU.mjs.map +7 -0
  84. package/dist/lib/{browser/resolve-navigation-targets-3ZPQE6SZ.mjs → neutral/resolve-navigation-targets-VXBSWV5L.mjs} +3 -5
  85. package/dist/lib/neutral/resolve-navigation-targets-VXBSWV5L.mjs.map +7 -0
  86. package/dist/lib/{browser/run-prompt-in-new-chat-AA3KPBDN.mjs → neutral/run-prompt-in-new-chat-VJXXZ6SI.mjs} +16 -19
  87. package/dist/lib/neutral/run-prompt-in-new-chat-VJXXZ6SI.mjs.map +7 -0
  88. package/dist/lib/{browser/set-current-chat-P4VHI3YF.mjs → neutral/set-current-chat-ZFDCYK5I.mjs} +4 -10
  89. package/dist/lib/neutral/set-current-chat-ZFDCYK5I.mjs.map +7 -0
  90. package/dist/lib/neutral/settings-W4BLWQ53.mjs +28 -0
  91. package/dist/lib/neutral/settings-W4BLWQ53.mjs.map +7 -0
  92. package/dist/lib/neutral/state-H3G7QCU6.mjs +28 -0
  93. package/dist/lib/neutral/state-H3G7QCU6.mjs.map +7 -0
  94. package/dist/lib/neutral/testing.mjs +8 -0
  95. package/dist/lib/neutral/toggle-trace-panel-debug-JGTB6KVJ.mjs +21 -0
  96. package/dist/lib/neutral/toggle-trace-panel-debug-JGTB6KVJ.mjs.map +7 -0
  97. package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs +14 -0
  98. package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs.map +7 -0
  99. package/dist/lib/{browser → neutral}/translations.mjs +5 -2
  100. package/dist/lib/neutral/translations.mjs.map +7 -0
  101. package/dist/lib/neutral/types/index.mjs +20 -0
  102. package/dist/lib/neutral/types/index.mjs.map +7 -0
  103. package/dist/lib/{browser/update-chat-name-VWKNUON7.mjs → neutral/update-chat-name-ENXRUMDJ.mjs} +3 -5
  104. package/dist/lib/neutral/update-chat-name-ENXRUMDJ.mjs.map +7 -0
  105. package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
  106. package/dist/types/src/AssistantPlugin.node.d.ts.map +1 -1
  107. package/dist/types/src/AssistantPlugin.workerd.d.ts +4 -0
  108. package/dist/types/src/AssistantPlugin.workerd.d.ts.map +1 -0
  109. package/dist/types/src/capabilities/companion-chat-provisioner.d.ts.map +1 -1
  110. package/dist/types/src/capabilities/create-object.d.ts +31 -0
  111. package/dist/types/src/capabilities/create-object.d.ts.map +1 -0
  112. package/dist/types/src/capabilities/index.d.ts +27 -1
  113. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  114. package/dist/types/src/capabilities/markdown.d.ts +1 -1
  115. package/dist/types/src/capabilities/migrations.d.ts +2 -1
  116. package/dist/types/src/capabilities/migrations.d.ts.map +1 -1
  117. package/dist/types/src/components/Chat/Chat.d.ts +11 -5
  118. package/dist/types/src/components/Chat/Chat.d.ts.map +1 -1
  119. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts +2 -2
  120. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts.map +1 -1
  121. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +2 -2
  122. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
  123. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +2 -3
  124. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
  125. package/dist/types/src/components/ChatThread/registry.d.ts.map +1 -1
  126. package/dist/types/src/components/ChatThread/widgets/StatusWidget.d.ts +2 -15
  127. package/dist/types/src/components/ChatThread/widgets/StatusWidget.d.ts.map +1 -1
  128. package/dist/types/src/components/ChatThread/widgets/SummaryWidget.d.ts.map +1 -1
  129. package/dist/types/src/components/ProcessTree/ProcessTree.d.ts.map +1 -1
  130. package/dist/types/src/components/TaskList/TaskList.d.ts +10 -0
  131. package/dist/types/src/components/TaskList/TaskList.d.ts.map +1 -0
  132. package/dist/types/src/components/TaskList/TaskList.stories.d.ts +16 -0
  133. package/dist/types/src/components/TaskList/TaskList.stories.d.ts.map +1 -0
  134. package/dist/types/src/components/TaskList/index.d.ts +2 -0
  135. package/dist/types/src/components/TaskList/index.d.ts.map +1 -0
  136. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +1 -2
  137. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
  138. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +1 -1
  139. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -1
  140. package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
  141. package/dist/types/src/components/index.d.ts +1 -0
  142. package/dist/types/src/components/index.d.ts.map +1 -1
  143. package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts.map +1 -1
  144. package/dist/types/src/containers/{ChatContainer/ChatContainer.d.ts → ChatArticle/ChatArticle.d.ts} +3 -3
  145. package/dist/types/src/containers/ChatArticle/ChatArticle.d.ts.map +1 -0
  146. package/dist/types/src/containers/ChatArticle/index.d.ts +2 -0
  147. package/dist/types/src/containers/ChatArticle/index.d.ts.map +1 -0
  148. package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts.map +1 -1
  149. package/dist/types/src/containers/PlanArticle/PlanArticle.d.ts +6 -0
  150. package/dist/types/src/containers/PlanArticle/PlanArticle.d.ts.map +1 -0
  151. package/dist/types/src/containers/PlanArticle/index.d.ts +2 -0
  152. package/dist/types/src/containers/PlanArticle/index.d.ts.map +1 -0
  153. package/dist/types/src/containers/RoutineArticle/RoutineArticle.d.ts.map +1 -1
  154. package/dist/types/src/containers/RoutineArticle/RoutineArticle.stories.d.ts +15 -0
  155. package/dist/types/src/containers/RoutineArticle/RoutineArticle.stories.d.ts.map +1 -0
  156. package/dist/types/src/containers/TracePanel/TracePanel.d.ts.map +1 -1
  157. package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts.map +1 -1
  158. package/dist/types/src/containers/TracePanel/execution-graph.d.ts +11 -2
  159. package/dist/types/src/containers/TracePanel/execution-graph.d.ts.map +1 -1
  160. package/dist/types/src/containers/TracePanel/span-tree.d.ts +73 -0
  161. package/dist/types/src/containers/TracePanel/span-tree.d.ts.map +1 -0
  162. package/dist/types/src/containers/TracePanel/span-tree.test.d.ts +2 -0
  163. package/dist/types/src/containers/TracePanel/span-tree.test.d.ts.map +1 -0
  164. package/dist/types/src/containers/index.d.ts +4 -3
  165. package/dist/types/src/containers/index.d.ts.map +1 -1
  166. package/dist/types/src/feed-logger.d.ts +13 -0
  167. package/dist/types/src/feed-logger.d.ts.map +1 -0
  168. package/dist/types/src/hooks/useBlueprintRegistry.d.ts +3 -3
  169. package/dist/types/src/hooks/useBlueprintRegistry.d.ts.map +1 -1
  170. package/dist/types/src/hooks/useChatProcessor.d.ts +1 -1
  171. package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
  172. package/dist/types/src/hooks/useChatServices.d.ts +1 -1
  173. package/dist/types/src/hooks/useChatServices.d.ts.map +1 -1
  174. package/dist/types/src/hooks/useChatToolbarActions.d.ts.map +1 -1
  175. package/dist/types/src/hooks/useContextBinder.d.ts +2 -2
  176. package/dist/types/src/hooks/useContextBinder.d.ts.map +1 -1
  177. package/dist/types/src/hooks/useContextObjects.d.ts +2 -2
  178. package/dist/types/src/hooks/useContextObjects.d.ts.map +1 -1
  179. package/dist/types/src/index.d.ts +2 -4
  180. package/dist/types/src/index.d.ts.map +1 -1
  181. package/dist/types/src/operations/create-chat.d.ts +2 -2
  182. package/dist/types/src/operations/create-chat.d.ts.map +1 -1
  183. package/dist/types/src/operations/ensure-companion-chat.d.ts +2 -2
  184. package/dist/types/src/operations/ensure-companion-chat.d.ts.map +1 -1
  185. package/dist/types/src/operations/index.d.ts +0 -1
  186. package/dist/types/src/operations/index.d.ts.map +1 -1
  187. package/dist/types/src/operations/on-create-space.d.ts +2 -2
  188. package/dist/types/src/operations/on-create-space.d.ts.map +1 -1
  189. package/dist/types/src/operations/run-prompt-in-new-chat.d.ts +2 -2
  190. package/dist/types/src/operations/run-prompt-in-new-chat.d.ts.map +1 -1
  191. package/dist/types/src/operations/set-current-chat.d.ts +2 -2
  192. package/dist/types/src/operations/set-current-chat.d.ts.map +1 -1
  193. package/dist/types/src/operations/toggle-trace-panel-debug.d.ts +5 -0
  194. package/dist/types/src/operations/toggle-trace-panel-debug.d.ts.map +1 -0
  195. package/dist/types/src/operations/update-chat-name.d.ts +2 -2
  196. package/dist/types/src/operations/update-chat-name.d.ts.map +1 -1
  197. package/dist/types/src/plugin.d.ts +4 -0
  198. package/dist/types/src/plugin.d.ts.map +1 -0
  199. package/dist/types/src/processor/processor.d.ts +11 -11
  200. package/dist/types/src/processor/processor.d.ts.map +1 -1
  201. package/dist/types/src/testing/test-generator.d.ts +2 -3
  202. package/dist/types/src/testing/test-generator.d.ts.map +1 -1
  203. package/dist/types/src/testing/test-sequence.d.ts +3 -3
  204. package/dist/types/src/testing/test-sequence.d.ts.map +1 -1
  205. package/dist/types/src/testing.d.ts +2 -0
  206. package/dist/types/src/testing.d.ts.map +1 -0
  207. package/dist/types/src/translations.d.ts.map +1 -1
  208. package/dist/types/src/types/Assistant.d.ts +1 -0
  209. package/dist/types/src/types/Assistant.d.ts.map +1 -1
  210. package/dist/types/src/types/AssistantCapabilities.d.ts +30 -0
  211. package/dist/types/src/types/AssistantCapabilities.d.ts.map +1 -0
  212. package/dist/types/src/types/AssistantEvents.d.ts +3 -0
  213. package/dist/types/src/types/AssistantEvents.d.ts.map +1 -0
  214. package/dist/types/src/{operations/definitions.d.ts → types/AssistantOperation.d.ts} +10 -6
  215. package/dist/types/src/types/AssistantOperation.d.ts.map +1 -0
  216. package/dist/types/src/types/Settings.d.ts +1 -0
  217. package/dist/types/src/types/Settings.d.ts.map +1 -1
  218. package/dist/types/src/types/index.d.ts +3 -2
  219. package/dist/types/src/types/index.d.ts.map +1 -1
  220. package/dist/types/src/util/suggestions.d.ts +9 -0
  221. package/dist/types/src/util/suggestions.d.ts.map +1 -0
  222. package/dist/types/src/util/suggestions.test.d.ts +2 -0
  223. package/dist/types/src/util/suggestions.test.d.ts.map +1 -0
  224. package/dist/types/tsconfig.tsbuildinfo +1 -1
  225. package/package.json +152 -128
  226. package/src/AssistantPlugin.node.ts +7 -88
  227. package/src/AssistantPlugin.test.ts +3 -3
  228. package/src/AssistantPlugin.ts +126 -0
  229. package/src/AssistantPlugin.workerd.ts +41 -0
  230. package/src/blueprints/assistant/blueprint.ts +1 -1
  231. package/src/capabilities/app-graph-builder.ts +48 -9
  232. package/src/capabilities/companion-chat-provisioner.ts +4 -5
  233. package/src/capabilities/create-object.ts +107 -0
  234. package/src/capabilities/index.ts +1 -0
  235. package/src/capabilities/markdown.ts +2 -2
  236. package/src/capabilities/migrations.ts +3 -3
  237. package/src/capabilities/react-surface.tsx +15 -7
  238. package/src/components/Chat/Chat.tsx +35 -5
  239. package/src/components/ChatPrompt/ChatMcpErrors.tsx +1 -1
  240. package/src/components/ChatPrompt/ChatOptions.stories.tsx +4 -4
  241. package/src/components/ChatPrompt/ChatOptions.tsx +12 -11
  242. package/src/components/ChatPrompt/ChatPrompt.tsx +3 -3
  243. package/src/components/ChatPrompt/ChatReferences.tsx +3 -3
  244. package/src/components/ChatPrompt/ChatStatus.tsx +1 -1
  245. package/src/components/ChatPrompt/ChatStatusIndicator.tsx +1 -1
  246. package/src/components/ChatThread/Anchor.stories.tsx +3 -3
  247. package/src/components/ChatThread/ChatThread.stories.tsx +25 -29
  248. package/src/components/ChatThread/ChatThread.tsx +1 -1
  249. package/src/components/ChatThread/registry.tsx +8 -4
  250. package/src/components/ChatThread/sync.test.ts +4 -6
  251. package/src/components/ChatThread/widgets/ReasoningWidget.ts +2 -2
  252. package/src/components/ChatThread/widgets/StatusWidget.ts +3 -83
  253. package/src/components/ChatThread/widgets/SummaryWidget.tsx +1 -3
  254. package/src/components/ProcessTree/ProcessTree.tsx +2 -1
  255. package/src/components/TaskList/TaskList.stories.tsx +44 -0
  256. package/src/components/TaskList/TaskList.tsx +45 -0
  257. package/src/{cli → components/TaskList}/index.ts +1 -1
  258. package/src/components/TemplateEditor/TemplateEditor.stories.tsx +1 -1
  259. package/src/components/TemplateEditor/TemplateForm.stories.tsx +2 -6
  260. package/src/components/TemplateEditor/TemplateForm.tsx +48 -69
  261. package/src/components/Toolbox/Toolbox.stories.tsx +4 -4
  262. package/src/components/Toolbox/Toolbox.tsx +2 -2
  263. package/src/components/index.ts +1 -0
  264. package/src/containers/AgentArticle/AgentArticle.stories.tsx +7 -7
  265. package/src/containers/AgentArticle/AgentArticle.tsx +11 -7
  266. package/src/containers/AgentProperties/AgentProperties.stories.tsx +4 -4
  267. package/src/containers/AgentProperties/AgentProperties.tsx +4 -4
  268. package/src/containers/{ChatContainer/ChatContainer.tsx → ChatArticle/ChatArticle.tsx} +11 -9
  269. package/src/containers/ChatArticle/index.ts +5 -0
  270. package/src/containers/ChatCompanion/ChatCompanion.tsx +20 -29
  271. package/src/containers/PlanArticle/PlanArticle.tsx +33 -0
  272. package/src/containers/PlanArticle/index.ts +5 -0
  273. package/src/containers/RoutineArticle/RoutineArticle.stories.tsx +75 -0
  274. package/src/containers/RoutineArticle/RoutineArticle.tsx +74 -24
  275. package/src/containers/RoutineList/RoutineList.stories.tsx +3 -3
  276. package/src/containers/RoutineList/RoutineList.tsx +3 -3
  277. package/src/containers/TracePanel/TracePanel.stories.tsx +33 -26
  278. package/src/containers/TracePanel/TracePanel.tsx +72 -33
  279. package/src/containers/TracePanel/dxn-extractor.ts +7 -7
  280. package/src/containers/TracePanel/execution-graph.test.ts +218 -213
  281. package/src/containers/TracePanel/execution-graph.ts +316 -271
  282. package/src/containers/TracePanel/span-tree.test.ts +166 -0
  283. package/src/containers/TracePanel/span-tree.ts +214 -0
  284. package/src/containers/index.ts +4 -3
  285. package/src/{queue-logger.ts → feed-logger.ts} +37 -27
  286. package/src/hooks/useBlueprintRegistry.ts +12 -6
  287. package/src/hooks/useChatProcessor.ts +3 -3
  288. package/src/hooks/useChatServices.ts +1 -1
  289. package/src/hooks/useChatToolbarActions.ts +86 -88
  290. package/src/hooks/useContextBinder.ts +4 -4
  291. package/src/hooks/useContextObjects.ts +2 -2
  292. package/src/index.ts +2 -9
  293. package/src/operations/create-chat.ts +16 -11
  294. package/src/operations/ensure-companion-chat.ts +47 -45
  295. package/src/operations/index.ts +1 -2
  296. package/src/operations/on-create-space.ts +3 -3
  297. package/src/operations/prompt.test.ts +5 -5
  298. package/src/operations/resolve-navigation-targets.ts +2 -2
  299. package/src/operations/run-prompt-in-new-chat.ts +85 -84
  300. package/src/operations/set-current-chat.ts +3 -4
  301. package/src/operations/toggle-trace-panel-debug.ts +27 -0
  302. package/src/operations/update-chat-name.ts +2 -2
  303. package/src/plugin.ts +11 -0
  304. package/src/processor/processor.test.ts +1 -1
  305. package/src/processor/processor.ts +15 -15
  306. package/src/testing/test-generator.test.ts +41 -52
  307. package/src/testing/test-generator.ts +174 -189
  308. package/src/testing/test-sequence.ts +3 -3
  309. package/src/testing/trace-timeline.conversations.json +1 -1
  310. package/src/testing/trace-timeline.test.ts +3 -5
  311. package/src/testing.ts +7 -0
  312. package/src/translations.ts +5 -2
  313. package/src/types/Assistant.ts +2 -1
  314. package/src/types/AssistantCapabilities.ts +35 -0
  315. package/src/types/AssistantEvents.ts +11 -0
  316. package/src/{operations/definitions.ts → types/AssistantOperation.ts} +15 -0
  317. package/src/types/Settings.ts +6 -0
  318. package/src/types/index.ts +5 -2
  319. package/src/util/suggestions.test.ts +52 -0
  320. package/src/util/suggestions.ts +42 -0
  321. package/dist/lib/browser/blueprints/index.mjs.map +0 -7
  322. package/dist/lib/browser/chunk-DVOOFAWU.mjs +0 -175
  323. package/dist/lib/browser/chunk-DVOOFAWU.mjs.map +0 -7
  324. package/dist/lib/browser/chunk-M55MBYG7.mjs.map +0 -7
  325. package/dist/lib/browser/chunk-SEMCG4ZK.mjs +0 -195
  326. package/dist/lib/browser/chunk-SEMCG4ZK.mjs.map +0 -7
  327. package/dist/lib/browser/chunk-VK53MITK.mjs.map +0 -7
  328. package/dist/lib/browser/cli/index.mjs +0 -73
  329. package/dist/lib/browser/cli/index.mjs.map +0 -7
  330. package/dist/lib/browser/components/index.mjs +0 -20
  331. package/dist/lib/browser/create-chat-E2ZLVTLP.mjs.map +0 -7
  332. package/dist/lib/browser/ensure-companion-chat-7GDMXSQW.mjs.map +0 -7
  333. package/dist/lib/browser/hooks/index.mjs +0 -39
  334. package/dist/lib/browser/index.mjs +0 -84
  335. package/dist/lib/browser/index.mjs.map +0 -7
  336. package/dist/lib/browser/meta.json +0 -1
  337. package/dist/lib/browser/on-create-space-4J3KTNAJ.mjs.map +0 -7
  338. package/dist/lib/browser/operations/index.mjs +0 -13
  339. package/dist/lib/browser/operations/index.mjs.map +0 -7
  340. package/dist/lib/browser/resolve-navigation-targets-3ZPQE6SZ.mjs.map +0 -7
  341. package/dist/lib/browser/run-prompt-in-new-chat-AA3KPBDN.mjs.map +0 -7
  342. package/dist/lib/browser/set-current-chat-P4VHI3YF.mjs.map +0 -7
  343. package/dist/lib/browser/translations.mjs.map +0 -7
  344. package/dist/lib/browser/types/index.mjs +0 -18
  345. package/dist/lib/browser/update-chat-name-VWKNUON7.mjs.map +0 -7
  346. package/dist/lib/node-esm/AssistantSettings-23A5IMHS.mjs +0 -41
  347. package/dist/lib/node-esm/AssistantSettings-23A5IMHS.mjs.map +0 -7
  348. package/dist/lib/node-esm/blueprints/index.mjs +0 -32
  349. package/dist/lib/node-esm/blueprints/index.mjs.map +0 -7
  350. package/dist/lib/node-esm/chunk-FWC3ZGPH.mjs +0 -933
  351. package/dist/lib/node-esm/chunk-FWC3ZGPH.mjs.map +0 -7
  352. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +0 -11
  353. package/dist/lib/node-esm/chunk-JKEB3NFZ.mjs +0 -2302
  354. package/dist/lib/node-esm/chunk-JKEB3NFZ.mjs.map +0 -7
  355. package/dist/lib/node-esm/chunk-MBDVPB4V.mjs +0 -176
  356. package/dist/lib/node-esm/chunk-MBDVPB4V.mjs.map +0 -7
  357. package/dist/lib/node-esm/chunk-XAFVSEUJ.mjs +0 -196
  358. package/dist/lib/node-esm/chunk-XAFVSEUJ.mjs.map +0 -7
  359. package/dist/lib/node-esm/cli/index.mjs +0 -74
  360. package/dist/lib/node-esm/cli/index.mjs.map +0 -7
  361. package/dist/lib/node-esm/components/index.mjs +0 -21
  362. package/dist/lib/node-esm/create-chat-UQQ3542N.mjs +0 -74
  363. package/dist/lib/node-esm/create-chat-UQQ3542N.mjs.map +0 -7
  364. package/dist/lib/node-esm/ensure-companion-chat-LVCPD4DJ.mjs +0 -66
  365. package/dist/lib/node-esm/ensure-companion-chat-LVCPD4DJ.mjs.map +0 -7
  366. package/dist/lib/node-esm/hooks/index.mjs +0 -40
  367. package/dist/lib/node-esm/index.mjs +0 -85
  368. package/dist/lib/node-esm/index.mjs.map +0 -7
  369. package/dist/lib/node-esm/meta.json +0 -1
  370. package/dist/lib/node-esm/on-create-space-M63UBTTT.mjs +0 -23
  371. package/dist/lib/node-esm/on-create-space-M63UBTTT.mjs.map +0 -7
  372. package/dist/lib/node-esm/operations/index.mjs +0 -14
  373. package/dist/lib/node-esm/operations/index.mjs.map +0 -7
  374. package/dist/lib/node-esm/resolve-navigation-targets-HO77CAFT.mjs +0 -23
  375. package/dist/lib/node-esm/resolve-navigation-targets-HO77CAFT.mjs.map +0 -7
  376. package/dist/lib/node-esm/run-prompt-in-new-chat-RIRYYYPK.mjs +0 -107
  377. package/dist/lib/node-esm/run-prompt-in-new-chat-RIRYYYPK.mjs.map +0 -7
  378. package/dist/lib/node-esm/set-current-chat-Z7GJ52VX.mjs +0 -55
  379. package/dist/lib/node-esm/set-current-chat-Z7GJ52VX.mjs.map +0 -7
  380. package/dist/lib/node-esm/translations.mjs +0 -173
  381. package/dist/lib/node-esm/translations.mjs.map +0 -7
  382. package/dist/lib/node-esm/types/index.mjs +0 -19
  383. package/dist/lib/node-esm/update-chat-name-GV4HX32Z.mjs +0 -57
  384. package/dist/lib/node-esm/update-chat-name-GV4HX32Z.mjs.map +0 -7
  385. package/dist/types/src/cli/index.d.ts +0 -2
  386. package/dist/types/src/cli/index.d.ts.map +0 -1
  387. package/dist/types/src/cli/plugin.d.ts +0 -10
  388. package/dist/types/src/cli/plugin.d.ts.map +0 -1
  389. package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts.map +0 -1
  390. package/dist/types/src/containers/ChatContainer/index.d.ts +0 -2
  391. package/dist/types/src/containers/ChatContainer/index.d.ts.map +0 -1
  392. package/dist/types/src/operations/definitions.d.ts.map +0 -1
  393. package/dist/types/src/queue-logger.d.ts +0 -11
  394. package/dist/types/src/queue-logger.d.ts.map +0 -1
  395. package/dist/types/src/types/capabilities.d.ts +0 -32
  396. package/dist/types/src/types/capabilities.d.ts.map +0 -1
  397. package/dist/types/src/types/events.d.ts +0 -5
  398. package/dist/types/src/types/events.d.ts.map +0 -1
  399. package/src/AssistantPlugin.tsx +0 -238
  400. package/src/cli/plugin.ts +0 -83
  401. package/src/containers/ChatContainer/index.ts +0 -5
  402. package/src/types/capabilities.ts +0 -35
  403. package/src/types/events.ts +0 -11
  404. /package/dist/lib/{browser/chunk-J5LGTIGS.mjs.map → neutral/AssistantPlugin.mjs.map} +0 -0
  405. /package/dist/lib/{browser → neutral}/AssistantSettings-GG52BLKS.mjs +0 -0
  406. /package/dist/lib/{browser → neutral}/AssistantSettings-GG52BLKS.mjs.map +0 -0
  407. /package/dist/lib/{browser/components/index.mjs.map → neutral/ChatArticle-WVAFZPVI.mjs.map} +0 -0
  408. /package/dist/lib/{browser/hooks → neutral/blueprints}/index.mjs.map +0 -0
  409. /package/dist/lib/{browser → neutral}/chunk-J5LGTIGS.mjs +0 -0
  410. /package/dist/lib/{browser/types/index.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
  411. /package/dist/lib/{node-esm/components → neutral}/index.mjs.map +0 -0
  412. /package/dist/lib/{node-esm/chunk-HSLMI22Q.mjs.map → neutral/meta.mjs.map} +0 -0
  413. /package/dist/lib/{node-esm/hooks → neutral/operations}/index.mjs.map +0 -0
  414. /package/dist/lib/{node-esm/types/index.mjs.map → neutral/testing.mjs.map} +0 -0
@@ -0,0 +1,672 @@
1
+ import "./chunk-J5LGTIGS.mjs";
2
+
3
+ // src/containers/TracePanel/TracePanel.tsx
4
+ import { Atom } from "@effect-atom/atom";
5
+ import { useAtomValue } from "@effect-atom/atom-react";
6
+ import { pipe as pipe2 } from "effect/Function";
7
+ import React, { useCallback, useMemo, useState } from "react";
8
+ import { useAtomCapability, useOperationInvoker } from "@dxos/app-framework/ui";
9
+ import { LayoutOperation } from "@dxos/app-toolkit";
10
+ import { Trace as Trace3 } from "@dxos/compute";
11
+ import { Filter, Query } from "@dxos/echo";
12
+ import { AtomQuery } from "@dxos/echo-atom";
13
+ import { FeedTraceSink, Process as Process2 } from "@dxos/functions-runtime";
14
+ import { DXN } from "@dxos/keys";
15
+ import { log as log2 } from "@dxos/log";
16
+ import { useComputeRuntimeService } from "@dxos/plugin-automation/hooks";
17
+ import { ScrollContainer } from "@dxos/react-ui";
18
+ import { useAttentionAttributes } from "@dxos/react-ui-attention";
19
+ import { Timeline } from "@dxos/react-ui-components";
20
+ import { Syntax } from "@dxos/react-ui-syntax-highlighter";
21
+ import { composable, composableProps, mx } from "@dxos/ui-theme";
22
+ import { ProcessTree } from "#components";
23
+ import { AssistantCapabilities } from "#types";
24
+
25
+ // src/containers/TracePanel/execution-graph.ts
26
+ import * as Array from "effect/Array";
27
+ import * as Either from "effect/Either";
28
+ import { pipe } from "effect/Function";
29
+ import * as Pipeable from "effect/Pipeable";
30
+ import * as Schema from "effect/Schema";
31
+ import * as Struct from "effect/Struct";
32
+ import { AgentRequestBegin as AgentRequestBegin2, AgentRequestEnd as AgentRequestEnd2, CompleteBlock } from "@dxos/assistant";
33
+ import { Trace as Trace2 } from "@dxos/compute";
34
+ import { AGENT_PROCESS_KEY, Process } from "@dxos/functions-runtime";
35
+ import { LogLevel, log } from "@dxos/log";
36
+
37
+ // src/containers/TracePanel/span-tree.ts
38
+ import { AgentRequestBegin, AgentRequestEnd } from "@dxos/assistant";
39
+ import { Trace } from "@dxos/compute";
40
+ var ROOT_SPAN_ID = "<main>";
41
+ var BEGIN_EVENT_TYPES = /* @__PURE__ */ new Set([
42
+ Trace.OperationStart.key,
43
+ AgentRequestBegin.key
44
+ ]);
45
+ var END_EVENT_TYPES = /* @__PURE__ */ new Set([
46
+ Trace.OperationEnd.key,
47
+ AgentRequestEnd.key
48
+ ]);
49
+ var isSpanBeginEvent = (event) => BEGIN_EVENT_TYPES.has(event.type);
50
+ var isSpanEndEvent = (event) => END_EVENT_TYPES.has(event.type);
51
+ var computeMeta = (rawMeta) => ({
52
+ pid: rawMeta.pid,
53
+ parentPid: rawMeta.parentPid,
54
+ processName: rawMeta.processName,
55
+ conversationId: rawMeta.conversationId,
56
+ triggerId: rawMeta.triggerId,
57
+ toolCallId: rawMeta.toolCallId,
58
+ runtimeName: rawMeta.runtimeName
59
+ });
60
+ var makeMutableSpan = (id, meta) => ({
61
+ id,
62
+ meta,
63
+ events: [],
64
+ children: [],
65
+ firstTimestamp: Number.POSITIVE_INFINITY
66
+ });
67
+ var freezeSpan = (span) => ({
68
+ id: span.id,
69
+ meta: span.meta,
70
+ events: span.events,
71
+ children: span.children.map(freezeSpan)
72
+ });
73
+ var buildSpanTree = (messages, options = {}) => {
74
+ const allEvents = messages.flatMap((message) => Trace.flatten(message));
75
+ allEvents.sort((a, b) => a.timestamp - b.timestamp);
76
+ const events = options.eventLimit !== void 0 && allEvents.length > options.eventLimit ? allEvents.slice(-options.eventLimit) : allEvents;
77
+ const root = makeMutableSpan(ROOT_SPAN_ID, {});
78
+ const openSpans = /* @__PURE__ */ new Map();
79
+ let spanCounter = 0;
80
+ const allocSpanId = (pid) => {
81
+ const id = `${pid}#${spanCounter}`;
82
+ spanCounter += 1;
83
+ return id;
84
+ };
85
+ const noteTimestamp = (span, timestamp) => {
86
+ if (timestamp < span.firstTimestamp) {
87
+ span.firstTimestamp = timestamp;
88
+ }
89
+ };
90
+ for (const event of events) {
91
+ const pid = event.meta.pid;
92
+ if (!pid) {
93
+ root.events.push(event);
94
+ noteTimestamp(root, event.timestamp);
95
+ continue;
96
+ }
97
+ if (BEGIN_EVENT_TYPES.has(event.type)) {
98
+ const parentPid = event.meta.parentPid;
99
+ const parent = parentPid && openSpans.get(parentPid) || root;
100
+ const span = makeMutableSpan(allocSpanId(pid), computeMeta(event.meta));
101
+ span.events.push(event);
102
+ noteTimestamp(span, event.timestamp);
103
+ parent.children.push(span);
104
+ openSpans.set(pid, span);
105
+ continue;
106
+ }
107
+ if (END_EVENT_TYPES.has(event.type)) {
108
+ const span = openSpans.get(pid);
109
+ if (span) {
110
+ span.events.push(event);
111
+ noteTimestamp(span, event.timestamp);
112
+ openSpans.delete(pid);
113
+ } else {
114
+ root.events.push(event);
115
+ noteTimestamp(root, event.timestamp);
116
+ }
117
+ continue;
118
+ }
119
+ const open = openSpans.get(pid);
120
+ if (open) {
121
+ open.events.push(event);
122
+ noteTimestamp(open, event.timestamp);
123
+ } else {
124
+ root.events.push(event);
125
+ noteTimestamp(root, event.timestamp);
126
+ }
127
+ }
128
+ const sortChildren = (span) => {
129
+ span.children.sort((a, b) => a.firstTimestamp - b.firstTimestamp);
130
+ for (const child of span.children) {
131
+ sortChildren(child);
132
+ }
133
+ };
134
+ sortChildren(root);
135
+ return freezeSpan(root);
136
+ };
137
+ var walkSpanTree = (root, visit, depth = 0) => {
138
+ visit(root, depth);
139
+ for (const child of root.children) {
140
+ walkSpanTree(child, visit, depth + 1);
141
+ }
142
+ };
143
+
144
+ // src/containers/TracePanel/execution-graph.ts
145
+ var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/containers/TracePanel/execution-graph.ts";
146
+ var MAIN_BRANCH = "main";
147
+ var ICONS = {
148
+ agentRequestBegin: {
149
+ icon: "ph--atom--regular",
150
+ level: LogLevel.VERBOSE
151
+ },
152
+ agentRequestEnd: {
153
+ icon: "ph--atom--regular",
154
+ level: LogLevel.INFO
155
+ },
156
+ userMessage: {
157
+ icon: "ph--user--regular",
158
+ level: LogLevel.VERBOSE
159
+ },
160
+ statusMessage: {
161
+ icon: "ph--info--regular",
162
+ level: LogLevel.VERBOSE
163
+ },
164
+ operationStart: {
165
+ icon: "ph--function--regular",
166
+ level: LogLevel.VERBOSE
167
+ },
168
+ operationEndSuccess: {
169
+ icon: "ph--function--regular",
170
+ level: LogLevel.INFO
171
+ },
172
+ operationEndError: {
173
+ icon: "ph--function--regular",
174
+ level: LogLevel.ERROR
175
+ },
176
+ agentRequestRunning: {
177
+ icon: "ph--spinner-gap--regular",
178
+ level: LogLevel.VERBOSE
179
+ },
180
+ processRunning: {
181
+ icon: "ph--spinner-gap--regular",
182
+ level: LogLevel.VERBOSE
183
+ }
184
+ };
185
+ var buildExecutionGraph = ({ traceMessages, activeProcesses = [], eventLimit = 500 }) => {
186
+ const spanTree = buildSpanTree(traceMessages, {
187
+ eventLimit
188
+ });
189
+ const built = spanTreeToCommits(spanTree, activeProcesses);
190
+ log("trace execution graph", {
191
+ traceMessages: traceMessages.length,
192
+ commits: built.commits.length,
193
+ branches: built.branches.length,
194
+ activeProcesses: activeProcesses.length
195
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 61, S: void 0 });
196
+ return {
197
+ ...built,
198
+ spanTree
199
+ };
200
+ };
201
+ var presentEvent = (event) => {
202
+ if (Trace2.isOfType(AgentRequestBegin2, event)) {
203
+ if (Either.isLeft(Schema.validateEither(AgentRequestBegin2.schema)(event.data))) {
204
+ log("invalid trace event", {
205
+ type: event.type
206
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 75, S: void 0 });
207
+ return void 0;
208
+ }
209
+ return {
210
+ icon: ICONS.agentRequestBegin.icon,
211
+ level: ICONS.agentRequestBegin.level,
212
+ message: "Agent processing request..."
213
+ };
214
+ }
215
+ if (Trace2.isOfType(AgentRequestEnd2, event)) {
216
+ if (Either.isLeft(Schema.validateEither(AgentRequestEnd2.schema)(event.data))) {
217
+ log("invalid trace event", {
218
+ type: event.type
219
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 88, S: void 0 });
220
+ return void 0;
221
+ }
222
+ return {
223
+ icon: ICONS.agentRequestEnd.icon,
224
+ level: ICONS.agentRequestEnd.level,
225
+ message: "Agent completed request"
226
+ };
227
+ }
228
+ if (Trace2.isOfType(CompleteBlock, event)) {
229
+ if (Either.isLeft(Schema.validateEither(CompleteBlock.schema)(event.data))) {
230
+ log("invalid trace event", {
231
+ type: event.type
232
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 101, S: void 0 });
233
+ return void 0;
234
+ }
235
+ switch (event.data.block._tag) {
236
+ case "text":
237
+ return event.data.role === "user" ? {
238
+ icon: ICONS.userMessage.icon,
239
+ level: ICONS.userMessage.level,
240
+ message: trimText(event.data.block.text)
241
+ } : void 0;
242
+ case "status":
243
+ return {
244
+ icon: ICONS.statusMessage.icon,
245
+ level: ICONS.statusMessage.level,
246
+ message: trimText(event.data.block.statusText)
247
+ };
248
+ default:
249
+ return void 0;
250
+ }
251
+ }
252
+ if (Trace2.isOfType(Trace2.OperationStart, event)) {
253
+ if (Either.isLeft(Schema.validateEither(Trace2.OperationStart.schema)(event.data))) {
254
+ log("invalid trace event", {
255
+ type: event.type
256
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 125, S: void 0 });
257
+ return void 0;
258
+ }
259
+ return {
260
+ icon: ICONS.operationStart.icon,
261
+ level: ICONS.operationStart.level,
262
+ message: event.data.name ?? event.data.key,
263
+ idSuffix: `${event.data.key}:start`
264
+ };
265
+ }
266
+ if (Trace2.isOfType(Trace2.OperationEnd, event)) {
267
+ if (Either.isLeft(Schema.validateEither(Trace2.OperationEnd.schema)(event.data))) {
268
+ log("invalid trace event", {
269
+ type: event.type
270
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 139, S: void 0 });
271
+ return void 0;
272
+ }
273
+ const success = event.data.outcome === "success";
274
+ return {
275
+ icon: success ? ICONS.operationEndSuccess.icon : ICONS.operationEndError.icon,
276
+ level: success ? ICONS.operationEndSuccess.level : ICONS.operationEndError.level,
277
+ message: `${event.data.name ?? event.data.key} - ${success ? "Success" : "Error"}`,
278
+ idSuffix: `${event.data.key}:end`
279
+ };
280
+ }
281
+ return void 0;
282
+ };
283
+ var isCollapsibleSpan = (span, parent) => {
284
+ if (span.id === ROOT_SPAN_ID) {
285
+ return false;
286
+ }
287
+ if (span.events.length !== 2) {
288
+ return false;
289
+ }
290
+ if (span.children.length > 0) {
291
+ return false;
292
+ }
293
+ const firstEvent = span.events[0];
294
+ const lastEvent = span.events[span.events.length - 1];
295
+ if (!isSpanBeginEvent(firstEvent) || !isSpanEndEvent(lastEvent)) {
296
+ return false;
297
+ }
298
+ return parent !== null;
299
+ };
300
+ var spanTreeToCommits = (root, activeProcesses) => {
301
+ const builder = new GraphBuilder();
302
+ builder.addBranch(MAIN_BRANCH);
303
+ const parentBySpan = /* @__PURE__ */ new Map();
304
+ parentBySpan.set(root, null);
305
+ const indexParents = (span) => {
306
+ for (const child of span.children) {
307
+ parentBySpan.set(child, span);
308
+ indexParents(child);
309
+ }
310
+ };
311
+ indexParents(root);
312
+ const findParentSpan = (span) => parentBySpan.get(span) ?? null;
313
+ const branchOf = (span) => {
314
+ if (!span || span.id === ROOT_SPAN_ID) {
315
+ return MAIN_BRANCH;
316
+ }
317
+ return span.meta.pid ?? span.id;
318
+ };
319
+ const lastInAncestorChain = (span) => {
320
+ const branches = [];
321
+ const seen = /* @__PURE__ */ new Set();
322
+ let current = span;
323
+ while (current) {
324
+ const branch = branchOf(current);
325
+ if (!seen.has(branch)) {
326
+ seen.add(branch);
327
+ branches.push(branch);
328
+ }
329
+ current = findParentSpan(current);
330
+ }
331
+ if (!seen.has(MAIN_BRANCH)) {
332
+ branches.push(MAIN_BRANCH);
333
+ }
334
+ return CommitSelector.firstOf(...branches.map((branch) => CommitSelector.branch(branch).pipe(CommitSelector.compose(CommitSelector.last()))));
335
+ };
336
+ const stream = [];
337
+ walkSpanTree(root, (span) => {
338
+ span.events.forEach((event, eventIndex) => {
339
+ stream.push({
340
+ span,
341
+ event,
342
+ eventIndex,
343
+ globalIndex: stream.length
344
+ });
345
+ });
346
+ });
347
+ stream.sort((a, b) => a.event.timestamp - b.event.timestamp || a.globalIndex - b.globalIndex);
348
+ const beginCommitIdBySpan = /* @__PURE__ */ new Map();
349
+ for (const { span, event, globalIndex } of stream) {
350
+ const presentation = presentEvent(event);
351
+ if (!presentation) {
352
+ continue;
353
+ }
354
+ const isBeginEvent = isSpanBeginEvent(event);
355
+ const isEndEvent = isSpanEndEvent(event);
356
+ const parentSpan = findParentSpan(span);
357
+ const collapsible = isCollapsibleSpan(span, parentSpan);
358
+ if (collapsible && isBeginEvent) {
359
+ continue;
360
+ }
361
+ const parentBranch = branchOf(parentSpan);
362
+ const ownBranch = branchOf(span);
363
+ let branch;
364
+ let parents;
365
+ if (span.id === ROOT_SPAN_ID) {
366
+ branch = MAIN_BRANCH;
367
+ parents = builder.computeParents(CommitSelector.branch(MAIN_BRANCH).pipe(CommitSelector.compose(CommitSelector.last())));
368
+ } else if (collapsible) {
369
+ branch = parentBranch;
370
+ parents = builder.computeParents(lastInAncestorChain(parentSpan));
371
+ } else if (isBeginEvent) {
372
+ branch = parentBranch;
373
+ parents = builder.computeParents(lastInAncestorChain(parentSpan));
374
+ } else if (isEndEvent) {
375
+ branch = parentBranch;
376
+ const beginId = beginCommitIdBySpan.get(span.id);
377
+ parents = builder.computeParents(CommitSelector.unionAll(beginId ? CommitSelector.id(beginId) : lastInAncestorChain(parentSpan), CommitSelector.branch(ownBranch).pipe(CommitSelector.compose(CommitSelector.last()))));
378
+ } else {
379
+ branch = ownBranch;
380
+ parents = builder.computeParents(CommitSelector.branch(ownBranch).pipe(CommitSelector.compose(CommitSelector.last()), CommitSelector.orElse(lastInAncestorChain(parentSpan))));
381
+ }
382
+ const commitId = formatCommitId(span, globalIndex, presentation.idSuffix);
383
+ const commit = {
384
+ id: commitId,
385
+ branch,
386
+ parents,
387
+ timestamp: new Date(event.timestamp),
388
+ icon: presentation.icon,
389
+ level: presentation.level,
390
+ message: presentation.message
391
+ };
392
+ builder.addCommit(commit);
393
+ if (isBeginEvent && !collapsible && span.id !== ROOT_SPAN_ID) {
394
+ beginCommitIdBySpan.set(span.id, commitId);
395
+ }
396
+ }
397
+ for (const process of activeProcesses) {
398
+ if (process.key === AGENT_PROCESS_KEY && process.params.target && (process.state === Process.State.RUNNING || process.state === Process.State.HYBERNATING)) {
399
+ builder.addCommit({
400
+ id: `running:${process.pid}`,
401
+ branch: process.pid,
402
+ parents: builder.computeParents(CommitSelector.branch(process.pid).pipe(CommitSelector.compose(CommitSelector.last()))),
403
+ icon: ICONS.agentRequestRunning.icon,
404
+ level: ICONS.agentRequestRunning.level,
405
+ message: "Generating...",
406
+ timestamp: /* @__PURE__ */ new Date()
407
+ });
408
+ } else if (process.state === Process.State.RUNNING && builder.hasBranch(process.pid)) {
409
+ builder.addCommit({
410
+ id: `running:${process.pid}`,
411
+ branch: process.pid,
412
+ parents: builder.computeParents(CommitSelector.branch(process.pid).pipe(CommitSelector.compose(CommitSelector.last()))),
413
+ icon: ICONS.processRunning.icon,
414
+ level: ICONS.processRunning.level,
415
+ message: "Running...",
416
+ timestamp: /* @__PURE__ */ new Date()
417
+ });
418
+ }
419
+ }
420
+ return builder.build();
421
+ };
422
+ var formatCommitId = (span, globalIndex, suffix) => {
423
+ const base = `${span.id}:${globalIndex}`;
424
+ return suffix ? `${base}:${suffix}` : base;
425
+ };
426
+ var trimText = (text) => text.slice(0, 100).trim().split("\n")[0];
427
+ var CommitSelector = {
428
+ make: (select) => ({
429
+ select,
430
+ pipe(...args) {
431
+ return Pipeable.pipeArguments(this, args);
432
+ }
433
+ }),
434
+ identity: () => CommitSelector.make((commits) => commits),
435
+ /**
436
+ * Selects commits that match the given predicate.
437
+ */
438
+ filter: (predicate) => CommitSelector.make((commits) => commits.filter(predicate)),
439
+ /**
440
+ * Selects commits by id.
441
+ */
442
+ id: (id) => CommitSelector.filter((commit) => commit.id === id),
443
+ /**
444
+ * Selects commits by tag.
445
+ */
446
+ tag: (tag) => CommitSelector.filter((commit) => tag && commit.tags?.includes(tag)),
447
+ /**
448
+ * Selects commits by if any of the given tags are present.
449
+ */
450
+ anyTags: (tags) => CommitSelector.filter((commit) => tags.some((tag) => tag && commit.tags?.includes(tag))),
451
+ /**
452
+ * Selects commits by branch.
453
+ */
454
+ branch: (branch) => CommitSelector.filter((commit) => branch && commit.branch === branch),
455
+ /**
456
+ * Chains two selectors together, applying the second selector to the result of the first.
457
+ *
458
+ * Example:
459
+ *
460
+ * ```
461
+ * CommitSelector.tag('tag').pipe(CommitSelector.compose(CommitSelector.branch('main')));
462
+ * ```
463
+ */
464
+ compose: (next) => (prev) => CommitSelector.make((commits) => next.select(prev.select(commits))),
465
+ /**
466
+ * If `prev` selector matches no commits, return `next` selector, otherwise return `prev` selector.
467
+ * Same as `CommitSelector.firstOf(prev, next)`.
468
+ *
469
+ * Example:
470
+ *
471
+ * ```
472
+ * CommitSelector.tag('tag').pipe(CommitSelector.orElse(CommitSelector.branch('main')));
473
+ * ```
474
+ */
475
+ orElse: (next) => (prev) => CommitSelector.make((commits) => {
476
+ const selected = prev.select(commits);
477
+ if (selected.length > 0) {
478
+ return selected;
479
+ }
480
+ return next.select(commits);
481
+ }),
482
+ /**
483
+ * Selects commits that match either of the given selectors.
484
+ */
485
+ andAlso: (next) => (prev) => CommitSelector.unionAll(prev, next),
486
+ /**
487
+ * Selects the first n commits.
488
+ */
489
+ first: (n = 1) => CommitSelector.make((commits) => commits.slice(0, n)),
490
+ /**
491
+ * Selects the last n commits (reverses the order of the commits).
492
+ */
493
+ last: (n = 1) => CommitSelector.make((commits) => commits.toReversed().slice(0, n)),
494
+ /**
495
+ * Selects commits that do not match the given selector.
496
+ */
497
+ not: (selector) => CommitSelector.make((commits) => {
498
+ const selected = selector.select(commits);
499
+ return commits.filter((commit) => !selected.includes(commit));
500
+ }),
501
+ /**
502
+ * Selects commits that match any of the given selectors.
503
+ */
504
+ unionAll: (...selectors) => CommitSelector.make((commits) => {
505
+ return Array.dedupeWith(selectors.flatMap((selector) => selector.select(commits)), (a, b) => a.id === b.id);
506
+ }),
507
+ /**
508
+ * Selects commits that match all of the given selectors.
509
+ */
510
+ intersectAll: (...selectors) => CommitSelector.make((commits) => {
511
+ const selected = selectors.map((selector) => selector.select(commits));
512
+ if (selected.length === 0) {
513
+ return [];
514
+ }
515
+ return selected[0].filter((commit) => selected.every((selected2) => selected2.some((c) => c.id === commit.id)));
516
+ }),
517
+ /**
518
+ * Returns the result of the first selector that matches any commits.
519
+ */
520
+ firstOf: (...selectors) => CommitSelector.make((commits) => {
521
+ for (const selector of selectors) {
522
+ const selected = selector.select(commits);
523
+ if (selected.length > 0) {
524
+ return selected;
525
+ }
526
+ }
527
+ return [];
528
+ })
529
+ };
530
+ var GraphBuilder = class {
531
+ #commits = [];
532
+ #branches = /* @__PURE__ */ new Set();
533
+ findCommits(selector) {
534
+ return selector.select(this.#commits);
535
+ }
536
+ hasBranch(branch) {
537
+ return this.#branches.has(branch);
538
+ }
539
+ addCommit(commit) {
540
+ this.addBranch(commit.branch);
541
+ this.#commits.push(commit);
542
+ }
543
+ /**
544
+ * Computes parents — picks first matching commit's id.
545
+ */
546
+ computeParents(selector) {
547
+ return Array.dedupe(selector.select(this.#commits).map((commit) => commit.id));
548
+ }
549
+ addBranch(branch) {
550
+ this.#branches.add(branch);
551
+ }
552
+ /**
553
+ * Removes duplicate commits and dangling parents.
554
+ */
555
+ doctor() {
556
+ this.#commits = pipe(this.#commits, Array.dedupeWith((a, b) => a.id === b.id), Array.map(Struct.evolve({
557
+ parents: (parents) => parents ? Array.filter(parents, (id) => this.#commits.some((commit) => commit.id === id)) : void 0
558
+ })));
559
+ }
560
+ build() {
561
+ this.doctor();
562
+ return {
563
+ commits: this.#commits,
564
+ branches: [
565
+ ...this.#branches
566
+ ]
567
+ };
568
+ }
569
+ };
570
+
571
+ // src/containers/TracePanel/TracePanel.tsx
572
+ var __dxlog_file2 = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/containers/TracePanel/TracePanel.tsx";
573
+ var TracePanel = composable(({ space, attendableId, onProcessTerminate, ...props }, forwardedRef) => {
574
+ const attentionAttrs = useAttentionAttributes(attendableId);
575
+ const { invokePromise } = useOperationInvoker();
576
+ const settings = useAtomCapability(AssistantCapabilities.Settings);
577
+ const tracePanelDebug = settings.tracePanelDebug ?? false;
578
+ const { branches, commits, spanTree } = useExecutionGraph(space);
579
+ const runtime = useComputeRuntimeService(Process2.ProcessMonitorService, space.id);
580
+ const processes = useAtomValue(runtime?.processTreeAtom ?? atomEmpty);
581
+ const [selectedCommit, setSelectedCommit] = useState();
582
+ const handleCommitSelect = useCallback((commit) => {
583
+ setSelectedCommit(commit);
584
+ if (commit?.link) {
585
+ const dxn = DXN.tryParse(commit.link)?.asEchoDXN();
586
+ if (dxn?.spaceId && dxn.echoId) {
587
+ void invokePromise(LayoutOperation.Open, {
588
+ subject: [
589
+ `${dxn.spaceId}:${dxn.echoId}`
590
+ ]
591
+ });
592
+ }
593
+ }
594
+ }, [
595
+ invokePromise,
596
+ setSelectedCommit
597
+ ]);
598
+ const [currentBranch, setCurrentBranch] = useState(null);
599
+ const handleProcessSelect = useCallback((process) => {
600
+ const branch = branches.find((branch2) => branch2 === process.pid.toString());
601
+ if (branch) {
602
+ setCurrentBranch(branch);
603
+ }
604
+ }, [
605
+ branches
606
+ ]);
607
+ return /* @__PURE__ */ React.createElement("div", {
608
+ ...composableProps(props, {
609
+ ...attentionAttrs,
610
+ classNames: mx("h-full grid divide-y divide-separator", !tracePanelDebug && selectedCommit ? "grid-rows-[minmax(0,4lh)_1fr_minmax(0,206px)]" : "grid-rows-[minmax(0,4lh)_1fr]")
611
+ }),
612
+ ref: forwardedRef
613
+ }, /* @__PURE__ */ React.createElement(ProcessTree, {
614
+ processes,
615
+ onProcessSelect: handleProcessSelect,
616
+ onProcessTerminate
617
+ }), /* @__PURE__ */ React.createElement(ScrollContainer.Root, {
618
+ pin: true
619
+ }, /* @__PURE__ */ React.createElement(ScrollContainer.Content, {
620
+ thin: true
621
+ }, /* @__PURE__ */ React.createElement(ScrollContainer.Fade, null), /* @__PURE__ */ React.createElement(ScrollContainer.Viewport, null, tracePanelDebug ? /* @__PURE__ */ React.createElement(Syntax.Root, {
622
+ data: spanTree
623
+ }, /* @__PURE__ */ React.createElement(Syntax.Content, null, /* @__PURE__ */ React.createElement(Syntax.Viewport, null, /* @__PURE__ */ React.createElement(Syntax.Code, {
624
+ className: "text-xs"
625
+ })))) : /* @__PURE__ */ React.createElement(Timeline, {
626
+ compact: true,
627
+ commits,
628
+ branches,
629
+ currentBranch,
630
+ onSelect: handleCommitSelect
631
+ })), /* @__PURE__ */ React.createElement(ScrollContainer.ScrollDownButton, null))), !tracePanelDebug && selectedCommit && /* @__PURE__ */ React.createElement(Syntax.Root, {
632
+ data: selectedCommit
633
+ }, /* @__PURE__ */ React.createElement(Syntax.Content, null, /* @__PURE__ */ React.createElement(Syntax.Viewport, null, /* @__PURE__ */ React.createElement(Syntax.Code, {
634
+ className: "text-xs"
635
+ })))));
636
+ });
637
+ var atomEmpty = Atom.make(() => []);
638
+ var useExecutionGraph = (space, { eventLimit } = {}) => {
639
+ const runtime = useComputeRuntimeService(Process2.ProcessMonitorService, space.id);
640
+ const activeProcesses = useAtomValue(runtime?.processTreeAtom ?? atomEmpty);
641
+ const atom = useMemo(() => getExecutionGraph(space, activeProcesses, {
642
+ eventLimit
643
+ }), [
644
+ space,
645
+ activeProcesses,
646
+ eventLimit
647
+ ]);
648
+ return useAtomValue(atom);
649
+ };
650
+ var getExecutionGraph = (space, activeProcesses = [], { eventLimit = 300 } = {}) => {
651
+ return pipe2(AtomQuery.make(space.db, FeedTraceSink.query), Atom.map((feeds) => {
652
+ log2("trace panel query trace feeds", {
653
+ spaceId: space.id,
654
+ feedCount: feeds.length
655
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 107, S: void 0 });
656
+ return AtomQuery.make(space.db, feeds.length > 0 ? Query.type(Trace3.Message).from(feeds[0]) : Query.select(Filter.nothing()));
657
+ }), (_) => Atom.make((get) => get(get(_))), (_) => Atom.make((get) => buildExecutionGraph({
658
+ traceMessages: [
659
+ ...get(_)
660
+ ],
661
+ activeProcesses,
662
+ eventLimit
663
+ })));
664
+ };
665
+
666
+ // src/containers/TracePanel/index.ts
667
+ var TracePanel_default = TracePanel;
668
+ export {
669
+ TracePanel,
670
+ TracePanel_default as default
671
+ };
672
+ //# sourceMappingURL=TracePanel-C77SPEIS.mjs.map