@dxos/plugin-automation 0.7.5-main.9d26e3a → 0.7.5-main.b19bfc8

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 (364) hide show
  1. package/dist/lib/browser/AssistantDialog-V67OWLRP.mjs +116 -0
  2. package/dist/lib/browser/AssistantDialog-V67OWLRP.mjs.map +7 -0
  3. package/dist/lib/browser/AutomationPanel-NCKK3CFN.mjs +8 -0
  4. package/dist/lib/browser/ChatContainer-5BS6THNV.mjs +33 -0
  5. package/dist/lib/browser/ChatContainer-5BS6THNV.mjs.map +7 -0
  6. package/dist/lib/browser/TemplateContainer-HJJV44CE.mjs +23 -0
  7. package/dist/lib/browser/TemplateContainer-HJJV44CE.mjs.map +7 -0
  8. package/dist/lib/browser/ai-client-T2PBJISL.mjs +22 -0
  9. package/dist/lib/browser/ai-client-T2PBJISL.mjs.map +7 -0
  10. package/dist/lib/browser/app-graph-builder-IR3CGVM6.mjs +110 -0
  11. package/dist/lib/browser/app-graph-builder-IR3CGVM6.mjs.map +7 -0
  12. package/dist/lib/browser/chunk-62E2AEXF.mjs +162 -0
  13. package/dist/lib/browser/chunk-62E2AEXF.mjs.map +7 -0
  14. package/dist/lib/browser/chunk-67KDIIM6.mjs +15 -0
  15. package/dist/lib/browser/chunk-67KDIIM6.mjs.map +7 -0
  16. package/dist/lib/browser/chunk-BQ4WHY4D.mjs +1818 -0
  17. package/dist/lib/browser/chunk-BQ4WHY4D.mjs.map +7 -0
  18. package/dist/lib/browser/{chunk-X5KMOH3I.mjs → chunk-HZSTXZWK.mjs} +6 -4
  19. package/dist/lib/browser/chunk-HZSTXZWK.mjs.map +7 -0
  20. package/dist/lib/browser/chunk-LJ7F4KDM.mjs +243 -0
  21. package/dist/lib/browser/chunk-LJ7F4KDM.mjs.map +7 -0
  22. package/dist/lib/browser/chunk-QH5E22EL.mjs +108 -0
  23. package/dist/lib/browser/chunk-QH5E22EL.mjs.map +7 -0
  24. package/dist/lib/browser/chunk-XAIWETH6.mjs +81 -0
  25. package/dist/lib/browser/chunk-XAIWETH6.mjs.map +7 -0
  26. package/dist/lib/browser/index.mjs +210 -467
  27. package/dist/lib/browser/index.mjs.map +4 -4
  28. package/dist/lib/browser/intent-resolver-ICLE6FSI.mjs +44 -0
  29. package/dist/lib/browser/intent-resolver-ICLE6FSI.mjs.map +7 -0
  30. package/dist/lib/browser/meta.json +1 -1
  31. package/dist/lib/browser/react-surface-KEKVLCPQ.mjs +80 -0
  32. package/dist/lib/browser/react-surface-KEKVLCPQ.mjs.map +7 -0
  33. package/dist/lib/browser/settings-FE5DDWOE.mjs +22 -0
  34. package/dist/lib/browser/settings-FE5DDWOE.mjs.map +7 -0
  35. package/dist/lib/browser/types/index.mjs +18 -9
  36. package/dist/lib/node/AssistantDialog-E62O72KI.cjs +140 -0
  37. package/dist/lib/node/AssistantDialog-E62O72KI.cjs.map +7 -0
  38. package/dist/lib/node/{meta.cjs → AutomationPanel-6COLKRIB.cjs} +7 -11
  39. package/dist/lib/node/AutomationPanel-6COLKRIB.cjs.map +7 -0
  40. package/dist/lib/node/ChatContainer-4QTLL7TH.cjs +61 -0
  41. package/dist/lib/node/ChatContainer-4QTLL7TH.cjs.map +7 -0
  42. package/dist/lib/node/TemplateContainer-3YCM6XPU.cjs +53 -0
  43. package/dist/lib/node/TemplateContainer-3YCM6XPU.cjs.map +7 -0
  44. package/dist/lib/node/ai-client-L5GUSAER.cjs +38 -0
  45. package/dist/lib/node/ai-client-L5GUSAER.cjs.map +7 -0
  46. package/dist/lib/node/app-graph-builder-ECNVGTRT.cjs +122 -0
  47. package/dist/lib/node/app-graph-builder-ECNVGTRT.cjs.map +7 -0
  48. package/dist/lib/node/chunk-3QSK6IPK.cjs +133 -0
  49. package/dist/lib/node/chunk-3QSK6IPK.cjs.map +7 -0
  50. package/dist/lib/node/chunk-76F5BCJE.cjs +111 -0
  51. package/dist/lib/node/chunk-76F5BCJE.cjs.map +7 -0
  52. package/dist/lib/node/chunk-B37JIAOP.cjs +1795 -0
  53. package/dist/lib/node/chunk-B37JIAOP.cjs.map +7 -0
  54. package/dist/lib/node/{chunk-DTJ7XVO2.cjs → chunk-BAQRBGOJ.cjs} +11 -8
  55. package/dist/lib/node/chunk-BAQRBGOJ.cjs.map +7 -0
  56. package/dist/lib/node/chunk-UVWK2XJE.cjs +183 -0
  57. package/dist/lib/node/chunk-UVWK2XJE.cjs.map +7 -0
  58. package/dist/lib/node/chunk-V4L7LTWM.cjs +267 -0
  59. package/dist/lib/node/chunk-V4L7LTWM.cjs.map +7 -0
  60. package/dist/lib/node/chunk-VNBYGJ4K.cjs +34 -0
  61. package/dist/lib/node/chunk-VNBYGJ4K.cjs.map +7 -0
  62. package/dist/lib/node/index.cjs +201 -473
  63. package/dist/lib/node/index.cjs.map +4 -4
  64. package/dist/lib/node/intent-resolver-4MQZULXW.cjs +58 -0
  65. package/dist/lib/node/intent-resolver-4MQZULXW.cjs.map +7 -0
  66. package/dist/lib/node/meta.json +1 -1
  67. package/dist/lib/node/react-surface-4RVHY6WI.cjs +95 -0
  68. package/dist/lib/node/react-surface-4RVHY6WI.cjs.map +7 -0
  69. package/dist/lib/node/settings-GOIB2WJQ.cjs +36 -0
  70. package/dist/lib/node/settings-GOIB2WJQ.cjs.map +7 -0
  71. package/dist/lib/node/types/index.cjs +19 -10
  72. package/dist/lib/node/types/index.cjs.map +2 -2
  73. package/dist/lib/node-esm/AssistantDialog-IPRBJKWA.mjs +117 -0
  74. package/dist/lib/node-esm/AssistantDialog-IPRBJKWA.mjs.map +7 -0
  75. package/dist/lib/node-esm/AutomationPanel-3MPIAO7R.mjs +9 -0
  76. package/dist/lib/node-esm/ChatContainer-4IWUGMGM.mjs +34 -0
  77. package/dist/lib/node-esm/ChatContainer-4IWUGMGM.mjs.map +7 -0
  78. package/dist/lib/node-esm/TemplateContainer-YJIXR24Z.mjs +24 -0
  79. package/dist/lib/node-esm/TemplateContainer-YJIXR24Z.mjs.map +7 -0
  80. package/dist/lib/node-esm/ai-client-45LZLW7V.mjs +23 -0
  81. package/dist/lib/node-esm/ai-client-45LZLW7V.mjs.map +7 -0
  82. package/dist/lib/node-esm/app-graph-builder-HMRKSZ2X.mjs +111 -0
  83. package/dist/lib/node-esm/app-graph-builder-HMRKSZ2X.mjs.map +7 -0
  84. package/dist/lib/node-esm/chunk-5BKKHYO5.mjs +163 -0
  85. package/dist/lib/node-esm/chunk-5BKKHYO5.mjs.map +7 -0
  86. package/dist/lib/node-esm/chunk-AWAU4BHR.mjs +244 -0
  87. package/dist/lib/node-esm/chunk-AWAU4BHR.mjs.map +7 -0
  88. package/dist/lib/node-esm/chunk-CAWPHOY4.mjs +82 -0
  89. package/dist/lib/node-esm/chunk-CAWPHOY4.mjs.map +7 -0
  90. package/dist/lib/node-esm/chunk-I32H7MCF.mjs +109 -0
  91. package/dist/lib/node-esm/chunk-I32H7MCF.mjs.map +7 -0
  92. package/dist/lib/node-esm/{chunk-HNOBZHWK.mjs → chunk-IG4GSWZN.mjs} +6 -4
  93. package/dist/lib/node-esm/chunk-IG4GSWZN.mjs.map +7 -0
  94. package/dist/lib/node-esm/chunk-QHKP5HT2.mjs +1819 -0
  95. package/dist/lib/node-esm/chunk-QHKP5HT2.mjs.map +7 -0
  96. package/dist/lib/node-esm/chunk-SS7U6GCX.mjs +16 -0
  97. package/dist/lib/node-esm/chunk-SS7U6GCX.mjs.map +7 -0
  98. package/dist/lib/node-esm/index.mjs +210 -467
  99. package/dist/lib/node-esm/index.mjs.map +4 -4
  100. package/dist/lib/node-esm/intent-resolver-ZS7XTYLG.mjs +45 -0
  101. package/dist/lib/node-esm/intent-resolver-ZS7XTYLG.mjs.map +7 -0
  102. package/dist/lib/node-esm/meta.json +1 -1
  103. package/dist/lib/node-esm/react-surface-5ILD642V.mjs +81 -0
  104. package/dist/lib/node-esm/react-surface-5ILD642V.mjs.map +7 -0
  105. package/dist/lib/node-esm/settings-ANNQPPRY.mjs +23 -0
  106. package/dist/lib/node-esm/settings-ANNQPPRY.mjs.map +7 -0
  107. package/dist/lib/node-esm/types/index.mjs +18 -9
  108. package/dist/types/src/AutomationPlugin.d.ts +1 -3
  109. package/dist/types/src/AutomationPlugin.d.ts.map +1 -1
  110. package/dist/types/src/capabilities/ai-client.d.ts +5 -0
  111. package/dist/types/src/capabilities/ai-client.d.ts.map +1 -0
  112. package/dist/types/src/capabilities/app-graph-builder.d.ts +181 -0
  113. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
  114. package/dist/types/src/capabilities/capabilities.d.ts +5 -0
  115. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -0
  116. package/dist/types/src/capabilities/index.d.ts +183 -0
  117. package/dist/types/src/capabilities/index.d.ts.map +1 -0
  118. package/dist/types/src/capabilities/intent-resolver.d.ts +4 -0
  119. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -0
  120. package/dist/types/src/capabilities/react-surface.d.ts +4 -0
  121. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  122. package/dist/types/src/capabilities/settings.d.ts +4 -0
  123. package/dist/types/src/capabilities/settings.d.ts.map +1 -0
  124. package/dist/types/src/components/AmbientDialog/AmbientDialog.d.ts +7 -0
  125. package/dist/types/src/components/AmbientDialog/AmbientDialog.d.ts.map +1 -0
  126. package/dist/types/src/components/AmbientDialog/AmbientDialog.stories.d.ts +8 -0
  127. package/dist/types/src/components/AmbientDialog/AmbientDialog.stories.d.ts.map +1 -0
  128. package/dist/types/src/components/AmbientDialog/index.d.ts +2 -0
  129. package/dist/types/src/components/AmbientDialog/index.d.ts.map +1 -0
  130. package/dist/types/src/components/AssistantDialog.d.ts +7 -0
  131. package/dist/types/src/components/AssistantDialog.d.ts.map +1 -0
  132. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts +1 -2
  133. package/dist/types/src/components/AutomationPanel/AutomationPanel.d.ts.map +1 -1
  134. package/dist/types/src/components/AutomationSettings/AutomationSettings.d.ts +5 -0
  135. package/dist/types/src/components/AutomationSettings/AutomationSettings.d.ts.map +1 -0
  136. package/dist/types/src/components/AutomationSettings/index.d.ts +2 -0
  137. package/dist/types/src/components/AutomationSettings/index.d.ts.map +1 -0
  138. package/dist/types/src/components/ChatContainer.d.ts +7 -0
  139. package/dist/types/src/components/ChatContainer.d.ts.map +1 -0
  140. package/dist/types/src/components/Prompt/Prompt.d.ts +17 -0
  141. package/dist/types/src/components/Prompt/Prompt.d.ts.map +1 -0
  142. package/dist/types/src/components/Prompt/Prompt.stories.d.ts +9 -0
  143. package/dist/types/src/components/Prompt/Prompt.stories.d.ts.map +1 -0
  144. package/dist/types/src/components/Prompt/PromptBar.d.ts +10 -0
  145. package/dist/types/src/components/Prompt/PromptBar.d.ts.map +1 -0
  146. package/dist/types/src/components/Prompt/autocomplete.d.ts +21 -0
  147. package/dist/types/src/components/Prompt/autocomplete.d.ts.map +1 -0
  148. package/dist/types/src/components/Prompt/index.d.ts +3 -0
  149. package/dist/types/src/components/Prompt/index.d.ts.map +1 -0
  150. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.d.ts +5 -0
  151. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.d.ts.map +1 -0
  152. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.stories.d.ts +8 -0
  153. package/dist/types/src/components/ServiceRegistry/ServiceRegistry.stories.d.ts.map +1 -0
  154. package/dist/types/src/components/ServiceRegistry/index.d.ts +2 -0
  155. package/dist/types/src/components/ServiceRegistry/index.d.ts.map +1 -0
  156. package/dist/types/src/components/TemplateContainer.d.ts +7 -0
  157. package/dist/types/src/components/TemplateContainer.d.ts.map +1 -0
  158. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts +12 -0
  159. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -0
  160. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +8 -0
  161. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -0
  162. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +10 -0
  163. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -0
  164. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +8 -0
  165. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -0
  166. package/dist/types/src/components/TemplateEditor/index.d.ts +2 -0
  167. package/dist/types/src/components/TemplateEditor/index.d.ts.map +1 -0
  168. package/dist/types/src/components/TemplateEditor/types.d.ts.map +1 -0
  169. package/dist/types/src/components/Thread/Thread.d.ts +17 -0
  170. package/dist/types/src/components/Thread/Thread.d.ts.map +1 -0
  171. package/dist/types/src/components/Thread/Thread.stories.d.ts +11 -0
  172. package/dist/types/src/components/Thread/Thread.stories.d.ts.map +1 -0
  173. package/dist/types/src/components/Thread/ThreadContainer.d.ts +10 -0
  174. package/dist/types/src/components/Thread/ThreadContainer.d.ts.map +1 -0
  175. package/dist/types/src/components/Thread/ThreadContainer.stories.d.ts +15 -0
  176. package/dist/types/src/components/Thread/ThreadContainer.stories.d.ts.map +1 -0
  177. package/dist/types/src/components/Thread/ThreadMessage.d.ts +13 -0
  178. package/dist/types/src/components/Thread/ThreadMessage.d.ts.map +1 -0
  179. package/dist/types/src/components/Thread/ToolInvocations.d.ts +13 -0
  180. package/dist/types/src/components/Thread/ToolInvocations.d.ts.map +1 -0
  181. package/dist/types/src/components/Thread/index.d.ts +3 -0
  182. package/dist/types/src/components/Thread/index.d.ts.map +1 -0
  183. package/dist/types/src/components/Thread/reducer.d.ts +12 -0
  184. package/dist/types/src/components/Thread/reducer.d.ts.map +1 -0
  185. package/dist/types/src/components/Toolbox/Toolbox.d.ts +19 -0
  186. package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -0
  187. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +8 -0
  188. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -0
  189. package/dist/types/src/components/Toolbox/index.d.ts +2 -0
  190. package/dist/types/src/components/Toolbox/index.d.ts.map +1 -0
  191. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts +1 -3
  192. package/dist/types/src/components/TriggerEditor/TriggerEditor.d.ts.map +1 -1
  193. package/dist/types/src/components/index.d.ts +19 -2
  194. package/dist/types/src/components/index.d.ts.map +1 -1
  195. package/dist/types/src/hooks/index.d.ts +5 -0
  196. package/dist/types/src/hooks/index.d.ts.map +1 -1
  197. package/dist/types/src/hooks/processor.d.ts +75 -0
  198. package/dist/types/src/hooks/processor.d.ts.map +1 -0
  199. package/dist/types/src/hooks/processor.test.d.ts +2 -0
  200. package/dist/types/src/hooks/processor.test.d.ts.map +1 -0
  201. package/dist/types/src/hooks/useChatProcessor.d.ts +8 -0
  202. package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -0
  203. package/dist/types/src/hooks/useMessageQueue.d.ts +41 -0
  204. package/dist/types/src/hooks/useMessageQueue.d.ts.map +1 -0
  205. package/dist/types/src/hooks/useServices.d.ts +7 -0
  206. package/dist/types/src/hooks/useServices.d.ts.map +1 -0
  207. package/dist/types/src/hooks/useTextInputEvents.d.ts +13 -0
  208. package/dist/types/src/hooks/useTextInputEvents.d.ts.map +1 -0
  209. package/dist/types/src/index.d.ts +2 -4
  210. package/dist/types/src/index.d.ts.map +1 -1
  211. package/dist/types/src/meta.d.ts +2 -2
  212. package/dist/types/src/meta.d.ts.map +1 -1
  213. package/dist/types/src/testing/index.d.ts +2 -1
  214. package/dist/types/src/testing/index.d.ts.map +1 -1
  215. package/dist/types/src/testing/{testing.d.ts → test-functions.d.ts} +3 -1
  216. package/dist/types/src/testing/test-functions.d.ts.map +1 -0
  217. package/dist/types/src/testing/test-services.d.ts +5 -0
  218. package/dist/types/src/testing/test-services.d.ts.map +1 -0
  219. package/dist/types/src/tools/function.d.ts +5 -0
  220. package/dist/types/src/tools/function.d.ts.map +1 -0
  221. package/dist/types/src/tools/index.d.ts +3 -0
  222. package/dist/types/src/tools/index.d.ts.map +1 -0
  223. package/dist/types/src/tools/openapi.d.ts +10 -0
  224. package/dist/types/src/tools/openapi.d.ts.map +1 -0
  225. package/dist/types/src/tools/openapi.test.d.ts +2 -0
  226. package/dist/types/src/tools/openapi.test.d.ts.map +1 -0
  227. package/dist/types/src/translations.d.ts +117 -2
  228. package/dist/types/src/translations.d.ts.map +1 -1
  229. package/dist/types/src/types/chat.d.ts +12 -0
  230. package/dist/types/src/types/chat.d.ts.map +1 -0
  231. package/dist/types/src/types/index.d.ts +3 -1
  232. package/dist/types/src/types/index.d.ts.map +1 -1
  233. package/dist/types/src/types/service.d.ts +160 -0
  234. package/dist/types/src/types/service.d.ts.map +1 -0
  235. package/dist/types/src/types/template.d.ts +40 -0
  236. package/dist/types/src/types/template.d.ts.map +1 -0
  237. package/dist/types/src/types/types.d.ts +35 -5
  238. package/dist/types/src/types/types.d.ts.map +1 -1
  239. package/dist/types/tsconfig.tsbuildinfo +1 -1
  240. package/package.json +62 -48
  241. package/src/AutomationPlugin.tsx +102 -193
  242. package/src/capabilities/ai-client.ts +19 -0
  243. package/src/capabilities/app-graph-builder.ts +99 -0
  244. package/src/capabilities/capabilities.ts +12 -0
  245. package/src/capabilities/index.ts +13 -0
  246. package/src/capabilities/intent-resolver.ts +38 -0
  247. package/src/capabilities/react-surface.tsx +63 -0
  248. package/src/capabilities/settings.ts +19 -0
  249. package/src/components/AmbientDialog/AmbientDialog.stories.tsx +81 -0
  250. package/src/components/AmbientDialog/AmbientDialog.tsx +103 -0
  251. package/src/components/AmbientDialog/index.ts +5 -0
  252. package/src/components/AssistantDialog.tsx +33 -0
  253. package/src/components/AutomationPanel/AutomationPanel.stories.tsx +2 -2
  254. package/src/components/AutomationPanel/AutomationPanel.tsx +54 -37
  255. package/src/components/AutomationSettings/AutomationSettings.tsx +49 -0
  256. package/src/components/AutomationSettings/index.ts +5 -0
  257. package/src/components/ChatContainer.tsx +29 -0
  258. package/src/components/Prompt/Prompt.stories.tsx +79 -0
  259. package/src/components/Prompt/Prompt.tsx +100 -0
  260. package/src/components/Prompt/PromptBar.tsx +100 -0
  261. package/src/components/Prompt/autocomplete.ts +212 -0
  262. package/src/components/Prompt/index.ts +6 -0
  263. package/src/components/ServiceRegistry/ServiceRegistry.stories.tsx +49 -0
  264. package/src/components/ServiceRegistry/ServiceRegistry.tsx +76 -0
  265. package/src/components/ServiceRegistry/index.ts +5 -0
  266. package/src/components/TemplateContainer.tsx +21 -0
  267. package/src/components/TemplateEditor/TemplateEditor.stories.tsx +72 -0
  268. package/src/components/TemplateEditor/TemplateEditor.tsx +76 -0
  269. package/src/components/TemplateEditor/TemplateForm.stories.tsx +65 -0
  270. package/src/components/TemplateEditor/TemplateForm.tsx +184 -0
  271. package/src/components/{PromptEditor → TemplateEditor}/index.ts +1 -1
  272. package/src/components/Thread/Thread.stories.tsx +212 -0
  273. package/src/components/Thread/Thread.tsx +97 -0
  274. package/src/components/Thread/ThreadContainer.stories.tsx +258 -0
  275. package/src/components/Thread/ThreadContainer.tsx +78 -0
  276. package/src/components/Thread/ThreadMessage.tsx +187 -0
  277. package/src/components/Thread/ToolInvocations.tsx +93 -0
  278. package/src/components/Thread/index.ts +6 -0
  279. package/src/components/Thread/reducer.ts +52 -0
  280. package/src/components/Toolbox/Toolbox.stories.tsx +65 -0
  281. package/src/components/Toolbox/Toolbox.tsx +117 -0
  282. package/src/components/Toolbox/index.ts +5 -0
  283. package/src/components/TriggerEditor/TriggerEditor.stories.tsx +2 -2
  284. package/src/components/TriggerEditor/TriggerEditor.tsx +78 -14
  285. package/src/components/index.ts +11 -1
  286. package/src/hooks/index.ts +6 -0
  287. package/src/hooks/processor.test.ts +15 -0
  288. package/src/hooks/processor.ts +219 -0
  289. package/src/hooks/useChatProcessor.tsx +77 -0
  290. package/src/hooks/useMessageQueue.ts +23 -0
  291. package/src/hooks/useServices.ts +28 -0
  292. package/src/hooks/useTextInputEvents.ts +49 -0
  293. package/src/index.ts +3 -6
  294. package/src/meta.ts +5 -2
  295. package/src/testing/index.ts +2 -1
  296. package/src/testing/{testing.ts → test-functions.ts} +9 -2
  297. package/src/testing/test-services.ts +131 -0
  298. package/src/tools/function.ts +47 -0
  299. package/src/tools/index.ts +6 -0
  300. package/src/tools/openapi.test.ts +224 -0
  301. package/src/tools/openapi.ts +331 -0
  302. package/src/translations.ts +36 -2
  303. package/src/types/chat.ts +11 -0
  304. package/src/types/index.ts +3 -1
  305. package/src/types/service.ts +102 -0
  306. package/src/types/template.ts +34 -0
  307. package/src/types/types.ts +34 -20
  308. package/src/typings.d.ts +9 -0
  309. package/dist/lib/browser/AssistantPanel-32FH2RA6.mjs +0 -339
  310. package/dist/lib/browser/AssistantPanel-32FH2RA6.mjs.map +0 -7
  311. package/dist/lib/browser/AutomationPanel-ABGPG5LE.mjs +0 -151
  312. package/dist/lib/browser/AutomationPanel-ABGPG5LE.mjs.map +0 -7
  313. package/dist/lib/browser/chunk-DN5M2QL5.mjs +0 -49
  314. package/dist/lib/browser/chunk-DN5M2QL5.mjs.map +0 -7
  315. package/dist/lib/browser/chunk-X5KMOH3I.mjs.map +0 -7
  316. package/dist/lib/browser/meta.mjs +0 -9
  317. package/dist/lib/node/AssistantPanel-XANI7YNV.cjs +0 -359
  318. package/dist/lib/node/AssistantPanel-XANI7YNV.cjs.map +0 -7
  319. package/dist/lib/node/AutomationPanel-VADY3HMP.cjs +0 -171
  320. package/dist/lib/node/AutomationPanel-VADY3HMP.cjs.map +0 -7
  321. package/dist/lib/node/chunk-DTJ7XVO2.cjs.map +0 -7
  322. package/dist/lib/node/chunk-NIL4TP6U.cjs +0 -73
  323. package/dist/lib/node/chunk-NIL4TP6U.cjs.map +0 -7
  324. package/dist/lib/node/meta.cjs.map +0 -7
  325. package/dist/lib/node-esm/AssistantPanel-5M6O6JV7.mjs +0 -340
  326. package/dist/lib/node-esm/AssistantPanel-5M6O6JV7.mjs.map +0 -7
  327. package/dist/lib/node-esm/AutomationPanel-EETYIDPA.mjs +0 -152
  328. package/dist/lib/node-esm/AutomationPanel-EETYIDPA.mjs.map +0 -7
  329. package/dist/lib/node-esm/chunk-GCHXTXVT.mjs +0 -51
  330. package/dist/lib/node-esm/chunk-GCHXTXVT.mjs.map +0 -7
  331. package/dist/lib/node-esm/chunk-HNOBZHWK.mjs.map +0 -7
  332. package/dist/lib/node-esm/meta.mjs +0 -10
  333. package/dist/types/src/components/AssistantPanel/AssistantPanel.d.ts +0 -8
  334. package/dist/types/src/components/AssistantPanel/AssistantPanel.d.ts.map +0 -1
  335. package/dist/types/src/components/AssistantPanel/index.d.ts +0 -3
  336. package/dist/types/src/components/AssistantPanel/index.d.ts.map +0 -1
  337. package/dist/types/src/components/AssistantPanel/system-instructions.d.ts +0 -6
  338. package/dist/types/src/components/AssistantPanel/system-instructions.d.ts.map +0 -1
  339. package/dist/types/src/components/PromptEditor/PromptEditor.d.ts +0 -10
  340. package/dist/types/src/components/PromptEditor/PromptEditor.d.ts.map +0 -1
  341. package/dist/types/src/components/PromptEditor/PromptEditor.stories.d.ts +0 -6
  342. package/dist/types/src/components/PromptEditor/PromptEditor.stories.d.ts.map +0 -1
  343. package/dist/types/src/components/PromptEditor/index.d.ts +0 -2
  344. package/dist/types/src/components/PromptEditor/index.d.ts.map +0 -1
  345. package/dist/types/src/components/PromptEditor/prompt-extension.d.ts +0 -4
  346. package/dist/types/src/components/PromptEditor/prompt-extension.d.ts.map +0 -1
  347. package/dist/types/src/components/PromptEditor/types.d.ts.map +0 -1
  348. package/dist/types/src/presets.d.ts +0 -9
  349. package/dist/types/src/presets.d.ts.map +0 -1
  350. package/dist/types/src/testing/testing.d.ts.map +0 -1
  351. package/dist/types/src/types/schema.d.ts +0 -63
  352. package/dist/types/src/types/schema.d.ts.map +0 -1
  353. package/src/components/AssistantPanel/AssistantPanel.tsx +0 -230
  354. package/src/components/AssistantPanel/index.ts +0 -7
  355. package/src/components/AssistantPanel/system-instructions.ts +0 -166
  356. package/src/components/PromptEditor/PromptEditor.stories.tsx +0 -64
  357. package/src/components/PromptEditor/PromptEditor.tsx +0 -222
  358. package/src/components/PromptEditor/prompt-extension.ts +0 -43
  359. package/src/presets.ts +0 -248
  360. package/src/types/schema.ts +0 -38
  361. /package/dist/lib/browser/{meta.mjs.map → AutomationPanel-NCKK3CFN.mjs.map} +0 -0
  362. /package/dist/lib/node-esm/{meta.mjs.map → AutomationPanel-3MPIAO7R.mjs.map} +0 -0
  363. /package/dist/types/src/components/{PromptEditor → TemplateEditor}/types.d.ts +0 -0
  364. /package/src/components/{PromptEditor → TemplateEditor}/types.tsx +0 -0
@@ -0,0 +1,76 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { HighlightStyle, LanguageSupport, syntaxHighlighting } from '@codemirror/language';
6
+ import { styleTags, tags } from '@lezer/highlight';
7
+ import { handlebarsLanguage } from '@xiechao/codemirror-lang-handlebars';
8
+ import React from 'react';
9
+
10
+ import { createDocAccessor } from '@dxos/react-client/echo';
11
+ import { useThemeContext, useTranslation, type ThemedClassName } from '@dxos/react-ui';
12
+ import {
13
+ createBasicExtensions,
14
+ createDataExtensions,
15
+ createThemeExtensions,
16
+ useTextEditor,
17
+ } from '@dxos/react-ui-editor';
18
+ import { mx } from '@dxos/react-ui-theme';
19
+
20
+ import { AUTOMATION_PLUGIN } from '../../meta';
21
+ import { type TemplateType } from '../../types';
22
+
23
+ handlebarsLanguage.configure({
24
+ props: [
25
+ styleTags({
26
+ '---': tags.lineComment,
27
+ }),
28
+ ],
29
+ });
30
+
31
+ export type TemplateEditorProps = ThemedClassName<{
32
+ template: TemplateType;
33
+ }>;
34
+
35
+ export const TemplateEditor = ({ classNames, template }: TemplateEditorProps) => {
36
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
37
+ const { themeMode } = useThemeContext();
38
+ const { parentRef } = useTextEditor(
39
+ () => ({
40
+ initialValue: template.source,
41
+ extensions: [
42
+ createDataExtensions({
43
+ id: template.id,
44
+ text: template.source !== undefined ? createDocAccessor(template, ['template']) : undefined,
45
+ }),
46
+ createBasicExtensions({
47
+ bracketMatching: false,
48
+ lineWrapping: true,
49
+ placeholder: t('template placeholder'),
50
+ }),
51
+ createThemeExtensions({
52
+ themeMode,
53
+ slots: {
54
+ content: { className: '!p-3' },
55
+ },
56
+ }),
57
+
58
+ // https://github.com/xiechao/lang-handlebars
59
+ new LanguageSupport(handlebarsLanguage, syntaxHighlighting(handlebarsHighlightStyle)),
60
+ ],
61
+ }),
62
+ [themeMode, prompt],
63
+ );
64
+
65
+ return <div ref={parentRef} className={mx(classNames)} />;
66
+ };
67
+
68
+ /**
69
+ * https://github.com/xiechao/lang-handlebars/blob/direct/src/highlight.js
70
+ */
71
+ export const handlebarsHighlightStyle = HighlightStyle.define([
72
+ { tag: tags.tagName, class: 'text-redText' }, // Braces.
73
+ { tag: tags.variableName, class: 'text-blueText' },
74
+ { tag: tags.keyword, class: 'text-greenText' },
75
+ { tag: tags.comment, class: 'text-subdued' },
76
+ ]);
@@ -0,0 +1,65 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import '@dxos-theme';
6
+
7
+ import { type Meta } from '@storybook/react';
8
+ import React, { useState } from 'react';
9
+
10
+ import { create } from '@dxos/live-object';
11
+ import { useClient } from '@dxos/react-client';
12
+ import { withClientProvider } from '@dxos/react-client/testing';
13
+ import { withLayout, withTheme } from '@dxos/storybook-utils';
14
+
15
+ import { TemplateForm } from './TemplateForm';
16
+ import translations from '../../translations';
17
+ import { TemplateType } from '../../types';
18
+
19
+ const TEMPLATE = [
20
+ 'You are a machine that is an expert chess player.',
21
+ 'The move history of the current game is: {{history}}',
22
+ 'If asked to suggest a move explain why it is a good move.',
23
+ '',
24
+ '---',
25
+ '',
26
+ '{{input}}',
27
+ ].join('\n');
28
+
29
+ const Render = () => {
30
+ const client = useClient();
31
+ const [template] = useState(() => {
32
+ const space = client.spaces.default;
33
+ return space.db.add(create(TemplateType, { source: TEMPLATE }));
34
+ });
35
+
36
+ return (
37
+ <div role='none' className='flex w-[40rem] border border-separator overflow-hidden'>
38
+ <TemplateForm template={template} />
39
+ </div>
40
+ );
41
+ };
42
+
43
+ const meta: Meta<typeof TemplateForm> = {
44
+ title: 'plugins/plugin-automation/TemplateForm',
45
+ component: TemplateForm,
46
+ render: Render,
47
+ decorators: [
48
+ withClientProvider({
49
+ createIdentity: true,
50
+ createSpace: true,
51
+ types: [TemplateType],
52
+ }),
53
+ withLayout({ fullscreen: true, classNames: 'flex justify-center' }),
54
+ withTheme,
55
+ ],
56
+ parameters: {
57
+ translations,
58
+ },
59
+ };
60
+
61
+ export default meta;
62
+
63
+ type Story = Meta<typeof TemplateForm>;
64
+
65
+ export const Default: Story = {};
@@ -0,0 +1,184 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type Schema as S } from '@effect/schema';
6
+ import React, { Fragment, useEffect } from 'react';
7
+
8
+ import { Input, Select, useTranslation } from '@dxos/react-ui';
9
+ import { attentionSurface, groupBorder, mx } from '@dxos/react-ui-theme';
10
+ import { isNonNullable } from '@dxos/util';
11
+
12
+ import { TemplateEditor } from './TemplateEditor';
13
+ import { AUTOMATION_PLUGIN } from '../../meta';
14
+ import { type TemplateInput, TemplateInputType, type TemplateType } from '../../types';
15
+
16
+ export type TemplateFormProps = {
17
+ template: TemplateType;
18
+ schema?: S.Schema<any, any, any>;
19
+ commandEditable?: boolean;
20
+ };
21
+
22
+ export const TemplateForm = ({ template, commandEditable = true }: TemplateFormProps) => {
23
+ const { t } = useTranslation(AUTOMATION_PLUGIN);
24
+
25
+ usePromptInputs(template);
26
+
27
+ return (
28
+ <div className={mx('flex flex-col w-full overflow-hidden gap-4', groupBorder)}>
29
+ {commandEditable && (
30
+ <div className='flex items-center pl-4'>
31
+ <span className='text-neutral-500'>/</span>
32
+ <Input.Root>
33
+ <Input.TextInput
34
+ placeholder={t('command placeholder')}
35
+ classNames={mx('is-full bg-transparent m-2')}
36
+ value={template.command ?? ''}
37
+ onChange={(event) => {
38
+ template.command = event.target.value.replace(/\w/g, '');
39
+ }}
40
+ />
41
+ </Input.Root>
42
+ </div>
43
+ )}
44
+
45
+ <TemplateEditor template={template} classNames={[attentionSurface, 'min-h-[120px]']} />
46
+
47
+ {(template.inputs?.length ?? 0) > 0 && (
48
+ <div className='grid grid-cols-[10rem_10rem_1fr] gap-1 items-center'>
49
+ {template.inputs?.filter(isNonNullable).map((input) => (
50
+ <Fragment key={input.name}>
51
+ <div className='pis-3 text-blueText'>{input.name}</div>
52
+
53
+ <Input.Root>
54
+ <Select.Root
55
+ value={String(input.type)}
56
+ onValueChange={(type) => {
57
+ input.type = getInputType(type) ?? TemplateInputType.VALUE;
58
+ }}
59
+ >
60
+ <Select.TriggerButton placeholder='Type' classNames='is-full' />
61
+ <Select.Portal>
62
+ <Select.Content>
63
+ <Select.Viewport>
64
+ {inputTypes.map(({ value, label }) => (
65
+ <Select.Option key={value} value={String(value)}>
66
+ {label}
67
+ </Select.Option>
68
+ ))}
69
+ </Select.Viewport>
70
+ </Select.Content>
71
+ </Select.Portal>
72
+ </Select.Root>
73
+ </Input.Root>
74
+
75
+ <div>
76
+ {input.type !== undefined &&
77
+ [
78
+ TemplateInputType.VALUE,
79
+ TemplateInputType.CONTEXT,
80
+ TemplateInputType.RESOLVER,
81
+ TemplateInputType.SCHEMA,
82
+ ].includes(input.type) && (
83
+ <div>
84
+ <Input.Root>
85
+ <Input.TextInput
86
+ placeholder={t('command placeholder')}
87
+ classNames={mx('is-full bg-transparent')}
88
+ value={input.value ?? ''}
89
+ onChange={(event) => {
90
+ input.value = event.target.value;
91
+ }}
92
+ />
93
+ </Input.Root>
94
+ </div>
95
+ )}
96
+ </div>
97
+ </Fragment>
98
+ ))}
99
+ </div>
100
+ )}
101
+ </div>
102
+ );
103
+ };
104
+
105
+ const inputTypes = [
106
+ {
107
+ value: TemplateInputType.VALUE,
108
+ label: 'Value',
109
+ },
110
+ {
111
+ value: TemplateInputType.PASS_THROUGH,
112
+ label: 'Pass through',
113
+ },
114
+ {
115
+ value: TemplateInputType.RETRIEVER,
116
+ label: 'Retriever',
117
+ },
118
+ // {
119
+ // value: TemplateInputType.FUNCTION,
120
+ // label: 'Function',
121
+ // },
122
+ // {
123
+ // value: TemplateInputType.QUERY,
124
+ // label: 'Query',
125
+ // },
126
+ {
127
+ value: TemplateInputType.RESOLVER,
128
+ label: 'Resolver',
129
+ },
130
+ {
131
+ value: TemplateInputType.CONTEXT,
132
+ label: 'Context',
133
+ },
134
+ {
135
+ value: TemplateInputType.SCHEMA,
136
+ label: 'Schema',
137
+ },
138
+ ];
139
+
140
+ export const nameRegex = /\{\{([\w-]+)\}\}/;
141
+
142
+ const getInputType = (type: string) => inputTypes.find(({ value }) => String(value) === type)?.value;
143
+
144
+ const usePromptInputs = (template: TemplateType) => {
145
+ useEffect(() => {
146
+ const text = template.source ?? '';
147
+ if (!template.inputs) {
148
+ template.inputs = []; // TODO(burdon): Required?
149
+ }
150
+
151
+ const regex = new RegExp(nameRegex, 'g');
152
+ const variables = new Set<string>([...text.matchAll(regex)].map((m) => m[1]));
153
+
154
+ // Create map of unclaimed inputs.
155
+ const unclaimed = new Map<string, TemplateInput>(
156
+ template.inputs?.filter(isNonNullable).map((input) => [input.name, input]),
157
+ );
158
+ const missing: string[] = [];
159
+ Array.from(variables.values()).forEach((name) => {
160
+ if (unclaimed.has(name)) {
161
+ unclaimed.delete(name);
162
+ } else {
163
+ missing.push(name);
164
+ }
165
+ });
166
+
167
+ // Match or create new inputs.
168
+ const values = unclaimed.values();
169
+ missing.forEach((name) => {
170
+ const next = values.next().value;
171
+ if (next) {
172
+ next.name = name;
173
+ } else {
174
+ template.inputs?.push({ name });
175
+ }
176
+ });
177
+
178
+ // Remove unclaimed (deleted) inputs.
179
+ // TODO(burdon): If user types incorrect name value, it will be deleted. Garbage collect?
180
+ for (const input of values) {
181
+ template.inputs.splice(template.inputs.indexOf(input), 1);
182
+ }
183
+ }, [template.source]);
184
+ };
@@ -2,4 +2,4 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- export * from './PromptEditor';
5
+ export * from './TemplateEditor';
@@ -0,0 +1,212 @@
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, useState } from 'react';
9
+
10
+ import { IntentPlugin } from '@dxos/app-framework';
11
+ import { withPluginManager } from '@dxos/app-framework/testing';
12
+ import { type Message } from '@dxos/artifact';
13
+ import { ObjectId } from '@dxos/echo-schema';
14
+ import { faker } from '@dxos/random';
15
+ import { withClientProvider } from '@dxos/react-client/testing';
16
+ import { withLayout, withSignals, withTheme } from '@dxos/storybook-utils';
17
+
18
+ import { Thread, type ThreadProps } from './Thread';
19
+ import translations from '../../translations';
20
+
21
+ faker.seed(1);
22
+
23
+ const Render = ({ messages: _messages, ...props }: ThreadProps) => {
24
+ const [processing, setProcessing] = useState(false);
25
+ const [messages, setMessages] = useState<Message[]>(_messages ?? []);
26
+ useEffect(() => {
27
+ setMessages(_messages ?? []);
28
+ }, [_messages]);
29
+
30
+ const handleSubmit = useCallback(
31
+ (text: string) => {
32
+ const request: Message = { id: ObjectId.random(), role: 'user', content: [{ type: 'text', text }] };
33
+ const response: Message = {
34
+ id: ObjectId.random(),
35
+ role: 'assistant',
36
+ content: [{ type: 'text', disposition: 'cot', pending: true, text: faker.lorem.paragraphs(1) }],
37
+ };
38
+ setMessages([...messages, request, response]);
39
+ setProcessing(true);
40
+ setTimeout(() => {
41
+ response.content[0].pending = false;
42
+ setMessages([
43
+ ...messages,
44
+ request,
45
+ response,
46
+ {
47
+ id: ObjectId.random(),
48
+ role: 'assistant',
49
+ content: [{ type: 'text', text: faker.lorem.paragraphs(1) }],
50
+ },
51
+ ]);
52
+ setProcessing(false);
53
+ }, 3_000);
54
+ },
55
+ [messages],
56
+ );
57
+
58
+ return (
59
+ <div className='flex w-[30rem] bg-white dark:bg-black'>
60
+ <Thread
61
+ {...props}
62
+ messages={messages}
63
+ processing={processing}
64
+ onSubmit={handleSubmit}
65
+ onCancel={() => setProcessing(false)}
66
+ />
67
+ </div>
68
+ );
69
+ };
70
+
71
+ const meta: Meta<ThreadProps> = {
72
+ title: 'plugins/plugin-automation/Thread',
73
+ render: Render,
74
+ component: Thread,
75
+ decorators: [
76
+ withSignals,
77
+ withClientProvider({
78
+ createIdentity: true,
79
+ createSpace: true,
80
+ }),
81
+ withPluginManager({ plugins: [IntentPlugin()] }),
82
+ withTheme,
83
+ withLayout({ fullscreen: true, tooltips: true, classNames: 'flex justify-center' }),
84
+ ],
85
+ parameters: {
86
+ translations,
87
+ },
88
+ };
89
+
90
+ export default meta;
91
+
92
+ type Story = StoryObj<ThreadProps>;
93
+
94
+ const TEST_MESSAGES: Message[] = [
95
+ {
96
+ id: ObjectId.random(),
97
+ role: 'user',
98
+ content: [
99
+ {
100
+ type: 'text',
101
+ text: faker.lorem.sentence(5),
102
+ },
103
+ ],
104
+ },
105
+ {
106
+ id: ObjectId.random(),
107
+ role: 'assistant',
108
+ content: [
109
+ {
110
+ type: 'text',
111
+ disposition: 'cot',
112
+ text: Array.from({ length: faker.number.int({ min: 3, max: 5 }) })
113
+ .map((_, idx) => `${idx + 1}. ${faker.lorem.paragraph()}`)
114
+ .join('\n'),
115
+ },
116
+ {
117
+ type: 'text',
118
+ text: Array.from({ length: faker.number.int({ min: 2, max: 5 }) })
119
+ .map(() => faker.lorem.paragraphs())
120
+ .join('\n\n'),
121
+ },
122
+ {
123
+ type: 'tool_use',
124
+ id: '1234',
125
+ name: 'search',
126
+ input: {},
127
+ },
128
+ ],
129
+ },
130
+ {
131
+ id: ObjectId.random(),
132
+ role: 'user',
133
+ content: [
134
+ {
135
+ type: 'tool_result',
136
+ toolUseId: '1234',
137
+ content: 'This is a tool result.',
138
+ },
139
+ ],
140
+ },
141
+ {
142
+ id: ObjectId.random(),
143
+ role: 'assistant',
144
+ content: [
145
+ {
146
+ type: 'tool_use',
147
+ id: '4567',
148
+ name: 'create',
149
+ input: {},
150
+ },
151
+ ],
152
+ },
153
+ {
154
+ id: ObjectId.random(),
155
+ role: 'user',
156
+ content: [
157
+ {
158
+ type: 'tool_result',
159
+ toolUseId: '4567',
160
+ content: 'This is a tool result.',
161
+ },
162
+ ],
163
+ },
164
+ {
165
+ id: ObjectId.random(),
166
+ role: 'assistant',
167
+ content: [
168
+ {
169
+ type: 'text',
170
+ text: faker.lorem.paragraphs(1),
171
+ },
172
+ ],
173
+ },
174
+ ];
175
+
176
+ export const Default: Story = {
177
+ args: {
178
+ messages: TEST_MESSAGES,
179
+ },
180
+ };
181
+
182
+ export const Input: Story = {
183
+ args: {
184
+ processing: true,
185
+ },
186
+ };
187
+
188
+ export const Collapse: Story = {
189
+ args: {
190
+ collapse: true,
191
+ messages: TEST_MESSAGES,
192
+ },
193
+ };
194
+
195
+ export const Incremental: Story = {
196
+ render: () => {
197
+ const [messages, setMessages] = useState<Message[]>([]);
198
+ useEffect(() => {
199
+ let i = 0;
200
+ const interval = setInterval(() => {
201
+ setMessages((messages) => [...messages, TEST_MESSAGES[i++]]);
202
+ if (i >= TEST_MESSAGES.length) {
203
+ clearInterval(interval);
204
+ }
205
+ }, 2_000);
206
+
207
+ return () => clearInterval(interval);
208
+ }, []);
209
+
210
+ return <Render messages={messages} collapse />;
211
+ },
212
+ };
@@ -0,0 +1,97 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import React, { type CSSProperties, useCallback, useMemo, useRef } from 'react';
6
+
7
+ import { type Message } from '@dxos/artifact';
8
+ import { type Space } from '@dxos/react-client/echo';
9
+ import { useIdentity } from '@dxos/react-client/halo';
10
+ import { type ThemedClassName } from '@dxos/react-ui';
11
+ import { ScrollContainer, type ScrollController } from '@dxos/react-ui-components';
12
+ import { mx } from '@dxos/react-ui-theme';
13
+ import { keyToFallback } from '@dxos/util';
14
+
15
+ import { ThreadMessage, type ThreadMessageProps } from './ThreadMessage';
16
+ import { messageReducer } from './reducer';
17
+ import { PromptBar, type PromptBarProps } from '../Prompt';
18
+
19
+ export type ThreadProps = ThemedClassName<{
20
+ space?: Space;
21
+ messages?: Message[];
22
+ collapse?: boolean;
23
+ transcription?: boolean;
24
+ onOpenChange?: (open: boolean) => void;
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
+ transcription,
38
+ processing,
39
+ error,
40
+ onSubmit,
41
+ onCancel,
42
+ onOpenChange,
43
+ ...props
44
+ }: ThreadProps) => {
45
+ const scroller = useRef<ScrollController>(null);
46
+
47
+ const identity = useIdentity();
48
+ const fallbackValue = keyToFallback(identity!.identityKey);
49
+ const userHue = identity!.profile?.data?.hue || fallbackValue.hue;
50
+
51
+ const handleSubmit = useCallback<NonNullable<PromptBarProps['onSubmit']>>(
52
+ (value: string) => {
53
+ onSubmit?.(value);
54
+ scroller.current?.scrollToBottom();
55
+ return true;
56
+ },
57
+ [onSubmit],
58
+ );
59
+
60
+ // TODO(dmaretskyi): This needs to be a separate type: `id` is not a valid ObjectId, this needs to accommodate messageId for deletion.
61
+ const { messages: filteredMessages = [] } = useMemo(() => {
62
+ if (collapse) {
63
+ return (messages ?? []).reduce<{ messages: Message[]; current?: Message }>(messageReducer, {
64
+ messages: [],
65
+ });
66
+ } else {
67
+ return { messages: messages ?? [] };
68
+ }
69
+ }, [messages, collapse]);
70
+
71
+ return (
72
+ <div role='none' className={mx('flex flex-col grow overflow-hidden', classNames)}>
73
+ <ScrollContainer ref={scroller} fade>
74
+ <div
75
+ role='none'
76
+ className={mx(filteredMessages.length > 0 && 'pbs-6 pbe-6')}
77
+ style={{ '--user-fill': `var(--dx-${userHue}Fill)` } as CSSProperties}
78
+ >
79
+ {filteredMessages.map((message) => (
80
+ <ThreadMessage key={message.id} classNames='px-4 pbe-4' space={space} message={message} {...props} />
81
+ ))}
82
+ </div>
83
+ </ScrollContainer>
84
+
85
+ {onSubmit && (
86
+ <PromptBar
87
+ microphone={transcription}
88
+ processing={processing}
89
+ error={error}
90
+ onSubmit={handleSubmit}
91
+ onCancel={onCancel}
92
+ onOpenChange={onOpenChange}
93
+ />
94
+ )}
95
+ </div>
96
+ );
97
+ };