@dxos/plugin-automation 0.7.5-staging.2ff1350 → 0.7.5-staging.e6154f3

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 (318) hide show
  1. package/dist/lib/browser/AutomationPanel-ITYXSN5Z.mjs +132 -0
  2. package/dist/lib/browser/AutomationPanel-ITYXSN5Z.mjs.map +7 -0
  3. package/dist/lib/browser/{chunk-HZSTXZWK.mjs → chunk-OFDNNRLE.mjs} +3 -8
  4. package/dist/lib/browser/chunk-OFDNNRLE.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-U7QLNY2S.mjs +8 -0
  6. package/dist/lib/browser/chunk-U7QLNY2S.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-WY2C7JY4.mjs +119 -0
  8. package/dist/lib/browser/chunk-WY2C7JY4.mjs.map +7 -0
  9. package/dist/lib/browser/complementary-panel-4CPOJL4Y.mjs +56 -0
  10. package/dist/lib/browser/complementary-panel-4CPOJL4Y.mjs.map +7 -0
  11. package/dist/lib/browser/index.mjs +18 -395
  12. package/dist/lib/browser/index.mjs.map +4 -4
  13. package/dist/lib/browser/meta.json +1 -1
  14. package/dist/lib/browser/react-surface-SAPMN4PF.mjs +27 -0
  15. package/dist/lib/browser/react-surface-SAPMN4PF.mjs.map +7 -0
  16. package/dist/lib/node/{chunk-V4L7LTWM.cjs → AutomationPanel-X33HHDMQ.cjs} +19 -132
  17. package/dist/lib/node/AutomationPanel-X33HHDMQ.cjs.map +7 -0
  18. package/dist/lib/node/chunk-7Q5SNGCL.cjs +148 -0
  19. package/dist/lib/node/chunk-7Q5SNGCL.cjs.map +7 -0
  20. package/dist/lib/node/chunk-CB5OB6JH.cjs +40 -0
  21. package/dist/lib/node/chunk-CB5OB6JH.cjs.map +7 -0
  22. package/dist/lib/node/{chunk-BAQRBGOJ.cjs → chunk-ORMEYEBE.cjs} +6 -12
  23. package/dist/lib/node/chunk-ORMEYEBE.cjs.map +7 -0
  24. package/dist/lib/node/complementary-panel-ZYJJ42ZU.cjs +72 -0
  25. package/dist/lib/node/complementary-panel-ZYJJ42ZU.cjs.map +7 -0
  26. package/dist/lib/node/index.cjs +33 -396
  27. package/dist/lib/node/index.cjs.map +4 -4
  28. package/dist/lib/node/meta.json +1 -1
  29. package/dist/lib/node/{react-surface-IXKIJFRP.cjs → react-surface-2WRVAPGR.cjs} +9 -34
  30. package/dist/lib/node/react-surface-2WRVAPGR.cjs.map +7 -0
  31. package/dist/lib/node-esm/AutomationPanel-HY3GB4BT.mjs +133 -0
  32. package/dist/lib/node-esm/AutomationPanel-HY3GB4BT.mjs.map +7 -0
  33. package/dist/lib/node-esm/{chunk-IG4GSWZN.mjs → chunk-6MUUH67V.mjs} +3 -8
  34. package/dist/lib/node-esm/chunk-6MUUH67V.mjs.map +7 -0
  35. package/dist/lib/node-esm/chunk-R3P2WPBQ.mjs +10 -0
  36. package/dist/lib/node-esm/chunk-R3P2WPBQ.mjs.map +7 -0
  37. package/dist/lib/node-esm/chunk-UDD2VA6G.mjs +120 -0
  38. package/dist/lib/node-esm/chunk-UDD2VA6G.mjs.map +7 -0
  39. package/dist/lib/node-esm/complementary-panel-S42RIIAY.mjs +57 -0
  40. package/dist/lib/node-esm/complementary-panel-S42RIIAY.mjs.map +7 -0
  41. package/dist/lib/node-esm/index.mjs +18 -395
  42. package/dist/lib/node-esm/index.mjs.map +4 -4
  43. package/dist/lib/node-esm/meta.json +1 -1
  44. package/dist/lib/node-esm/react-surface-QWLPOYXO.mjs +28 -0
  45. package/dist/lib/node-esm/react-surface-QWLPOYXO.mjs.map +7 -0
  46. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  47. package/dist/types/src/capabilities/{ai-client.d.ts → complementary-panel.d.ts} +2 -3
  48. package/dist/types/src/capabilities/complementary-panel.d.ts.map +1 -0
  49. package/dist/types/src/capabilities/index.d.ts +1 -180
  50. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  51. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  52. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  53. package/dist/types/src/components/AutomationPanel/AutomationPanel.stories.d.ts.map +1 -1
  54. package/dist/types/src/components/TriggerEditor/TriggerEditor.stories.d.ts.map +1 -1
  55. package/dist/types/src/components/index.d.ts +0 -11
  56. package/dist/types/src/components/index.d.ts.map +1 -1
  57. package/dist/types/src/index.d.ts +1 -3
  58. package/dist/types/src/index.d.ts.map +1 -1
  59. package/dist/types/src/meta.d.ts +0 -2
  60. package/dist/types/src/meta.d.ts.map +1 -1
  61. package/dist/types/src/testing/index.d.ts +0 -1
  62. package/dist/types/src/testing/index.d.ts.map +1 -1
  63. package/dist/types/src/testing/test-functions.d.ts +0 -2
  64. package/dist/types/src/testing/test-functions.d.ts.map +1 -1
  65. package/dist/types/src/translations.d.ts +1 -112
  66. package/dist/types/src/translations.d.ts.map +1 -1
  67. package/package.json +21 -74
  68. package/src/AutomationPlugin.tsx +7 -76
  69. package/src/capabilities/complementary-panel.ts +56 -0
  70. package/src/capabilities/index.ts +1 -5
  71. package/src/capabilities/react-surface.tsx +3 -23
  72. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +1 -2
  73. package/src/components/AutomationPanel/AutomationPanel.tsx +56 -49
  74. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +1 -2
  75. package/src/components/index.ts +0 -8
  76. package/src/index.ts +2 -3
  77. package/src/meta.ts +1 -4
  78. package/src/testing/index.ts +0 -1
  79. package/src/testing/test-functions.ts +0 -7
  80. package/src/translations.ts +1 -37
  81. package/dist/lib/browser/AutomationPanel-NCKK3CFN.mjs +0 -8
  82. package/dist/lib/browser/AutomationPanel-NCKK3CFN.mjs.map +0 -7
  83. package/dist/lib/browser/ChatContainer-AZPLZJ5H.mjs +0 -12
  84. package/dist/lib/browser/ChatContainer-AZPLZJ5H.mjs.map +0 -7
  85. package/dist/lib/browser/ai-client-T2PBJISL.mjs +0 -22
  86. package/dist/lib/browser/ai-client-T2PBJISL.mjs.map +0 -7
  87. package/dist/lib/browser/app-graph-builder-F22H4YBQ.mjs +0 -111
  88. package/dist/lib/browser/app-graph-builder-F22H4YBQ.mjs.map +0 -7
  89. package/dist/lib/browser/chunk-67KDIIM6.mjs +0 -15
  90. package/dist/lib/browser/chunk-67KDIIM6.mjs.map +0 -7
  91. package/dist/lib/browser/chunk-HZSTXZWK.mjs.map +0 -7
  92. package/dist/lib/browser/chunk-L2YLAKCS.mjs +0 -151
  93. package/dist/lib/browser/chunk-L2YLAKCS.mjs.map +0 -7
  94. package/dist/lib/browser/chunk-LJ7F4KDM.mjs +0 -243
  95. package/dist/lib/browser/chunk-LJ7F4KDM.mjs.map +0 -7
  96. package/dist/lib/browser/chunk-M4MWUOUC.mjs +0 -382
  97. package/dist/lib/browser/chunk-M4MWUOUC.mjs.map +0 -7
  98. package/dist/lib/browser/chunk-U435IUIA.mjs +0 -1775
  99. package/dist/lib/browser/chunk-U435IUIA.mjs.map +0 -7
  100. package/dist/lib/browser/intent-resolver-MONKAKTY.mjs +0 -30
  101. package/dist/lib/browser/intent-resolver-MONKAKTY.mjs.map +0 -7
  102. package/dist/lib/browser/react-surface-7QWCWE4K.mjs +0 -58
  103. package/dist/lib/browser/react-surface-7QWCWE4K.mjs.map +0 -7
  104. package/dist/lib/browser/types/index.mjs +0 -24
  105. package/dist/lib/browser/types/index.mjs.map +0 -7
  106. package/dist/lib/node/AutomationPanel-6COLKRIB.cjs +0 -26
  107. package/dist/lib/node/AutomationPanel-6COLKRIB.cjs.map +0 -7
  108. package/dist/lib/node/ChatContainer-SBEUFMQ3.cjs +0 -33
  109. package/dist/lib/node/ChatContainer-SBEUFMQ3.cjs.map +0 -7
  110. package/dist/lib/node/ai-client-L5GUSAER.cjs +0 -38
  111. package/dist/lib/node/ai-client-L5GUSAER.cjs.map +0 -7
  112. package/dist/lib/node/app-graph-builder-OCSH5R6U.cjs +0 -123
  113. package/dist/lib/node/app-graph-builder-OCSH5R6U.cjs.map +0 -7
  114. package/dist/lib/node/chunk-BAQRBGOJ.cjs.map +0 -7
  115. package/dist/lib/node/chunk-BZFAEBME.cjs +0 -1747
  116. package/dist/lib/node/chunk-BZFAEBME.cjs.map +0 -7
  117. package/dist/lib/node/chunk-K3F5JNZ6.cjs +0 -394
  118. package/dist/lib/node/chunk-K3F5JNZ6.cjs.map +0 -7
  119. package/dist/lib/node/chunk-NUOYHYAF.cjs +0 -174
  120. package/dist/lib/node/chunk-NUOYHYAF.cjs.map +0 -7
  121. package/dist/lib/node/chunk-V4L7LTWM.cjs.map +0 -7
  122. package/dist/lib/node/chunk-VNBYGJ4K.cjs +0 -34
  123. package/dist/lib/node/chunk-VNBYGJ4K.cjs.map +0 -7
  124. package/dist/lib/node/intent-resolver-KQGTYVF2.cjs +0 -45
  125. package/dist/lib/node/intent-resolver-KQGTYVF2.cjs.map +0 -7
  126. package/dist/lib/node/react-surface-IXKIJFRP.cjs.map +0 -7
  127. package/dist/lib/node/types/index.cjs +0 -46
  128. package/dist/lib/node/types/index.cjs.map +0 -7
  129. package/dist/lib/node-esm/AutomationPanel-3MPIAO7R.mjs +0 -9
  130. package/dist/lib/node-esm/AutomationPanel-3MPIAO7R.mjs.map +0 -7
  131. package/dist/lib/node-esm/ChatContainer-JCDLYMDZ.mjs +0 -13
  132. package/dist/lib/node-esm/ChatContainer-JCDLYMDZ.mjs.map +0 -7
  133. package/dist/lib/node-esm/ai-client-45LZLW7V.mjs +0 -23
  134. package/dist/lib/node-esm/ai-client-45LZLW7V.mjs.map +0 -7
  135. package/dist/lib/node-esm/app-graph-builder-XSM7DETF.mjs +0 -112
  136. package/dist/lib/node-esm/app-graph-builder-XSM7DETF.mjs.map +0 -7
  137. package/dist/lib/node-esm/chunk-53FFD4VO.mjs +0 -1776
  138. package/dist/lib/node-esm/chunk-53FFD4VO.mjs.map +0 -7
  139. package/dist/lib/node-esm/chunk-AWAU4BHR.mjs +0 -244
  140. package/dist/lib/node-esm/chunk-AWAU4BHR.mjs.map +0 -7
  141. package/dist/lib/node-esm/chunk-IG4GSWZN.mjs.map +0 -7
  142. package/dist/lib/node-esm/chunk-K5NNSGIV.mjs +0 -152
  143. package/dist/lib/node-esm/chunk-K5NNSGIV.mjs.map +0 -7
  144. package/dist/lib/node-esm/chunk-RAT3GSJP.mjs +0 -383
  145. package/dist/lib/node-esm/chunk-RAT3GSJP.mjs.map +0 -7
  146. package/dist/lib/node-esm/chunk-SS7U6GCX.mjs +0 -16
  147. package/dist/lib/node-esm/chunk-SS7U6GCX.mjs.map +0 -7
  148. package/dist/lib/node-esm/intent-resolver-XSZRLU6V.mjs +0 -31
  149. package/dist/lib/node-esm/intent-resolver-XSZRLU6V.mjs.map +0 -7
  150. package/dist/lib/node-esm/react-surface-FZAAAXGR.mjs +0 -59
  151. package/dist/lib/node-esm/react-surface-FZAAAXGR.mjs.map +0 -7
  152. package/dist/lib/node-esm/types/index.mjs +0 -25
  153. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  154. package/dist/types/src/capabilities/ai-client.d.ts.map +0 -1
  155. package/dist/types/src/capabilities/app-graph-builder.d.ts +0 -181
  156. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +0 -1
  157. package/dist/types/src/capabilities/capabilities.d.ts +0 -5
  158. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  159. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  160. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  161. package/dist/types/src/components/AmbientDialog/AmbientDialog.d.ts +0 -7
  162. package/dist/types/src/components/AmbientDialog/AmbientDialog.d.ts.map +0 -1
  163. package/dist/types/src/components/AmbientDialog/AmbientDialog.stories.d.ts +0 -8
  164. package/dist/types/src/components/AmbientDialog/AmbientDialog.stories.d.ts.map +0 -1
  165. package/dist/types/src/components/AmbientDialog/index.d.ts +0 -2
  166. package/dist/types/src/components/AmbientDialog/index.d.ts.map +0 -1
  167. package/dist/types/src/components/AssistantDialog/AssistantDialog.d.ts +0 -6
  168. package/dist/types/src/components/AssistantDialog/AssistantDialog.d.ts.map +0 -1
  169. package/dist/types/src/components/AssistantDialog/index.d.ts +0 -2
  170. package/dist/types/src/components/AssistantDialog/index.d.ts.map +0 -1
  171. package/dist/types/src/components/ChatContainer/ChatContainer.d.ts +0 -6
  172. package/dist/types/src/components/ChatContainer/ChatContainer.d.ts.map +0 -1
  173. package/dist/types/src/components/ChatContainer/index.d.ts +0 -4
  174. package/dist/types/src/components/ChatContainer/index.d.ts.map +0 -1
  175. package/dist/types/src/components/Prompt/Prompt.d.ts +0 -13
  176. package/dist/types/src/components/Prompt/Prompt.d.ts.map +0 -1
  177. package/dist/types/src/components/Prompt/Prompt.stories.d.ts +0 -9
  178. package/dist/types/src/components/Prompt/Prompt.stories.d.ts.map +0 -1
  179. package/dist/types/src/components/Prompt/PromptBar.d.ts +0 -10
  180. package/dist/types/src/components/Prompt/PromptBar.d.ts.map +0 -1
  181. package/dist/types/src/components/Prompt/autocomplete.d.ts +0 -21
  182. package/dist/types/src/components/Prompt/autocomplete.d.ts.map +0 -1
  183. package/dist/types/src/components/Prompt/index.d.ts +0 -3
  184. package/dist/types/src/components/Prompt/index.d.ts.map +0 -1
  185. package/dist/types/src/components/PromptEditor/PromptEditor.d.ts +0 -9
  186. package/dist/types/src/components/PromptEditor/PromptEditor.d.ts.map +0 -1
  187. package/dist/types/src/components/PromptEditor/PromptEditor.stories.d.ts +0 -6
  188. package/dist/types/src/components/PromptEditor/PromptEditor.stories.d.ts.map +0 -1
  189. package/dist/types/src/components/PromptEditor/index.d.ts +0 -2
  190. package/dist/types/src/components/PromptEditor/index.d.ts.map +0 -1
  191. package/dist/types/src/components/PromptEditor/prompt-extension.d.ts +0 -4
  192. package/dist/types/src/components/PromptEditor/prompt-extension.d.ts.map +0 -1
  193. package/dist/types/src/components/PromptEditor/types.d.ts +0 -18
  194. package/dist/types/src/components/PromptEditor/types.d.ts.map +0 -1
  195. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.d.ts +0 -5
  196. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.d.ts.map +0 -1
  197. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.stories.d.ts +0 -8
  198. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.stories.d.ts.map +0 -1
  199. package/dist/types/src/components/ServiceRegistry/index.d.ts +0 -2
  200. package/dist/types/src/components/ServiceRegistry/index.d.ts.map +0 -1
  201. package/dist/types/src/components/Thread/Thread.d.ts +0 -15
  202. package/dist/types/src/components/Thread/Thread.d.ts.map +0 -1
  203. package/dist/types/src/components/Thread/Thread.stories.d.ts +0 -11
  204. package/dist/types/src/components/Thread/Thread.stories.d.ts.map +0 -1
  205. package/dist/types/src/components/Thread/ThreadContainer.d.ts +0 -8
  206. package/dist/types/src/components/Thread/ThreadContainer.d.ts.map +0 -1
  207. package/dist/types/src/components/Thread/ThreadContainer.stories.d.ts +0 -15
  208. package/dist/types/src/components/Thread/ThreadContainer.stories.d.ts.map +0 -1
  209. package/dist/types/src/components/Thread/ThreadMessage.d.ts +0 -13
  210. package/dist/types/src/components/Thread/ThreadMessage.d.ts.map +0 -1
  211. package/dist/types/src/components/Thread/ToolInvocations.d.ts +0 -13
  212. package/dist/types/src/components/Thread/ToolInvocations.d.ts.map +0 -1
  213. package/dist/types/src/components/Thread/index.d.ts +0 -3
  214. package/dist/types/src/components/Thread/index.d.ts.map +0 -1
  215. package/dist/types/src/components/Thread/reducer.d.ts +0 -12
  216. package/dist/types/src/components/Thread/reducer.d.ts.map +0 -1
  217. package/dist/types/src/components/Toolbox/Toolbox.d.ts +0 -19
  218. package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +0 -1
  219. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +0 -8
  220. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +0 -1
  221. package/dist/types/src/components/Toolbox/index.d.ts +0 -2
  222. package/dist/types/src/components/Toolbox/index.d.ts.map +0 -1
  223. package/dist/types/src/hooks/email.d.ts +0 -4
  224. package/dist/types/src/hooks/email.d.ts.map +0 -1
  225. package/dist/types/src/hooks/index.d.ts +0 -7
  226. package/dist/types/src/hooks/index.d.ts.map +0 -1
  227. package/dist/types/src/hooks/invocation-handler.d.ts +0 -5
  228. package/dist/types/src/hooks/invocation-handler.d.ts.map +0 -1
  229. package/dist/types/src/hooks/processor.d.ts +0 -75
  230. package/dist/types/src/hooks/processor.d.ts.map +0 -1
  231. package/dist/types/src/hooks/processor.test.d.ts +0 -2
  232. package/dist/types/src/hooks/processor.test.d.ts.map +0 -1
  233. package/dist/types/src/hooks/useChatProcessor.d.ts +0 -7
  234. package/dist/types/src/hooks/useChatProcessor.d.ts.map +0 -1
  235. package/dist/types/src/hooks/useLocalTriggerManager.d.ts +0 -3
  236. package/dist/types/src/hooks/useLocalTriggerManager.d.ts.map +0 -1
  237. package/dist/types/src/hooks/useMessageQueue.d.ts +0 -41
  238. package/dist/types/src/hooks/useMessageQueue.d.ts.map +0 -1
  239. package/dist/types/src/hooks/useServices.d.ts +0 -7
  240. package/dist/types/src/hooks/useServices.d.ts.map +0 -1
  241. package/dist/types/src/hooks/useTextInputEvents.d.ts +0 -13
  242. package/dist/types/src/hooks/useTextInputEvents.d.ts.map +0 -1
  243. package/dist/types/src/presets.d.ts +0 -9
  244. package/dist/types/src/presets.d.ts.map +0 -1
  245. package/dist/types/src/testing/test-services.d.ts +0 -5
  246. package/dist/types/src/testing/test-services.d.ts.map +0 -1
  247. package/dist/types/src/tools/function.d.ts +0 -5
  248. package/dist/types/src/tools/function.d.ts.map +0 -1
  249. package/dist/types/src/tools/index.d.ts +0 -3
  250. package/dist/types/src/tools/index.d.ts.map +0 -1
  251. package/dist/types/src/tools/openapi.d.ts +0 -10
  252. package/dist/types/src/tools/openapi.d.ts.map +0 -1
  253. package/dist/types/src/tools/openapi.test.d.ts +0 -2
  254. package/dist/types/src/tools/openapi.test.d.ts.map +0 -1
  255. package/dist/types/src/types/index.d.ts +0 -4
  256. package/dist/types/src/types/index.d.ts.map +0 -1
  257. package/dist/types/src/types/registry.d.ts +0 -10
  258. package/dist/types/src/types/registry.d.ts.map +0 -1
  259. package/dist/types/src/types/schema.d.ts +0 -221
  260. package/dist/types/src/types/schema.d.ts.map +0 -1
  261. package/dist/types/src/types/types.d.ts +0 -19
  262. package/dist/types/src/types/types.d.ts.map +0 -1
  263. package/src/capabilities/ai-client.ts +0 -19
  264. package/src/capabilities/app-graph-builder.ts +0 -100
  265. package/src/capabilities/capabilities.ts +0 -12
  266. package/src/capabilities/intent-resolver.ts +0 -26
  267. package/src/components/AmbientDialog/AmbientDialog.stories.tsx +0 -81
  268. package/src/components/AmbientDialog/AmbientDialog.tsx +0 -103
  269. package/src/components/AmbientDialog/index.ts +0 -5
  270. package/src/components/AssistantDialog/AssistantDialog.tsx +0 -23
  271. package/src/components/AssistantDialog/index.ts +0 -5
  272. package/src/components/ChatContainer/ChatContainer.tsx +0 -19
  273. package/src/components/ChatContainer/index.ts +0 -9
  274. package/src/components/Prompt/Prompt.stories.tsx +0 -79
  275. package/src/components/Prompt/Prompt.tsx +0 -79
  276. package/src/components/Prompt/PromptBar.tsx +0 -100
  277. package/src/components/Prompt/autocomplete.ts +0 -212
  278. package/src/components/Prompt/index.ts +0 -6
  279. package/src/components/PromptEditor/PromptEditor.stories.tsx +0 -64
  280. package/src/components/PromptEditor/PromptEditor.tsx +0 -222
  281. package/src/components/PromptEditor/index.ts +0 -5
  282. package/src/components/PromptEditor/prompt-extension.ts +0 -43
  283. package/src/components/PromptEditor/types.tsx +0 -28
  284. package/src/components/ServiceRegistry/ServiceRegistry.stories.tsx +0 -49
  285. package/src/components/ServiceRegistry/ServiceRegistry.tsx +0 -76
  286. package/src/components/ServiceRegistry/index.ts +0 -5
  287. package/src/components/Thread/Thread.stories.tsx +0 -210
  288. package/src/components/Thread/Thread.tsx +0 -106
  289. package/src/components/Thread/ThreadContainer.stories.tsx +0 -245
  290. package/src/components/Thread/ThreadContainer.tsx +0 -67
  291. package/src/components/Thread/ThreadMessage.tsx +0 -187
  292. package/src/components/Thread/ToolInvocations.tsx +0 -86
  293. package/src/components/Thread/index.ts +0 -6
  294. package/src/components/Thread/reducer.ts +0 -52
  295. package/src/components/Toolbox/Toolbox.stories.tsx +0 -66
  296. package/src/components/Toolbox/Toolbox.tsx +0 -89
  297. package/src/components/Toolbox/index.ts +0 -5
  298. package/src/hooks/email.ts +0 -49
  299. package/src/hooks/index.ts +0 -11
  300. package/src/hooks/invocation-handler.ts +0 -109
  301. package/src/hooks/processor.test.ts +0 -15
  302. package/src/hooks/processor.ts +0 -218
  303. package/src/hooks/useChatProcessor.tsx +0 -75
  304. package/src/hooks/useLocalTriggerManager.ts +0 -82
  305. package/src/hooks/useMessageQueue.ts +0 -23
  306. package/src/hooks/useServices.ts +0 -28
  307. package/src/hooks/useTextInputEvents.ts +0 -49
  308. package/src/presets.ts +0 -248
  309. package/src/testing/test-services.ts +0 -131
  310. package/src/tools/function.ts +0 -47
  311. package/src/tools/index.ts +0 -6
  312. package/src/tools/openapi.test.ts +0 -224
  313. package/src/tools/openapi.ts +0 -331
  314. package/src/types/index.ts +0 -7
  315. package/src/types/registry.ts +0 -26
  316. package/src/types/schema.ts +0 -132
  317. package/src/types/types.ts +0 -22
  318. package/src/typings.d.ts +0 -9
@@ -1,106 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { type CSSProperties, useCallback, useMemo, useRef } from 'react';
6
-
7
- import { useCapabilities } from '@dxos/app-framework';
8
- import { type Message } from '@dxos/artifact';
9
- import { TranscriptionCapabilities } from '@dxos/plugin-transcription';
10
- import { type Space } from '@dxos/react-client/echo';
11
- import { useIdentity } from '@dxos/react-client/halo';
12
- import { type ThemedClassName } from '@dxos/react-ui';
13
- import { ScrollContainer, type ScrollController } from '@dxos/react-ui-components';
14
- import { mx } from '@dxos/react-ui-theme';
15
- import { keyToFallback } from '@dxos/util';
16
-
17
- import { ThreadMessage, type ThreadMessageProps } from './ThreadMessage';
18
- import { messageReducer } from './reducer';
19
- import { PromptBar, type PromptBarProps } from '../Prompt';
20
-
21
- export type ThreadProps = ThemedClassName<{
22
- space?: Space;
23
- messages?: Message[];
24
- collapse?: boolean;
25
- }> &
26
- Pick<PromptBarProps, 'processing' | 'error' | 'onSubmit' | 'onSuggest' | 'onCancel'> &
27
- Pick<ThreadMessageProps, 'debug' | 'onPrompt' | 'onDelete'>;
28
-
29
- /**
30
- * Chat thread component.
31
- */
32
- export const Thread = ({
33
- classNames,
34
- space,
35
- messages,
36
- collapse = true,
37
- processing,
38
- error,
39
- debug,
40
- onSubmit,
41
- onCancel,
42
- onPrompt,
43
- onDelete,
44
- }: ThreadProps) => {
45
- const hasTrascription = useCapabilities(TranscriptionCapabilities.Transcription).length > 0;
46
-
47
- const scroller = useRef<ScrollController>(null);
48
-
49
- const identity = useIdentity();
50
- const fallbackValue = keyToFallback(identity!.identityKey);
51
- const userHue = identity!.profile?.data?.hue || fallbackValue.hue;
52
-
53
- const handleSubmit = useCallback<NonNullable<PromptBarProps['onSubmit']>>(
54
- (value: string) => {
55
- onSubmit?.(value);
56
- scroller.current?.scrollToBottom();
57
- return true;
58
- },
59
- [onSubmit],
60
- );
61
-
62
- // TODO(dmaretskyi): This needs to be a separate type: `id` is not a valid ObjectId, this needs to accommodate messageId for deletion.
63
- const { messages: filteredMessages = [] } = useMemo(() => {
64
- if (collapse) {
65
- return (messages ?? []).reduce<{ messages: Message[]; current?: Message }>(messageReducer, {
66
- messages: [],
67
- });
68
- } else {
69
- return { messages: messages ?? [] };
70
- }
71
- }, [messages, collapse]);
72
-
73
- return (
74
- <>
75
- <ScrollContainer ref={scroller} fade>
76
- <div
77
- role='none'
78
- className={mx(filteredMessages.length > 0 && 'pbs-6 pbe-6', classNames)}
79
- style={{ '--user-fill': `var(--dx-${userHue}Fill)` } as CSSProperties}
80
- >
81
- {filteredMessages.map((message) => (
82
- <ThreadMessage
83
- key={message.id}
84
- classNames='px-4 pbe-4'
85
- space={space}
86
- message={message}
87
- debug={debug}
88
- onPrompt={onPrompt}
89
- onDelete={onDelete}
90
- />
91
- ))}
92
- </div>
93
- </ScrollContainer>
94
-
95
- {onSubmit && (
96
- <PromptBar
97
- microphone={hasTrascription}
98
- processing={processing}
99
- error={error}
100
- onSubmit={handleSubmit}
101
- onCancel={onCancel}
102
- />
103
- )}
104
- </>
105
- );
106
- };
@@ -1,245 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import '@dxos-theme';
6
-
7
- import { type StoryObj, type Meta } from '@storybook/react';
8
- import React, { useCallback, useEffect, useMemo, useState } from 'react';
9
-
10
- import { Capabilities, IntentPlugin, Surface, useCapabilities, useIntentDispatcher } from '@dxos/app-framework';
11
- import { withPluginManager } from '@dxos/app-framework/testing';
12
- import { Message, type Tool } from '@dxos/artifact';
13
- import { capabilities, genericTools, localServiceEndpoints, type IsObject } from '@dxos/artifact-testing';
14
- import { AIServiceClientImpl } from '@dxos/assistant';
15
- import { createStatic, ObjectId } from '@dxos/echo-schema';
16
- import { EdgeHttpClient } from '@dxos/edge-client';
17
- import { invariant } from '@dxos/invariant';
18
- import { DXN, QueueSubspaceTags, SpaceId } from '@dxos/keys';
19
- import { ChessPlugin } from '@dxos/plugin-chess';
20
- import { ChessType } from '@dxos/plugin-chess/types';
21
- import { ClientPlugin } from '@dxos/plugin-client';
22
- import { MapPlugin } from '@dxos/plugin-map';
23
- import { SpacePlugin } from '@dxos/plugin-space';
24
- import { TablePlugin } from '@dxos/plugin-table';
25
- import { useSpace } from '@dxos/react-client/echo';
26
- import { useQueue } from '@dxos/react-edge-client';
27
- import { IconButton, Input, Toolbar } from '@dxos/react-ui';
28
- import { mx } from '@dxos/react-ui-theme';
29
- import { withLayout, withSignals, withTheme } from '@dxos/storybook-utils';
30
-
31
- import { Thread, type ThreadProps } from './Thread';
32
- import { ChatProcessor } from '../../hooks';
33
- import { createProcessorOptions } from '../../testing';
34
- import translations from '../../translations';
35
-
36
- const endpoints = localServiceEndpoints;
37
-
38
- type RenderProps = {
39
- items?: IsObject[];
40
- prompts?: string[];
41
- } & Pick<ThreadProps, 'debug'>;
42
-
43
- // TODO(burdon): Use ChatContainer.
44
- const Render = ({ items: _items, prompts = [], ...props }: RenderProps) => {
45
- const space = useSpace();
46
- const artifactDefinitions = useCapabilities(Capabilities.ArtifactDefinition);
47
- const tools = useMemo<Tool[]>(
48
- () => [...genericTools, ...artifactDefinitions.flatMap((definition) => definition.tools)],
49
- [genericTools, artifactDefinitions],
50
- );
51
-
52
- const [aiClient] = useState(() => new AIServiceClientImpl({ endpoint: endpoints.ai }));
53
- const [edgeClient] = useState(() => new EdgeHttpClient(endpoints.edge));
54
- const { dispatchPromise: dispatch } = useIntentDispatcher();
55
- const processor = useMemo<ChatProcessor | undefined>(() => {
56
- if (!space) {
57
- return;
58
- }
59
-
60
- return new ChatProcessor(
61
- aiClient,
62
- tools,
63
- {
64
- space,
65
- dispatch,
66
- },
67
- createProcessorOptions(artifactDefinitions.map((definition) => definition.instructions)),
68
- );
69
- }, [aiClient, tools, space, dispatch, artifactDefinitions]);
70
-
71
- // Queue.
72
- const [queueDxn, setQueueDxn] = useState(() => randomQueueDxn());
73
- const queue = useQueue<Message>(edgeClient, DXN.tryParse(queueDxn));
74
-
75
- useEffect(() => {
76
- if (queue?.items.length === 0 && !queue.isLoading && prompts.length > 0) {
77
- queue.append([
78
- createStatic(Message, {
79
- role: 'assistant',
80
- content: prompts.map(
81
- (prompt) =>
82
- ({
83
- type: 'json',
84
- disposition: 'suggest',
85
- json: JSON.stringify({ text: prompt }),
86
- }) as const,
87
- ),
88
- }),
89
- ]);
90
- }
91
- }, [queueDxn, prompts, queue?.items.length, queue?.isLoading]);
92
-
93
- // State.
94
- const artifactItems: any[] = []; // TODO(burdon): Query from space.
95
- const messages = [...(queue?.items ?? []), ...(processor?.messages.value ?? [])];
96
-
97
- const handleSubmit = processor
98
- ? (message: string) => {
99
- requestAnimationFrame(async () => {
100
- invariant(processor);
101
- if (processor.streaming.value) {
102
- await processor.cancel();
103
- }
104
-
105
- invariant(queue);
106
- await processor.request(message, {
107
- history: queue.items,
108
- onComplete: (messages) => {
109
- queue.append(messages);
110
- },
111
- });
112
- });
113
-
114
- return true;
115
- }
116
- : undefined;
117
-
118
- const handlePrompt = useCallback(
119
- (text: string) => {
120
- void handleSubmit?.(text);
121
- },
122
- [handleSubmit],
123
- );
124
-
125
- const handleDelete = useCallback(
126
- (id: string) => {
127
- invariant(ObjectId.isValid(id), 'Invalid message id');
128
- void queue?.delete([id]);
129
- },
130
- [queue],
131
- );
132
-
133
- return (
134
- <div className='grid grid-cols-2 w-full h-full divide-x divide-separator overflow-hidden'>
135
- {/* Thread */}
136
- <div className='flex flex-col gap-4 overflow-hidden'>
137
- <Toolbar.Root classNames='p-2'>
138
- <Input.Root>
139
- <Input.TextInput
140
- spellCheck={false}
141
- placeholder='Queue DXN'
142
- value={queueDxn}
143
- onChange={(ev) => setQueueDxn(ev.target.value)}
144
- />
145
- <IconButton
146
- iconOnly
147
- label='Copy DXN'
148
- icon='ph--copy--regular'
149
- onClick={() => navigator.clipboard.writeText(queueDxn)}
150
- />
151
- <IconButton
152
- iconOnly
153
- label='Clear history'
154
- icon='ph--trash--regular'
155
- onClick={() => setQueueDxn(randomQueueDxn())}
156
- />
157
- <IconButton iconOnly label='Stop' icon='ph--stop--regular' onClick={() => processor?.cancel()} />
158
- </Input.Root>
159
- </Toolbar.Root>
160
-
161
- {/* TODO(burdon): Replace with ThreadContainer. */}
162
- <Thread
163
- messages={messages}
164
- processing={processor?.streaming.value}
165
- onSubmit={processor ? handleSubmit : undefined}
166
- onPrompt={processor ? handlePrompt : undefined}
167
- onDelete={processor ? handleDelete : undefined}
168
- {...props}
169
- />
170
- </div>
171
-
172
- {/* Artifacts Deck/Mosaic */}
173
- <div className='overflow-hidden grid grid-rows-[2fr_1fr] divide-y divide-separator'>
174
- {artifactItems.length > 0 && (
175
- <div className={mx('flex grow overflow-hidden', artifactItems.length === 1 && 'row-span-2')}>
176
- <Surface role='canvas-node' limit={1} data={artifactItems[0]} />
177
- </div>
178
- )}
179
-
180
- {artifactItems.length > 1 && (
181
- <div className='flex shrink-0 overflow-hidden divide-x divide-separator'>
182
- <div className='flex flex-1 h-full'>
183
- {artifactItems.slice(1, 3).map((item, idx) => (
184
- <Surface key={idx} role='canvas-node' limit={1} data={item} />
185
- ))}
186
- </div>
187
- </div>
188
- )}
189
- </div>
190
- </div>
191
- );
192
- };
193
-
194
- const randomQueueDxn = () =>
195
- new DXN(DXN.kind.QUEUE, [QueueSubspaceTags.DATA, SpaceId.random(), ObjectId.random()]).toString();
196
-
197
- const meta: Meta<typeof Render> = {
198
- title: 'plugins/plugin-automation/ThreadContainer',
199
- render: Render,
200
- decorators: [
201
- withSignals,
202
- withPluginManager({
203
- plugins: [
204
- ClientPlugin({
205
- onClientInitialized: async (_, client) => {
206
- await client.halo.createIdentity();
207
- },
208
- }),
209
- SpacePlugin({ observability: false }),
210
- IntentPlugin(),
211
- ChessPlugin(),
212
- MapPlugin(),
213
- TablePlugin(),
214
- ],
215
- capabilities,
216
- }),
217
- withTheme,
218
- withLayout({ fullscreen: true, tooltips: true }),
219
- ],
220
- parameters: {
221
- translations,
222
- },
223
- };
224
-
225
- export default meta;
226
-
227
- type Story = StoryObj<typeof Render>;
228
-
229
- export const Default: Story = {
230
- args: {
231
- debug: true,
232
- prompts: ['Ask me a question', 'Show me a chess puzzle'],
233
- },
234
- };
235
-
236
- export const WithInitialItems: Story = {
237
- args: {
238
- debug: true,
239
- items: [
240
- createStatic(ChessType, {
241
- fen: 'rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w KQkq - 0 1',
242
- }),
243
- ],
244
- },
245
- };
@@ -1,67 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { type FC, useCallback } from 'react';
6
-
7
- import { invariant } from '@dxos/invariant';
8
- import { log } from '@dxos/log';
9
- import { getSpace } from '@dxos/react-client/echo';
10
- import { type ThemedClassName } from '@dxos/react-ui';
11
-
12
- import { Thread } from './Thread';
13
- import { useChatProcessor, useMessageQueue } from '../../hooks';
14
- import { type AIChatType } from '../../types';
15
-
16
- // TODO(burdon): Since this only wraps Thread, just separate out hook?
17
- export const ThreadContainer: FC<ThemedClassName<{ chat?: AIChatType; onOpenChange?: (open: boolean) => void }>> = ({
18
- classNames,
19
- chat,
20
- onOpenChange,
21
- }) => {
22
- const space = getSpace(chat);
23
- const processor = useChatProcessor(space);
24
- const messageQueue = useMessageQueue(chat);
25
- const messages = [...(messageQueue?.items ?? []), ...processor.messages.value];
26
-
27
- const handleSubmit = useCallback(
28
- (text: string) => {
29
- // Don't accept input if still processing.
30
- if (processor.streaming.value) {
31
- log.warn('still processing');
32
- return false;
33
- }
34
-
35
- onOpenChange?.(true);
36
-
37
- invariant(messageQueue);
38
- void processor.request(text, {
39
- history: messageQueue.items,
40
- onComplete: (messages) => {
41
- messageQueue.append(messages);
42
- },
43
- });
44
-
45
- return true;
46
- },
47
- [processor, messageQueue, onOpenChange],
48
- );
49
-
50
- const handleCancel = useCallback(() => {
51
- if (processor.streaming.value) {
52
- void processor.cancel();
53
- }
54
- }, [processor]);
55
-
56
- return (
57
- <Thread
58
- classNames={classNames}
59
- space={space}
60
- messages={messages}
61
- processing={processor.streaming.value}
62
- error={processor.error.value}
63
- onSubmit={handleSubmit}
64
- onCancel={handleCancel}
65
- />
66
- );
67
- };
@@ -1,187 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { type PropsWithChildren, type FC } from 'react';
6
-
7
- import { type MessageContentBlock, type Message } from '@dxos/artifact';
8
- import { invariant } from '@dxos/invariant';
9
- import { type Space } from '@dxos/react-client/echo';
10
- import { Button, ButtonGroup, Icon, IconButton, type ThemedClassName } from '@dxos/react-ui';
11
- import {
12
- MarkdownViewer,
13
- ToggleContainer as NativeToggleContainer,
14
- type ToggleContainerProps,
15
- } from '@dxos/react-ui-components';
16
- import { Json } from '@dxos/react-ui-syntax-highlighter';
17
- import { mx } from '@dxos/react-ui-theme';
18
- import { safeParseJson } from '@dxos/util';
19
-
20
- import { ToolBlock, isToolMessage } from './ToolInvocations';
21
- import { ToolboxContainer } from '../Toolbox';
22
-
23
- const userClassNames = 'bg-[--user-fill]';
24
- const panelClassNames = 'flex flex-col w-full bg-groupSurface rounded-md';
25
-
26
- const ToggleContainer = (props: ToggleContainerProps) => {
27
- return <NativeToggleContainer {...props} classNames={mx(panelClassNames, props.classNames)} />;
28
- };
29
-
30
- const MessageContainer = ({ children, classNames, user }: ThemedClassName<PropsWithChildren<{ user?: boolean }>>) => {
31
- return (
32
- <div role='list-item' className={mx('flex w-full', user && 'justify-end', classNames)}>
33
- <div className={mx(user ? ['px-2 py-1 rounded-md', userClassNames] : 'w-full')}>{children}</div>
34
- </div>
35
- );
36
- };
37
-
38
- export type ThreadMessageProps = ThemedClassName<{
39
- space?: Space;
40
- message: Message;
41
- debug?: boolean;
42
- onPrompt?: (text: string) => void;
43
- onDelete?: (id: string) => void;
44
- }>;
45
-
46
- export const ThreadMessage: FC<ThreadMessageProps> = ({ classNames, space, message, onPrompt }) => {
47
- const { role, content = [] } = message;
48
-
49
- // TODO(burdon): Restructure types to make check unnecessary.
50
- if (isToolMessage(message)) {
51
- return (
52
- <MessageContainer classNames={classNames}>
53
- <ToolBlock space={space} classNames={panelClassNames} message={message} />
54
- </MessageContainer>
55
- );
56
- }
57
-
58
- return (
59
- <div role='none' className='flex flex-col gap-2'>
60
- {content.map((block, idx) => (
61
- <MessageContainer key={idx} classNames={classNames} user={block.type === 'text' && role === 'user'}>
62
- <Block space={space} block={block} onPrompt={onPrompt} />
63
- </MessageContainer>
64
- ))}
65
- </div>
66
- );
67
- };
68
-
69
- const Block: FC<{ space?: Space; block: MessageContentBlock; onPrompt?: (text: string) => void }> = ({
70
- space,
71
- block,
72
- onPrompt,
73
- }) => {
74
- const Component = components[block.type] ?? components.default;
75
- return <Component space={space} block={block} onPrompt={onPrompt} />;
76
- };
77
-
78
- type BlockComponent = FC<{ space?: Space; block: MessageContentBlock; onPrompt?: (text: string) => void }>;
79
-
80
- const components: Record<string, BlockComponent> = {
81
- //
82
- // Text
83
- //
84
- ['text' as const]: ({ block }) => {
85
- invariant(block.type === 'text');
86
- // const [open, setOpen] = useState(block.disposition === 'cot' && block.pending);
87
- const title = block.disposition ? titles[block.disposition] : undefined;
88
- if (!title) {
89
- return <MarkdownViewer content={block.text} />;
90
- }
91
-
92
- // TOOD(burdon): Store last time user opened/closed COT.
93
- // Autoclose when streaming ends.
94
- // useEffect(() => {
95
- // if (block.disposition === 'cot' && !block.pending) {
96
- // setOpen(false);
97
- // }
98
- // }, [block.disposition, block.pending]);
99
-
100
- return (
101
- <ToggleContainer
102
- // open={open}
103
- defaultOpen={block.disposition === 'cot' && block.pending}
104
- title={title}
105
- icon={
106
- block.pending ? (
107
- <Icon icon={'ph--circle-notch--regular'} classNames='text-subdued ml-2 animate-spin' size={4} />
108
- ) : undefined
109
- }
110
- >
111
- <MarkdownViewer
112
- content={block.text}
113
- classNames={['pbe-2', block.disposition === 'cot' && 'text-sm text-subdued']}
114
- />
115
- </ToggleContainer>
116
- );
117
- },
118
-
119
- //
120
- // JSON
121
- //
122
- ['json' as const]: ({ space, block, onPrompt }) => {
123
- invariant(block.type === 'json');
124
-
125
- switch (block.disposition) {
126
- case 'tool_list': {
127
- return (
128
- <ToggleContainer title={titles[block.disposition]} defaultOpen={true}>
129
- <ToolboxContainer space={space} />
130
- </ToggleContainer>
131
- );
132
- }
133
-
134
- case 'suggest': {
135
- const { text = '' }: { text: string } = safeParseJson(block.json ?? '{}') ?? ({} as any);
136
- return <IconButton icon='ph--lightning--regular' label={text} onClick={() => onPrompt?.(text)} />;
137
- }
138
-
139
- case 'select': {
140
- const { options = [] }: { options: string[] } = safeParseJson(block.json ?? '{}') ?? ({} as any);
141
- return (
142
- <ButtonGroup>
143
- {options.map((option) => (
144
- <Button key={option} onClick={() => onPrompt?.(option)}>
145
- {option}
146
- </Button>
147
- ))}
148
- </ButtonGroup>
149
- );
150
- }
151
-
152
- default: {
153
- const title = block.disposition ? titles[block.disposition] : undefined;
154
- return (
155
- <ToggleContainer title={title ?? 'JSON'}>
156
- <Json data={safeParseJson(block.json ?? block)} classNames='!p-1 text-xs' />
157
- </ToggleContainer>
158
- );
159
- }
160
- }
161
- },
162
-
163
- //
164
- // Default
165
- //
166
- default: ({ block }) => {
167
- let title = titles[block.type];
168
- if (block.type === 'tool_use') {
169
- title = `Tool [${block.name}]`; // TODO(burdon): Get label from tool.
170
- }
171
-
172
- return (
173
- <ToggleContainer title={title ?? 'JSON'}>
174
- <Json data={block} classNames='!p-1 text-xs' />
175
- </ToggleContainer>
176
- );
177
- },
178
- };
179
-
180
- // TODO(burdon): Translations.
181
- const titles: Record<string, string> = {
182
- ['cot' as const]: 'Chain of thought',
183
- ['artifact' as const]: 'Artifact',
184
- ['tool_use' as const]: 'Tool request',
185
- ['tool_result' as const]: 'Tool result',
186
- ['tool_list' as const]: 'Tools',
187
- };
@@ -1,86 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { type FC, useEffect, useRef, useState } from 'react';
6
-
7
- import { type Message, type MessageContentBlock } from '@dxos/artifact';
8
- import { log } from '@dxos/log';
9
- import { type ThemedClassName } from '@dxos/react-ui';
10
- import { NumericTabs, StatusRoll, ToggleContainer } from '@dxos/react-ui-components';
11
- import { Json } from '@dxos/react-ui-syntax-highlighter';
12
-
13
- import { type ThreadMessageProps } from './ThreadMessage';
14
-
15
- export const isToolMessage = (message: Message) => {
16
- return message.content.some((block) => block.type === 'tool_use' || block.type === 'tool_result');
17
- };
18
-
19
- export const ToolBlock: FC<ThemedClassName<ThreadMessageProps>> = ({ classNames, message }) => {
20
- const { content = [] } = message;
21
-
22
- let request: (MessageContentBlock & { type: 'tool_use' }) | undefined;
23
- const blocks = content.filter((block) => block.type === 'tool_use' || block.type === 'tool_result');
24
- const items = blocks.map((block) => {
25
- switch (block.type) {
26
- case 'tool_use': {
27
- request = block;
28
- // TODO(burdon): Get plugin name.
29
- return { title: `Calling ${block.name}...`, block };
30
- }
31
-
32
- case 'tool_result': {
33
- if (!request) {
34
- log.warn('unexpected message', { block });
35
- return { title: 'Error', block };
36
- }
37
-
38
- return { title: `Processed ${request.name}`, block };
39
- }
40
-
41
- default: {
42
- request = undefined;
43
- return { title: 'Error', block };
44
- }
45
- }
46
- });
47
-
48
- return <ToolContainer classNames={classNames} items={items} />;
49
- };
50
-
51
- export const ToolContainer: FC<ThemedClassName<{ items: { title: string; block: any }[] }>> = ({
52
- classNames,
53
- items,
54
- }) => {
55
- const lines = items.map((item) => item.title);
56
- const tabsRef = useRef<HTMLDivElement>(null);
57
- const [selected, setSelected] = useState(0);
58
- const [open, setOpen] = useState(false);
59
- useEffect(() => {
60
- if (open) {
61
- tabsRef.current?.focus();
62
- }
63
- }, [open]);
64
-
65
- const handleSelect = (index: number) => {
66
- if (index === selected) {
67
- setOpen(false);
68
- } else {
69
- setSelected(index);
70
- }
71
- };
72
-
73
- return (
74
- <ToggleContainer
75
- classNames={['flex flex-col', classNames]}
76
- title={<StatusRoll lines={lines} autoAdvance />}
77
- open={open}
78
- onChangeOpen={setOpen}
79
- >
80
- <div className='grid grid-cols-[32px_1fr]'>
81
- <NumericTabs ref={tabsRef} length={items.length} selected={selected} onSelect={handleSelect} />
82
- <Json data={items[selected].block} classNames='!p-1 text-xs' />
83
- </div>
84
- </ToggleContainer>
85
- );
86
- };
@@ -1,6 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- export * from './Thread';
6
- export * from './ThreadContainer';