@dxos/plugin-assistant 0.8.3 → 0.8.4-main.5acf9ea

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 (432) hide show
  1. package/dist/lib/browser/{TemplateContainer-QQHVOTSI.mjs → BlueprintContainer-IZ4AK5EO.mjs} +10 -10
  2. package/dist/lib/browser/BlueprintContainer-IZ4AK5EO.mjs.map +7 -0
  3. package/dist/lib/browser/ChatContainer-RP3QEXYX.mjs +54 -0
  4. package/dist/lib/browser/ChatContainer-RP3QEXYX.mjs.map +7 -0
  5. package/dist/lib/browser/ChatDialog-ZVLXFHEY.mjs +72 -0
  6. package/dist/lib/browser/ChatDialog-ZVLXFHEY.mjs.map +7 -0
  7. package/dist/lib/browser/SequenceContainer-3UDVKWPA.mjs +162 -0
  8. package/dist/lib/browser/SequenceContainer-3UDVKWPA.mjs.map +7 -0
  9. package/dist/lib/browser/{app-graph-builder-E4H5DCOJ.mjs → app-graph-builder-XSEOKJLG.mjs} +25 -86
  10. package/dist/lib/browser/app-graph-builder-XSEOKJLG.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-63GG6U6D.mjs +2226 -0
  12. package/dist/lib/browser/chunk-63GG6U6D.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-7W7LHTRH.mjs +171 -0
  14. package/dist/lib/browser/chunk-7W7LHTRH.mjs.map +7 -0
  15. package/dist/lib/{node/chunk-P74TWGMG.cjs → browser/chunk-FDCJSQYF.mjs} +10 -14
  16. package/dist/lib/{node-esm/chunk-BB2TAT4P.mjs.map → browser/chunk-FDCJSQYF.mjs.map} +1 -1
  17. package/dist/lib/browser/{chunk-JQFUME3B.mjs → chunk-KFXSBNZR.mjs} +36 -34
  18. package/dist/lib/browser/chunk-KFXSBNZR.mjs.map +7 -0
  19. package/dist/lib/browser/{chunk-BI6AHRNJ.mjs → chunk-LERGF5YG.mjs} +19 -68
  20. package/dist/lib/browser/chunk-LERGF5YG.mjs.map +7 -0
  21. package/dist/lib/browser/index.mjs +99 -119
  22. package/dist/lib/browser/index.mjs.map +4 -4
  23. package/dist/lib/browser/intent-resolver-MV3VSZLS.mjs +75 -0
  24. package/dist/lib/browser/intent-resolver-MV3VSZLS.mjs.map +7 -0
  25. package/dist/lib/browser/meta.json +1 -1
  26. package/dist/lib/browser/{react-surface-LXCNUSZN.mjs → react-surface-3GYEHQRP.mjs} +44 -53
  27. package/dist/lib/browser/react-surface-3GYEHQRP.mjs.map +7 -0
  28. package/dist/lib/browser/{settings-XRHXVWGB.mjs → settings-5GTTCVGD.mjs} +6 -6
  29. package/dist/lib/browser/settings-5GTTCVGD.mjs.map +7 -0
  30. package/dist/lib/browser/types/index.mjs +4 -20
  31. package/dist/lib/node-esm/{TemplateContainer-SOEWY2ZN.mjs → BlueprintContainer-RGTMNLNX.mjs} +10 -10
  32. package/dist/lib/node-esm/BlueprintContainer-RGTMNLNX.mjs.map +7 -0
  33. package/dist/lib/node-esm/ChatContainer-W3W6FWV3.mjs +55 -0
  34. package/dist/lib/node-esm/ChatContainer-W3W6FWV3.mjs.map +7 -0
  35. package/dist/lib/node-esm/ChatDialog-QW4JRKVO.mjs +73 -0
  36. package/dist/lib/node-esm/ChatDialog-QW4JRKVO.mjs.map +7 -0
  37. package/dist/lib/node-esm/SequenceContainer-RQQH5XOC.mjs +163 -0
  38. package/dist/lib/node-esm/SequenceContainer-RQQH5XOC.mjs.map +7 -0
  39. package/dist/lib/node-esm/{app-graph-builder-3SY5MBIK.mjs → app-graph-builder-PANCJUHV.mjs} +25 -86
  40. package/dist/lib/node-esm/app-graph-builder-PANCJUHV.mjs.map +7 -0
  41. package/dist/lib/node-esm/chunk-BFO3KHYL.mjs +2227 -0
  42. package/dist/lib/node-esm/chunk-BFO3KHYL.mjs.map +7 -0
  43. package/dist/lib/node-esm/{chunk-UCOFKNKN.mjs → chunk-MS3PJARN.mjs} +19 -68
  44. package/dist/lib/node-esm/chunk-MS3PJARN.mjs.map +7 -0
  45. package/dist/lib/node-esm/chunk-QN2H2EHV.mjs +41 -0
  46. package/dist/lib/{browser/chunk-XOZ7YMO3.mjs.map → node-esm/chunk-QN2H2EHV.mjs.map} +1 -1
  47. package/dist/lib/node-esm/{chunk-OYN6HLXZ.mjs → chunk-VIIMA3XQ.mjs} +36 -34
  48. package/dist/lib/node-esm/chunk-VIIMA3XQ.mjs.map +7 -0
  49. package/dist/lib/node-esm/chunk-Z7PUODRT.mjs +172 -0
  50. package/dist/lib/node-esm/chunk-Z7PUODRT.mjs.map +7 -0
  51. package/dist/lib/node-esm/index.mjs +99 -119
  52. package/dist/lib/node-esm/index.mjs.map +4 -4
  53. package/dist/lib/node-esm/intent-resolver-3FMC3GHC.mjs +76 -0
  54. package/dist/lib/node-esm/intent-resolver-3FMC3GHC.mjs.map +7 -0
  55. package/dist/lib/node-esm/meta.json +1 -1
  56. package/dist/lib/node-esm/{react-surface-7HA5EDWY.mjs → react-surface-QDQWJ7FZ.mjs} +44 -53
  57. package/dist/lib/node-esm/react-surface-QDQWJ7FZ.mjs.map +7 -0
  58. package/dist/lib/node-esm/{settings-5IAY6BT4.mjs → settings-J2EXEM5H.mjs} +6 -6
  59. package/dist/lib/node-esm/settings-J2EXEM5H.mjs.map +7 -0
  60. package/dist/lib/node-esm/types/index.mjs +4 -20
  61. package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
  62. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  63. package/dist/types/src/capabilities/index.d.ts +1 -3
  64. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  65. package/dist/types/src/capabilities/intent-resolver.d.ts +2 -2
  66. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  67. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  68. package/dist/types/src/capability-definitions.d.ts +7 -0
  69. package/dist/types/src/capability-definitions.d.ts.map +1 -0
  70. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts +2 -2
  71. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
  72. package/dist/types/src/components/BlueprintContainer.d.ts +5 -6
  73. package/dist/types/src/components/BlueprintContainer.d.ts.map +1 -1
  74. package/dist/types/src/components/Chat/Chat.d.ts +47 -0
  75. package/dist/types/src/components/Chat/Chat.d.ts.map +1 -0
  76. package/dist/types/src/components/Chat/events.d.ts +30 -0
  77. package/dist/types/src/components/Chat/events.d.ts.map +1 -0
  78. package/dist/types/src/components/Chat/index.d.ts +3 -0
  79. package/dist/types/src/components/Chat/index.d.ts.map +1 -0
  80. package/dist/types/src/components/ChatContainer.d.ts +6 -6
  81. package/dist/types/src/components/ChatContainer.d.ts.map +1 -1
  82. package/dist/types/src/components/ChatDialog.d.ts +8 -0
  83. package/dist/types/src/components/ChatDialog.d.ts.map +1 -0
  84. package/dist/types/src/components/ChatPrompt/ChatActions.d.ts +11 -0
  85. package/dist/types/src/components/ChatPrompt/ChatActions.d.ts.map +1 -0
  86. package/dist/types/src/components/ChatPrompt/ChatOptionsMenu.d.ts +9 -0
  87. package/dist/types/src/components/ChatPrompt/ChatOptionsMenu.d.ts.map +1 -0
  88. package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts +11 -0
  89. package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts.map +1 -0
  90. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +11 -0
  91. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -0
  92. package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts +8 -0
  93. package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts.map +1 -0
  94. package/dist/types/src/components/ChatPrompt/index.d.ts +6 -0
  95. package/dist/types/src/components/ChatPrompt/index.d.ts.map +1 -0
  96. package/dist/types/src/components/ChatThread/ChatMessage.d.ts +17 -0
  97. package/dist/types/src/components/ChatThread/ChatMessage.d.ts.map +1 -0
  98. package/dist/types/src/components/ChatThread/ChatThread.d.ts +19 -0
  99. package/dist/types/src/components/ChatThread/ChatThread.d.ts.map +1 -0
  100. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +199 -0
  101. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -0
  102. package/dist/types/src/components/ChatThread/ToolBlock.d.ts +19 -0
  103. package/dist/types/src/components/ChatThread/ToolBlock.d.ts.map +1 -0
  104. package/dist/types/src/components/ChatThread/index.d.ts +2 -0
  105. package/dist/types/src/components/ChatThread/index.d.ts.map +1 -0
  106. package/dist/types/src/components/{Thread → ChatThread}/reducer.d.ts +4 -4
  107. package/dist/types/src/components/ChatThread/reducer.d.ts.map +1 -0
  108. package/dist/types/src/components/PromptSettings.d.ts +2 -2
  109. package/dist/types/src/components/PromptSettings.d.ts.map +1 -1
  110. package/dist/types/src/components/SequenceContainer.d.ts +8 -0
  111. package/dist/types/src/components/SequenceContainer.d.ts.map +1 -0
  112. package/dist/types/src/components/SequenceEditor/SequenceEditor.d.ts +13 -0
  113. package/dist/types/src/components/SequenceEditor/SequenceEditor.d.ts.map +1 -0
  114. package/dist/types/src/components/SequenceEditor/SequenceEditor.stories.d.ts +8 -0
  115. package/dist/types/src/components/SequenceEditor/SequenceEditor.stories.d.ts.map +1 -0
  116. package/dist/types/src/components/SequenceEditor/index.d.ts +2 -0
  117. package/dist/types/src/components/SequenceEditor/index.d.ts.map +1 -0
  118. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts +4 -3
  119. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
  120. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +3 -3
  121. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
  122. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +5 -4
  123. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
  124. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +1 -1
  125. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -1
  126. package/dist/types/src/components/Toolbox/Toolbox.d.ts +11 -4
  127. package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
  128. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +1 -1
  129. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
  130. package/dist/types/src/components/index.d.ts +6 -12
  131. package/dist/types/src/components/index.d.ts.map +1 -1
  132. package/dist/types/src/events.d.ts.map +1 -1
  133. package/dist/types/src/hooks/{processor.d.ts → chat-processor.d.ts} +36 -22
  134. package/dist/types/src/hooks/chat-processor.d.ts.map +1 -0
  135. package/dist/types/src/hooks/chat-processor.test.d.ts +2 -0
  136. package/dist/types/src/hooks/chat-processor.test.d.ts.map +1 -0
  137. package/dist/types/src/hooks/index.d.ts +5 -5
  138. package/dist/types/src/hooks/index.d.ts.map +1 -1
  139. package/dist/types/src/hooks/presets.d.ts +13 -0
  140. package/dist/types/src/hooks/presets.d.ts.map +1 -0
  141. package/dist/types/src/hooks/useBlueprints.d.ts +9 -0
  142. package/dist/types/src/hooks/useBlueprints.d.ts.map +1 -0
  143. package/dist/types/src/hooks/useChatProcessor.d.ts +20 -8
  144. package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
  145. package/dist/types/src/hooks/useChatServices.d.ts +14 -0
  146. package/dist/types/src/hooks/useChatServices.d.ts.map +1 -0
  147. package/dist/types/src/hooks/useReferencesProvider.d.ts +7 -0
  148. package/dist/types/src/hooks/useReferencesProvider.d.ts.map +1 -0
  149. package/dist/types/src/parser/index.d.ts +1 -1
  150. package/dist/types/src/parser/index.d.ts.map +1 -1
  151. package/dist/types/src/queue-logger.d.ts +5 -5
  152. package/dist/types/src/queue-logger.d.ts.map +1 -1
  153. package/dist/types/src/stories/Chat.stories.d.ts +207 -0
  154. package/dist/types/src/stories/Chat.stories.d.ts.map +1 -0
  155. package/dist/types/src/testing/index.d.ts +1 -1
  156. package/dist/types/src/testing/index.d.ts.map +1 -1
  157. package/dist/types/src/testing/test-sequence.d.ts +8 -0
  158. package/dist/types/src/testing/test-sequence.d.ts.map +1 -0
  159. package/dist/types/src/translations.d.ts +68 -113
  160. package/dist/types/src/translations.d.ts.map +1 -1
  161. package/dist/types/src/types/index.d.ts +1 -3
  162. package/dist/types/src/types/index.d.ts.map +1 -1
  163. package/dist/types/src/types/schema.d.ts +120 -0
  164. package/dist/types/src/types/schema.d.ts.map +1 -0
  165. package/dist/types/src/types/service.d.ts +9 -9
  166. package/dist/types/src/types/service.d.ts.map +1 -1
  167. package/dist/types/tsconfig.tsbuildinfo +1 -1
  168. package/package.json +84 -76
  169. package/src/AssistantPlugin.tsx +43 -44
  170. package/src/capabilities/app-graph-builder.ts +24 -103
  171. package/src/capabilities/index.ts +0 -3
  172. package/src/capabilities/intent-resolver.ts +41 -14
  173. package/src/capabilities/react-surface.tsx +38 -37
  174. package/src/capabilities/settings.ts +3 -3
  175. package/src/capability-definitions.ts +15 -0
  176. package/src/components/AssistantSettings/AssistantSettings.tsx +4 -4
  177. package/src/components/BlueprintContainer.tsx +9 -133
  178. package/src/components/Chat/Chat.tsx +388 -0
  179. package/src/components/Chat/events.ts +50 -0
  180. package/src/components/Chat/index.ts +7 -0
  181. package/src/components/ChatContainer.tsx +26 -20
  182. package/src/components/ChatDialog.tsx +64 -0
  183. package/src/components/ChatPrompt/ChatActions.tsx +71 -0
  184. package/src/components/ChatPrompt/ChatOptionsMenu.tsx +52 -0
  185. package/src/components/ChatPrompt/ChatPresets.tsx +28 -0
  186. package/src/components/ChatPrompt/ChatReferences.tsx +53 -0
  187. package/src/components/ChatPrompt/ChatStatusIndicator.tsx +39 -0
  188. package/src/components/ChatPrompt/index.ts +9 -0
  189. package/src/components/ChatThread/ChatMessage.tsx +268 -0
  190. package/src/components/ChatThread/ChatThread.stories.tsx +143 -0
  191. package/src/components/ChatThread/ChatThread.tsx +57 -0
  192. package/src/components/{Thread/ToolInvocations.tsx → ChatThread/ToolBlock.tsx} +36 -21
  193. package/src/{experimental/transcription → components/ChatThread}/index.ts +2 -0
  194. package/src/components/{Thread → ChatThread}/reducer.ts +14 -14
  195. package/src/components/PromptSettings.tsx +43 -45
  196. package/src/components/SequenceContainer.tsx +132 -0
  197. package/src/components/SequenceEditor/SequenceEditor.stories.tsx +32 -0
  198. package/src/components/{BlueprintEditor/BlueprintEditor.tsx → SequenceEditor/SequenceEditor.tsx} +7 -7
  199. package/src/components/{AmbientDialog → SequenceEditor}/index.ts +1 -1
  200. package/src/components/TemplateEditor/TemplateEditor.stories.tsx +29 -34
  201. package/src/components/TemplateEditor/TemplateEditor.tsx +39 -24
  202. package/src/components/TemplateEditor/TemplateForm.stories.tsx +17 -17
  203. package/src/components/TemplateEditor/TemplateForm.tsx +50 -57
  204. package/src/components/Toolbox/Toolbox.stories.tsx +5 -6
  205. package/src/components/Toolbox/Toolbox.tsx +60 -4
  206. package/src/components/index.ts +4 -5
  207. package/src/events.ts +2 -2
  208. package/src/hooks/{processor.test.ts → chat-processor.test.ts} +3 -2
  209. package/src/hooks/chat-processor.ts +314 -0
  210. package/src/hooks/index.ts +5 -5
  211. package/src/hooks/presets.ts +52 -0
  212. package/src/hooks/useBlueprints.ts +57 -0
  213. package/src/hooks/useChatProcessor.ts +143 -0
  214. package/src/hooks/useChatServices.ts +67 -0
  215. package/src/hooks/{useContextProvider.ts → useReferencesProvider.ts} +14 -14
  216. package/src/parser/index.ts +1 -1
  217. package/src/queue-logger.ts +6 -6
  218. package/src/stories/Chat.stories.tsx +371 -0
  219. package/src/testing/index.ts +1 -1
  220. package/src/testing/test-functions.ts +1 -1
  221. package/src/testing/test-sequence.ts +51 -0
  222. package/src/tools/openapi.test.ts +11 -11
  223. package/src/translations.ts +39 -28
  224. package/src/types/index.ts +1 -3
  225. package/src/types/schema.ts +108 -0
  226. package/dist/lib/browser/AssistantDialog-MQOOR364.mjs +0 -47
  227. package/dist/lib/browser/AssistantDialog-MQOOR364.mjs.map +0 -7
  228. package/dist/lib/browser/BlueprintContainer-AT5Y7EXG.mjs +0 -321
  229. package/dist/lib/browser/BlueprintContainer-AT5Y7EXG.mjs.map +0 -7
  230. package/dist/lib/browser/ChatContainer-C2NEAS3A.mjs +0 -40
  231. package/dist/lib/browser/ChatContainer-C2NEAS3A.mjs.map +0 -7
  232. package/dist/lib/browser/TemplateContainer-QQHVOTSI.mjs.map +0 -7
  233. package/dist/lib/browser/ai-client-MK2ZZII2.mjs +0 -39
  234. package/dist/lib/browser/ai-client-MK2ZZII2.mjs.map +0 -7
  235. package/dist/lib/browser/app-graph-builder-E4H5DCOJ.mjs.map +0 -7
  236. package/dist/lib/browser/chunk-AAOKC2JN.mjs +0 -208
  237. package/dist/lib/browser/chunk-AAOKC2JN.mjs.map +0 -7
  238. package/dist/lib/browser/chunk-BI6AHRNJ.mjs.map +0 -7
  239. package/dist/lib/browser/chunk-JO4W3MF7.mjs +0 -2101
  240. package/dist/lib/browser/chunk-JO4W3MF7.mjs.map +0 -7
  241. package/dist/lib/browser/chunk-JQFUME3B.mjs.map +0 -7
  242. package/dist/lib/browser/chunk-MEGMOFJB.mjs +0 -16
  243. package/dist/lib/browser/chunk-MEGMOFJB.mjs.map +0 -7
  244. package/dist/lib/browser/chunk-Q6UZ4F3H.mjs +0 -96
  245. package/dist/lib/browser/chunk-Q6UZ4F3H.mjs.map +0 -7
  246. package/dist/lib/browser/chunk-UE3IZ4PN.mjs +0 -15
  247. package/dist/lib/browser/chunk-UE3IZ4PN.mjs.map +0 -7
  248. package/dist/lib/browser/chunk-XOZ7YMO3.mjs +0 -20
  249. package/dist/lib/browser/intent-resolver-3UICTGPM.mjs +0 -43
  250. package/dist/lib/browser/intent-resolver-3UICTGPM.mjs.map +0 -7
  251. package/dist/lib/browser/react-surface-LXCNUSZN.mjs.map +0 -7
  252. package/dist/lib/browser/settings-XRHXVWGB.mjs.map +0 -7
  253. package/dist/lib/node/AssistantDialog-AN4Z6YUV.cjs +0 -73
  254. package/dist/lib/node/AssistantDialog-AN4Z6YUV.cjs.map +0 -7
  255. package/dist/lib/node/BlueprintContainer-NOWLDYCZ.cjs +0 -344
  256. package/dist/lib/node/BlueprintContainer-NOWLDYCZ.cjs.map +0 -7
  257. package/dist/lib/node/ChatContainer-VKYBQHUB.cjs +0 -68
  258. package/dist/lib/node/ChatContainer-VKYBQHUB.cjs.map +0 -7
  259. package/dist/lib/node/TemplateContainer-JZF2DCCG.cjs +0 -58
  260. package/dist/lib/node/TemplateContainer-JZF2DCCG.cjs.map +0 -7
  261. package/dist/lib/node/ai-client-7HNSMUMT.cjs +0 -53
  262. package/dist/lib/node/ai-client-7HNSMUMT.cjs.map +0 -7
  263. package/dist/lib/node/app-graph-builder-PPR5B5KU.cjs +0 -235
  264. package/dist/lib/node/app-graph-builder-PPR5B5KU.cjs.map +0 -7
  265. package/dist/lib/node/chunk-4EEWTDQK.cjs +0 -117
  266. package/dist/lib/node/chunk-4EEWTDQK.cjs.map +0 -7
  267. package/dist/lib/node/chunk-FUAGEO7Q.cjs +0 -52
  268. package/dist/lib/node/chunk-FUAGEO7Q.cjs.map +0 -7
  269. package/dist/lib/node/chunk-HRNIUYVQ.cjs +0 -128
  270. package/dist/lib/node/chunk-HRNIUYVQ.cjs.map +0 -7
  271. package/dist/lib/node/chunk-IKZBMHSW.cjs +0 -184
  272. package/dist/lib/node/chunk-IKZBMHSW.cjs.map +0 -7
  273. package/dist/lib/node/chunk-LMDJEGZ2.cjs +0 -233
  274. package/dist/lib/node/chunk-LMDJEGZ2.cjs.map +0 -7
  275. package/dist/lib/node/chunk-NIDICM57.cjs +0 -2080
  276. package/dist/lib/node/chunk-NIDICM57.cjs.map +0 -7
  277. package/dist/lib/node/chunk-P74TWGMG.cjs.map +0 -7
  278. package/dist/lib/node/chunk-QGPWY6GW.cjs +0 -34
  279. package/dist/lib/node/chunk-QGPWY6GW.cjs.map +0 -7
  280. package/dist/lib/node/index.cjs +0 -289
  281. package/dist/lib/node/index.cjs.map +0 -7
  282. package/dist/lib/node/intent-resolver-QSWGTKON.cjs +0 -58
  283. package/dist/lib/node/intent-resolver-QSWGTKON.cjs.map +0 -7
  284. package/dist/lib/node/meta.json +0 -1
  285. package/dist/lib/node/react-surface-D3NBYRZ6.cjs +0 -172
  286. package/dist/lib/node/react-surface-D3NBYRZ6.cjs.map +0 -7
  287. package/dist/lib/node/settings-2JXLKYGE.cjs +0 -36
  288. package/dist/lib/node/settings-2JXLKYGE.cjs.map +0 -7
  289. package/dist/lib/node/types/index.cjs +0 -54
  290. package/dist/lib/node/types/index.cjs.map +0 -7
  291. package/dist/lib/node-esm/AssistantDialog-6WEMLUPU.mjs +0 -48
  292. package/dist/lib/node-esm/AssistantDialog-6WEMLUPU.mjs.map +0 -7
  293. package/dist/lib/node-esm/BlueprintContainer-STOJAVML.mjs +0 -322
  294. package/dist/lib/node-esm/BlueprintContainer-STOJAVML.mjs.map +0 -7
  295. package/dist/lib/node-esm/ChatContainer-3MVBTUJN.mjs +0 -41
  296. package/dist/lib/node-esm/ChatContainer-3MVBTUJN.mjs.map +0 -7
  297. package/dist/lib/node-esm/TemplateContainer-SOEWY2ZN.mjs.map +0 -7
  298. package/dist/lib/node-esm/ai-client-XGZBJ6BE.mjs +0 -40
  299. package/dist/lib/node-esm/ai-client-XGZBJ6BE.mjs.map +0 -7
  300. package/dist/lib/node-esm/app-graph-builder-3SY5MBIK.mjs.map +0 -7
  301. package/dist/lib/node-esm/chunk-34EX6E5Q.mjs +0 -18
  302. package/dist/lib/node-esm/chunk-34EX6E5Q.mjs.map +0 -7
  303. package/dist/lib/node-esm/chunk-3UEZLJ2V.mjs +0 -16
  304. package/dist/lib/node-esm/chunk-3UEZLJ2V.mjs.map +0 -7
  305. package/dist/lib/node-esm/chunk-BB2TAT4P.mjs +0 -22
  306. package/dist/lib/node-esm/chunk-CDAILLCU.mjs +0 -98
  307. package/dist/lib/node-esm/chunk-CDAILLCU.mjs.map +0 -7
  308. package/dist/lib/node-esm/chunk-J6UXXZGJ.mjs +0 -209
  309. package/dist/lib/node-esm/chunk-J6UXXZGJ.mjs.map +0 -7
  310. package/dist/lib/node-esm/chunk-OD574YIU.mjs +0 -2102
  311. package/dist/lib/node-esm/chunk-OD574YIU.mjs.map +0 -7
  312. package/dist/lib/node-esm/chunk-OYN6HLXZ.mjs.map +0 -7
  313. package/dist/lib/node-esm/chunk-UCOFKNKN.mjs.map +0 -7
  314. package/dist/lib/node-esm/intent-resolver-E6MXTYAU.mjs +0 -44
  315. package/dist/lib/node-esm/intent-resolver-E6MXTYAU.mjs.map +0 -7
  316. package/dist/lib/node-esm/react-surface-7HA5EDWY.mjs.map +0 -7
  317. package/dist/lib/node-esm/settings-5IAY6BT4.mjs.map +0 -7
  318. package/dist/types/src/capabilities/ai-client.d.ts +0 -5
  319. package/dist/types/src/capabilities/ai-client.d.ts.map +0 -1
  320. package/dist/types/src/capabilities/capabilities.d.ts +0 -6
  321. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  322. package/dist/types/src/components/AmbientDialog/AmbientDialog.d.ts +0 -10
  323. package/dist/types/src/components/AmbientDialog/AmbientDialog.d.ts.map +0 -1
  324. package/dist/types/src/components/AmbientDialog/AmbientDialog.stories.d.ts +0 -8
  325. package/dist/types/src/components/AmbientDialog/AmbientDialog.stories.d.ts.map +0 -1
  326. package/dist/types/src/components/AmbientDialog/index.d.ts +0 -2
  327. package/dist/types/src/components/AmbientDialog/index.d.ts.map +0 -1
  328. package/dist/types/src/components/AssistantDialog.d.ts +0 -7
  329. package/dist/types/src/components/AssistantDialog.d.ts.map +0 -1
  330. package/dist/types/src/components/BlueprintEditor/BlueprintEditor.d.ts +0 -13
  331. package/dist/types/src/components/BlueprintEditor/BlueprintEditor.d.ts.map +0 -1
  332. package/dist/types/src/components/BlueprintEditor/BlueprintEditor.stories.d.ts +0 -8
  333. package/dist/types/src/components/BlueprintEditor/BlueprintEditor.stories.d.ts.map +0 -1
  334. package/dist/types/src/components/BlueprintEditor/index.d.ts +0 -2
  335. package/dist/types/src/components/BlueprintEditor/index.d.ts.map +0 -1
  336. package/dist/types/src/components/Prompt/Prompt.d.ts +0 -23
  337. package/dist/types/src/components/Prompt/Prompt.d.ts.map +0 -1
  338. package/dist/types/src/components/Prompt/Prompt.stories.d.ts +0 -13
  339. package/dist/types/src/components/Prompt/Prompt.stories.d.ts.map +0 -1
  340. package/dist/types/src/components/Prompt/PromptBar.d.ts +0 -16
  341. package/dist/types/src/components/Prompt/PromptBar.d.ts.map +0 -1
  342. package/dist/types/src/components/Prompt/PromptBar.stories.d.ts +0 -9
  343. package/dist/types/src/components/Prompt/PromptBar.stories.d.ts.map +0 -1
  344. package/dist/types/src/components/Prompt/autocomplete.d.ts +0 -25
  345. package/dist/types/src/components/Prompt/autocomplete.d.ts.map +0 -1
  346. package/dist/types/src/components/Prompt/index.d.ts +0 -3
  347. package/dist/types/src/components/Prompt/index.d.ts.map +0 -1
  348. package/dist/types/src/components/Prompt/references.d.ts +0 -30
  349. package/dist/types/src/components/Prompt/references.d.ts.map +0 -1
  350. package/dist/types/src/components/TemplateContainer.d.ts +0 -8
  351. package/dist/types/src/components/TemplateContainer.d.ts.map +0 -1
  352. package/dist/types/src/components/Thread/Thread.d.ts +0 -28
  353. package/dist/types/src/components/Thread/Thread.d.ts.map +0 -1
  354. package/dist/types/src/components/Thread/Thread.stories.d.ts +0 -11
  355. package/dist/types/src/components/Thread/Thread.stories.d.ts.map +0 -1
  356. package/dist/types/src/components/Thread/ThreadContainer.d.ts +0 -13
  357. package/dist/types/src/components/Thread/ThreadContainer.d.ts.map +0 -1
  358. package/dist/types/src/components/Thread/ThreadContainer.stories.d.ts +0 -16
  359. package/dist/types/src/components/Thread/ThreadContainer.stories.d.ts.map +0 -1
  360. package/dist/types/src/components/Thread/ThreadMessage.d.ts +0 -16
  361. package/dist/types/src/components/Thread/ThreadMessage.d.ts.map +0 -1
  362. package/dist/types/src/components/Thread/ToolInvocations.d.ts +0 -13
  363. package/dist/types/src/components/Thread/ToolInvocations.d.ts.map +0 -1
  364. package/dist/types/src/components/Thread/index.d.ts +0 -3
  365. package/dist/types/src/components/Thread/index.d.ts.map +0 -1
  366. package/dist/types/src/components/Thread/reducer.d.ts.map +0 -1
  367. package/dist/types/src/experimental/transcription/index.d.ts +0 -1
  368. package/dist/types/src/experimental/transcription/index.d.ts.map +0 -1
  369. package/dist/types/src/hooks/processor.d.ts.map +0 -1
  370. package/dist/types/src/hooks/processor.test.d.ts +0 -2
  371. package/dist/types/src/hooks/processor.test.d.ts.map +0 -1
  372. package/dist/types/src/hooks/useContextProvider.d.ts +0 -17
  373. package/dist/types/src/hooks/useContextProvider.d.ts.map +0 -1
  374. package/dist/types/src/hooks/useMessageQueue.d.ts +0 -42
  375. package/dist/types/src/hooks/useMessageQueue.d.ts.map +0 -1
  376. package/dist/types/src/hooks/useServices.d.ts +0 -7
  377. package/dist/types/src/hooks/useServices.d.ts.map +0 -1
  378. package/dist/types/src/hooks/useTextInputEvents.d.ts +0 -13
  379. package/dist/types/src/hooks/useTextInputEvents.d.ts.map +0 -1
  380. package/dist/types/src/stories/Prompt.stories.d.ts +0 -8
  381. package/dist/types/src/stories/Prompt.stories.d.ts.map +0 -1
  382. package/dist/types/src/stories/Query.stories.d.ts +0 -19
  383. package/dist/types/src/stories/Query.stories.d.ts.map +0 -1
  384. package/dist/types/src/stories/Research.stories.d.ts +0 -15
  385. package/dist/types/src/stories/Research.stories.d.ts.map +0 -1
  386. package/dist/types/src/stories/test-data.d.ts +0 -3
  387. package/dist/types/src/stories/test-data.d.ts.map +0 -1
  388. package/dist/types/src/stories/testing.d.ts +0 -12
  389. package/dist/types/src/stories/testing.d.ts.map +0 -1
  390. package/dist/types/src/testing/test-blueprint.d.ts +0 -8
  391. package/dist/types/src/testing/test-blueprint.d.ts.map +0 -1
  392. package/dist/types/src/types/chat.d.ts +0 -23
  393. package/dist/types/src/types/chat.d.ts.map +0 -1
  394. package/dist/types/src/types/template.d.ts +0 -56
  395. package/dist/types/src/types/template.d.ts.map +0 -1
  396. package/dist/types/src/types/types.d.ts +0 -50
  397. package/dist/types/src/types/types.d.ts.map +0 -1
  398. package/src/capabilities/ai-client.ts +0 -42
  399. package/src/capabilities/capabilities.ts +0 -15
  400. package/src/components/AmbientDialog/AmbientDialog.stories.tsx +0 -84
  401. package/src/components/AmbientDialog/AmbientDialog.tsx +0 -117
  402. package/src/components/AssistantDialog.tsx +0 -37
  403. package/src/components/BlueprintEditor/BlueprintEditor.stories.tsx +0 -32
  404. package/src/components/BlueprintEditor/index.ts +0 -5
  405. package/src/components/Prompt/Prompt.stories.tsx +0 -121
  406. package/src/components/Prompt/Prompt.tsx +0 -124
  407. package/src/components/Prompt/PromptBar.stories.tsx +0 -69
  408. package/src/components/Prompt/PromptBar.tsx +0 -105
  409. package/src/components/Prompt/autocomplete.ts +0 -218
  410. package/src/components/Prompt/index.ts +0 -6
  411. package/src/components/Prompt/references.ts +0 -180
  412. package/src/components/TemplateContainer.tsx +0 -23
  413. package/src/components/Thread/Thread.stories.tsx +0 -201
  414. package/src/components/Thread/Thread.tsx +0 -118
  415. package/src/components/Thread/ThreadContainer.stories.tsx +0 -283
  416. package/src/components/Thread/ThreadContainer.tsx +0 -105
  417. package/src/components/Thread/ThreadMessage.tsx +0 -234
  418. package/src/components/Thread/index.ts +0 -6
  419. package/src/hooks/processor.ts +0 -238
  420. package/src/hooks/useChatProcessor.tsx +0 -97
  421. package/src/hooks/useMessageQueue.ts +0 -22
  422. package/src/hooks/useServices.ts +0 -28
  423. package/src/hooks/useTextInputEvents.ts +0 -49
  424. package/src/stories/Prompt.stories.tsx +0 -60
  425. package/src/stories/Query.stories.tsx +0 -514
  426. package/src/stories/Research.stories.tsx +0 -482
  427. package/src/stories/test-data.ts +0 -128
  428. package/src/stories/testing.ts +0 -60
  429. package/src/testing/test-blueprint.ts +0 -58
  430. package/src/types/chat.ts +0 -32
  431. package/src/types/template.ts +0 -66
  432. package/src/types/types.ts +0 -48
@@ -0,0 +1,28 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import React from 'react';
6
+
7
+ import { Select } from '@dxos/react-ui';
8
+
9
+ export type ChatPresetsProps = {
10
+ presets?: { id: string; label: string }[];
11
+ preset?: string;
12
+ onChange?: (id: string) => void;
13
+ };
14
+
15
+ export const ChatPresets = ({ presets, preset, onChange }: ChatPresetsProps) => {
16
+ return (
17
+ <Select.Root value={preset} onValueChange={onChange}>
18
+ <Select.TriggerButton classNames='text-sm' />
19
+ <Select.Content>
20
+ {presets?.map(({ id, label }) => (
21
+ <Select.Option key={id} value={id} classNames='text-sm'>
22
+ {label}
23
+ </Select.Option>
24
+ ))}
25
+ </Select.Content>
26
+ </Select.Root>
27
+ );
28
+ };
@@ -0,0 +1,53 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import React, { useCallback } from 'react';
6
+
7
+ import { type ContextBinder } from '@dxos/assistant';
8
+ import { type Space } from '@dxos/client/echo';
9
+ import { Filter, Obj, Ref } from '@dxos/echo';
10
+ import { type ThemedClassName, useAsyncState, useTranslation } from '@dxos/react-ui';
11
+ import { TagPicker, type TagPickerItemData, type TagPickerOptions } from '@dxos/react-ui-tag-picker';
12
+ import { mx } from '@dxos/react-ui-theme';
13
+ import { isNonNullable } from '@dxos/util';
14
+
15
+ import { meta } from '../../meta';
16
+
17
+ export type ChatReferencesProps = ThemedClassName<{
18
+ space: Space;
19
+ context: ContextBinder;
20
+ onUpdate?: (ids: string[]) => void;
21
+ }>;
22
+
23
+ export const ChatReferences = ({ classNames, space, context, onUpdate }: ChatReferencesProps) => {
24
+ const { t: _t } = useTranslation(meta.id);
25
+
26
+ const [items] = useAsyncState<TagPickerItemData[]>(async () => {
27
+ const objects = await Ref.Array.loadAll(context.objects.value ?? []);
28
+ return objects.filter(isNonNullable).map((obj) => ({ id: obj.id, label: Obj.getLabel(obj) ?? obj.id }));
29
+ }, [context]);
30
+
31
+ const handleSearch = useCallback<NonNullable<TagPickerOptions['onSearch']>>(
32
+ (text, ids) => {
33
+ // TODO(burdon): Filter by Item tag (e.g., exclude "contacts") and Query by object label.
34
+ // TODO(burdon): Change to Filter.text().
35
+ const objects = space.db.query(Filter.everything()).runSync();
36
+ return objects
37
+ .map(({ object }) => ({ id: object.id, label: Obj.getLabel(object) ?? '' }))
38
+ .filter(({ id, label }) => !ids.includes(id) && label.toLocaleLowerCase().includes(text.toLocaleLowerCase()));
39
+ },
40
+ [space],
41
+ );
42
+
43
+ return (
44
+ <TagPicker
45
+ classNames={mx('h-[1.75rem] text-sm', classNames)}
46
+ mode='multi-select'
47
+ // placeholder={t('context objects placeholder')}
48
+ items={items}
49
+ onSearch={handleSearch}
50
+ onUpdate={onUpdate}
51
+ />
52
+ );
53
+ };
@@ -0,0 +1,39 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import React, { useEffect, useState } from 'react';
6
+
7
+ import { Icon, Tooltip, useTimeout } from '@dxos/react-ui';
8
+ import { Spinner } from '@dxos/react-ui-sfx';
9
+ import { errorText } from '@dxos/react-ui-theme';
10
+
11
+ export type ChatStatusIndicatorProps = {
12
+ preset?: string;
13
+ error?: Error;
14
+ processing?: boolean;
15
+ };
16
+
17
+ export const ChatStatusIndicator = ({ preset, error, processing }: ChatStatusIndicatorProps) => {
18
+ const [init, setInit] = useState(false);
19
+ useEffect(() => {
20
+ setInit(false);
21
+ }, [preset]);
22
+ useTimeout(
23
+ async () => {
24
+ setInit(true);
25
+ },
26
+ 1_500,
27
+ [preset],
28
+ );
29
+
30
+ if (error) {
31
+ return (
32
+ <Tooltip.Trigger content={error.message} delayDuration={0}>
33
+ <Icon icon='ph--warning-circle--regular' classNames={errorText} size={5} />
34
+ </Tooltip.Trigger>
35
+ );
36
+ }
37
+
38
+ return <Spinner state={!init ? 'flash' : processing ? 'spin' : 'pulse'} />;
39
+ };
@@ -0,0 +1,9 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export * from './ChatActions';
6
+ export * from './ChatOptionsMenu';
7
+ export * from './ChatPresets';
8
+ export * from './ChatReferences';
9
+ export * from './ChatStatusIndicator';
@@ -0,0 +1,268 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import React, { Fragment, type FC, type PropsWithChildren } from 'react';
6
+
7
+ import { type Tool } from '@dxos/ai';
8
+ import { Surface } from '@dxos/app-framework';
9
+ import { invariant } from '@dxos/invariant';
10
+ import { type Space } from '@dxos/react-client/echo';
11
+ import { Button, Icon, IconButton, useTranslation, type ThemedClassName } from '@dxos/react-ui';
12
+ import {
13
+ MarkdownViewer,
14
+ ToggleContainer as NativeToggleContainer,
15
+ type ToggleContainerProps,
16
+ } from '@dxos/react-ui-components';
17
+ import { mx } from '@dxos/react-ui-theme';
18
+ import { type ContentBlock, type DataType } from '@dxos/schema';
19
+ import { safeParseJson } from '@dxos/util';
20
+
21
+ import { Json, ToolBlock, isToolMessage } from './ToolBlock';
22
+ import { type ChatProcessor } from '../../hooks';
23
+ import { meta } from '../../meta';
24
+ import { type ChatEvent } from '../Chat';
25
+ import { ToolboxContainer } from '../Toolbox';
26
+
27
+ export type ChatMessageProps = ThemedClassName<{
28
+ debug?: boolean;
29
+ space?: Space;
30
+ message: DataType.Message;
31
+ // TODO(burdon): Move to context.
32
+ processor?: ChatProcessor;
33
+ tools?: Tool[];
34
+ onEvent?: (event: ChatEvent) => void;
35
+ }>;
36
+
37
+ export const ChatMessage = ({ classNames, debug, space, message, processor, tools, onEvent }: ChatMessageProps) => {
38
+ const { t } = useTranslation(meta.id);
39
+ const {
40
+ sender: { role },
41
+ blocks,
42
+ } = message;
43
+
44
+ // TODO(burdon): Restructure types to make check unnecessary.
45
+ if (isToolMessage(message)) {
46
+ return (
47
+ <MessageContainer classNames={mx(classNames, 'animate-[fadeIn_0.5s]')}>
48
+ <ToolBlock classNames={panelClasses} message={message} tools={tools} />
49
+ </MessageContainer>
50
+ );
51
+ }
52
+
53
+ return (
54
+ <>
55
+ {debug && (
56
+ <div className={mx('flex justify-end text-subdued', marginClasses)}>
57
+ <pre className='text-xs'>{JSON.stringify({ created: message.created })}</pre>
58
+ </div>
59
+ )}
60
+
61
+ {blocks.map((block, idx) => {
62
+ // TODO(burdon): Filter empty messages.
63
+ if (block._tag === 'text' && block.text.replaceAll(/\s+/g, '').length === 0) {
64
+ return null;
65
+ }
66
+
67
+ const Component: BlockComponent = components[block._tag] ?? components.default!;
68
+ if (!Component) {
69
+ return null;
70
+ }
71
+
72
+ return (
73
+ <Fragment key={idx}>
74
+ <MessageContainer classNames={classNames} user={block._tag === 'text' && role === 'user'}>
75
+ <Component space={space} processor={processor} block={block} onEvent={onEvent} />
76
+ </MessageContainer>
77
+ {debug && (
78
+ <div className={mx('flex justify-end text-subdued', marginClasses)}>
79
+ <pre className='text-xs'>{JSON.stringify({ block: block._tag })}</pre>
80
+ </div>
81
+ )}
82
+ </Fragment>
83
+ );
84
+ })}
85
+ <div className={mx('flex justify-end pbs-2 pbe-2 opacity-50 hover:opacity-100', marginClasses)}>
86
+ <IconButton
87
+ classNames='animate-[fadeIn_0.5s]'
88
+ icon='ph--trash--regular'
89
+ iconOnly
90
+ label={t('button delete message')}
91
+ onClick={() => onEvent?.({ type: 'delete', id: message.id })}
92
+ />
93
+ </div>
94
+ </>
95
+ );
96
+ };
97
+
98
+ type BlockComponentProps = {
99
+ space?: Space;
100
+ block: ContentBlock.Any;
101
+ /** @deprecated Replace with context */
102
+ processor?: ChatProcessor;
103
+ onEvent?: (event: ChatEvent) => void;
104
+ };
105
+
106
+ type BlockComponent = FC<BlockComponentProps>;
107
+
108
+ const components: Partial<Record<ContentBlock.Any['_tag'] | 'default', BlockComponent>> = {
109
+ //
110
+ // Text
111
+ //
112
+ ['text' as const]: ({ block }) => {
113
+ invariant(block._tag === 'text');
114
+ // const [open, setOpen] = useState(block.disposition === 'cot' && block.pending);
115
+ const title = block.disposition ? titles[block.disposition] : undefined;
116
+ if (!title) {
117
+ return <MarkdownViewer content={block.text} />;
118
+ }
119
+
120
+ // TOOD(burdon): Store last time user opened/closed COT.
121
+ // Autoclose when streaming ends.
122
+ // useEffect(() => {
123
+ // if (block.disposition === 'cot' && !block.pending) {
124
+ // setOpen(false);
125
+ // }
126
+ // }, [block.disposition, block.pending]);
127
+
128
+ return (
129
+ <ToggleContainer
130
+ // open={open}
131
+ defaultOpen={systemDispositions.includes(block.disposition ?? '') && block.pending}
132
+ title={title}
133
+ icon={
134
+ block.pending ? (
135
+ <Icon icon={'ph--circle-notch--regular'} classNames='text-subdued animate-spin' size={4} />
136
+ ) : undefined
137
+ }
138
+ >
139
+ <MarkdownViewer
140
+ content={block.text}
141
+ classNames={['pbe-2', systemDispositions.includes(block.disposition ?? '') && 'text-sm text-subdued']}
142
+ />
143
+ </ToggleContainer>
144
+ );
145
+ },
146
+
147
+ //
148
+ // JSON
149
+ //
150
+ ['json' as const]: ({ space, processor, block, onEvent }) => {
151
+ invariant(block._tag === 'json');
152
+
153
+ switch (block.disposition) {
154
+ case 'tool_list': {
155
+ return (
156
+ <ToggleContainer title={titles[block.disposition]} defaultOpen={true}>
157
+ <ToolboxContainer space={space} processor={processor} classNames='pbe-2' />
158
+ </ToggleContainer>
159
+ );
160
+ }
161
+
162
+ case 'suggest': {
163
+ const { text = '' }: { text: string } = safeParseJson(block.data ?? '{}') ?? ({} as any);
164
+ return (
165
+ <IconButton icon='ph--lightning--regular' label={text} onClick={() => onEvent?.({ type: 'submit', text })} />
166
+ );
167
+ }
168
+
169
+ case 'select': {
170
+ const { options = [] }: { options: string[] } = safeParseJson(block.data ?? '{}') ?? ({} as any);
171
+ return (
172
+ <div className='flex flex-wrap gap-1'>
173
+ {options.map((text, idx) => (
174
+ <Button
175
+ classNames={'animate-[fadeIn_0.5s] rounded-sm text-sm'}
176
+ key={idx}
177
+ onClick={() => onEvent?.({ type: 'submit', text })}
178
+ >
179
+ {text}
180
+ </Button>
181
+ ))}
182
+ </div>
183
+ );
184
+ }
185
+
186
+ case 'graph': {
187
+ return (
188
+ <div className='flex flex-wrap gap-1'>
189
+ <Surface
190
+ role='card'
191
+ data={{ subject: JSON.parse(block.data ?? '{}') }}
192
+ limit={1}
193
+ fallback={<div className='font-mono text-xs text-pre'>{block.data}</div>}
194
+ />
195
+ {onEvent && (
196
+ <IconButton
197
+ icon='ph--plus--regular'
198
+ label='Add to graph'
199
+ onClick={() => onEvent?.({ type: 'add', object: JSON.parse(block.data ?? '{}') })}
200
+ />
201
+ )}
202
+ </div>
203
+ );
204
+ }
205
+
206
+ default: {
207
+ const title = block.disposition ? titles[block.disposition] : undefined;
208
+ return (
209
+ <ToggleContainer title={title ?? 'JSON'}>
210
+ <Json data={safeParseJson(block.data ?? block)} />
211
+ </ToggleContainer>
212
+ );
213
+ }
214
+ }
215
+ },
216
+
217
+ //
218
+ // Default
219
+ //
220
+ default: ({ block }) => {
221
+ let title = titles[block._tag];
222
+ if (block._tag === 'toolCall') {
223
+ title = `Tool [${block.name}]`; // TODO(burdon): Get label from tool.
224
+ } else {
225
+ title = block._tag;
226
+ }
227
+
228
+ return (
229
+ <ToggleContainer title={title ?? 'JSON'}>
230
+ <Json data={block} />
231
+ </ToggleContainer>
232
+ );
233
+ },
234
+ };
235
+
236
+ // TODO(burdon): Translations.
237
+ const titles: Record<string, string> = {
238
+ ['cot' as const]: 'Chain of thought',
239
+ ['artifact' as const]: 'Artifact',
240
+ ['tool_use' as const]: 'Tool request',
241
+ ['tool_result' as const]: 'Tool result',
242
+ ['tool_list' as const]: 'Tools',
243
+ ['artifact-update' as const]: 'Artifact(s) changed',
244
+ };
245
+
246
+ const systemDispositions: string[] = ['cot', 'artifact-update'];
247
+
248
+ const panelClasses = 'flex flex-col is-full bg-activeSurface rounded-sm';
249
+ const marginClasses = 'pie-4 pis-4';
250
+ const paddingClasses = 'pis-2 pie-2 pbs-0.5 pbe-0.5';
251
+
252
+ const MessageContainer = ({ classNames, children, user }: ThemedClassName<PropsWithChildren<{ user?: boolean }>>) => {
253
+ if (!children) {
254
+ return null;
255
+ }
256
+
257
+ return (
258
+ <div role='list-item' className={mx('flex is-full', user && 'justify-end', marginClasses, classNames)}>
259
+ <div className={mx(user ? ['rounded-sm', 'bg-[--user-fill] text-accentSurfaceText', paddingClasses] : 'is-full')}>
260
+ {children}
261
+ </div>
262
+ </div>
263
+ );
264
+ };
265
+
266
+ const ToggleContainer = (props: ToggleContainerProps) => {
267
+ return <NativeToggleContainer {...props} classNames={mx(panelClasses, props.classNames)} />;
268
+ };
@@ -0,0 +1,143 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import '@dxos-theme';
6
+
7
+ import { type StoryObj, type Meta } from '@storybook/react-vite';
8
+ import React, { useEffect, useState } from 'react';
9
+
10
+ import { Obj } from '@dxos/echo';
11
+ import { faker } from '@dxos/random';
12
+ import { withClientProvider } from '@dxos/react-client/testing';
13
+ import { DataType, type ContentBlock } from '@dxos/schema';
14
+ import { ColumnContainer, withLayout, withTheme } from '@dxos/storybook-utils';
15
+
16
+ import { ChatThread } from './ChatThread';
17
+ import { translations } from '../../translations';
18
+
19
+ faker.seed(1);
20
+
21
+ const createMessage = (role: DataType.ActorRole, blocks: ContentBlock.Any[]): DataType.Message => {
22
+ return Obj.make(DataType.Message, {
23
+ created: new Date().toISOString(),
24
+ sender: { role },
25
+ blocks,
26
+ });
27
+ };
28
+
29
+ const TEST_MESSAGES: DataType.Message[] = [
30
+ createMessage('user', [
31
+ {
32
+ _tag: 'text',
33
+ text: faker.lorem.sentence(5),
34
+ } satisfies ContentBlock.Text,
35
+ ]),
36
+
37
+ createMessage('assistant', [
38
+ {
39
+ _tag: 'text',
40
+ disposition: 'cot',
41
+ text: Array.from({ length: faker.number.int({ min: 3, max: 5 }) })
42
+ .map((_, idx) => `${idx + 1}. ${faker.lorem.paragraph()}`)
43
+ .join('\n'),
44
+ },
45
+ {
46
+ _tag: 'text',
47
+ text: Array.from({ length: faker.number.int({ min: 2, max: 5 }) })
48
+ .map(() => faker.lorem.paragraphs())
49
+ .join('\n\n'),
50
+ },
51
+ {
52
+ _tag: 'toolCall',
53
+ toolCallId: '1234',
54
+ name: 'search',
55
+ input: {},
56
+ } satisfies ContentBlock.ToolCall,
57
+ ]),
58
+
59
+ createMessage('user', [
60
+ {
61
+ _tag: 'toolResult',
62
+ toolCallId: '1234',
63
+ name: 'search',
64
+ result: 'This is a tool result.',
65
+ } satisfies ContentBlock.ToolResult,
66
+ ]),
67
+
68
+ createMessage('assistant', [
69
+ {
70
+ _tag: 'toolCall',
71
+ toolCallId: '4567',
72
+ name: 'create',
73
+ input: {},
74
+ } satisfies ContentBlock.ToolCall,
75
+ ]),
76
+
77
+ createMessage('user', [
78
+ {
79
+ _tag: 'toolResult',
80
+ toolCallId: '4567',
81
+ name: 'create',
82
+ result: 'This is a tool result.',
83
+ } satisfies ContentBlock.ToolResult,
84
+ ]),
85
+
86
+ createMessage('assistant', [
87
+ {
88
+ _tag: 'text',
89
+ text: faker.lorem.paragraphs(1),
90
+ } satisfies ContentBlock.Text,
91
+ ]),
92
+
93
+ createMessage('assistant', [
94
+ {
95
+ _tag: 'json',
96
+ disposition: 'suggest',
97
+ data: JSON.stringify({ text: 'Search...' }),
98
+ },
99
+ {
100
+ _tag: 'json',
101
+ disposition: 'suggest',
102
+ data: JSON.stringify({ text: faker.lorem.paragraphs(1) }),
103
+ } satisfies ContentBlock.Json,
104
+ ]),
105
+ ];
106
+
107
+ const meta = {
108
+ title: 'plugins/plugin-assistant/ChatThread',
109
+ component: ChatThread,
110
+ decorators: [withClientProvider({ createIdentity: true }), withTheme, withLayout({ Container: ColumnContainer })],
111
+ parameters: {
112
+ translations,
113
+ },
114
+ } satisfies Meta<typeof ChatThread>;
115
+
116
+ export default meta;
117
+
118
+ type Story = StoryObj<typeof meta>;
119
+
120
+ export const Default = {
121
+ args: {
122
+ messages: TEST_MESSAGES,
123
+ },
124
+ } satisfies Story;
125
+
126
+ export const Incremental = {
127
+ render: () => {
128
+ const [messages, setMessages] = useState<DataType.Message[]>([]);
129
+ useEffect(() => {
130
+ let i = 0;
131
+ const interval = setInterval(() => {
132
+ setMessages((messages) => [...messages, TEST_MESSAGES[i++]]);
133
+ if (i >= TEST_MESSAGES.length) {
134
+ clearInterval(interval);
135
+ }
136
+ }, 2_000);
137
+
138
+ return () => clearInterval(interval);
139
+ }, []);
140
+
141
+ return <ChatThread messages={messages} collapse />;
142
+ },
143
+ } satisfies Story;
@@ -0,0 +1,57 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import React, { type CSSProperties, forwardRef, useMemo } from 'react';
6
+
7
+ import { PublicKey } from '@dxos/keys';
8
+ import { type Identity } from '@dxos/react-client/halo';
9
+ import { type ThemedClassName } from '@dxos/react-ui';
10
+ import { ScrollContainer, type ScrollController } from '@dxos/react-ui-components';
11
+ import { mx } from '@dxos/react-ui-theme';
12
+ import { type DataType } from '@dxos/schema';
13
+ import { keyToFallback } from '@dxos/util';
14
+
15
+ import { ChatMessage, type ChatMessageProps } from './ChatMessage';
16
+ import { messageReducer } from './reducer';
17
+
18
+ export type ChatThreadProps = ThemedClassName<
19
+ {
20
+ identity?: Identity;
21
+ messages?: DataType.Message[];
22
+ collapse?: boolean;
23
+ } & Pick<ChatMessageProps, 'debug' | 'space' | 'processor' | 'tools' | 'onEvent'>
24
+ >;
25
+
26
+ export const ChatThread = forwardRef<ScrollController, ChatThreadProps>(
27
+ ({ classNames, identity, messages, collapse = true, ...props }, forwardedRef) => {
28
+ const userHue = useMemo(() => {
29
+ return identity?.profile?.data?.hue || keyToFallback(identity?.identityKey ?? PublicKey.random()).hue;
30
+ }, [identity]);
31
+
32
+ // TODO(dmaretskyi): This needs to be a separate type: `id` is not a valid ObjectId, this needs to accommodate messageId for deletion.
33
+ const { messages: filteredMessages = [] } = useMemo(() => {
34
+ if (collapse) {
35
+ return (messages ?? []).reduce<{ messages: DataType.Message[]; current?: DataType.Message }>(messageReducer, {
36
+ messages: [],
37
+ });
38
+ } else {
39
+ return { messages: messages ?? [] };
40
+ }
41
+ }, [messages, collapse]);
42
+
43
+ return (
44
+ <ScrollContainer ref={forwardedRef} classNames={classNames} fade>
45
+ <div
46
+ role='none'
47
+ className={mx(filteredMessages.length > 0 && 'pbs-4 pbe-4')}
48
+ style={{ '--user-fill': `var(--dx-${userHue}Fill)` } as CSSProperties}
49
+ >
50
+ {filteredMessages.map((message) => (
51
+ <ChatMessage key={message.id} message={message} {...props} />
52
+ ))}
53
+ </div>
54
+ </ScrollContainer>
55
+ );
56
+ },
57
+ );