@dxos/plugin-assistant 0.8.4-main.3c1ae3b → 0.8.4-main.3fbcb4aa9b

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 (708) hide show
  1. package/dist/lib/neutral/AgentArticle-LDV6UTSH.mjs +168 -0
  2. package/dist/lib/neutral/AgentArticle-LDV6UTSH.mjs.map +7 -0
  3. package/dist/lib/neutral/AgentProperties-H535EM5S.mjs +100 -0
  4. package/dist/lib/neutral/AgentProperties-H535EM5S.mjs.map +7 -0
  5. package/dist/lib/neutral/AssistantPlugin.mjs +99 -0
  6. package/dist/lib/neutral/AssistantPlugin.mjs.map +7 -0
  7. package/dist/lib/neutral/AssistantPlugin.node.mjs +46 -0
  8. package/dist/lib/neutral/AssistantPlugin.node.mjs.map +7 -0
  9. package/dist/lib/neutral/AssistantSettings-GG52BLKS.mjs +40 -0
  10. package/dist/lib/neutral/AssistantSettings-GG52BLKS.mjs.map +7 -0
  11. package/dist/lib/neutral/BlueprintArticle-U7LUBFOS.mjs +27 -0
  12. package/dist/lib/neutral/BlueprintArticle-U7LUBFOS.mjs.map +7 -0
  13. package/dist/lib/neutral/ChatCompanion-6LC7YCV6.mjs +130 -0
  14. package/dist/lib/neutral/ChatCompanion-6LC7YCV6.mjs.map +7 -0
  15. package/dist/lib/neutral/ChatContainer-X3R4ALHT.mjs +8 -0
  16. package/dist/lib/neutral/ChatDialog-QKZLG7SQ.mjs +72 -0
  17. package/dist/lib/neutral/ChatDialog-QKZLG7SQ.mjs.map +7 -0
  18. package/dist/lib/neutral/RoutineArticle-6LC3P7OB.mjs +55 -0
  19. package/dist/lib/neutral/RoutineArticle-6LC3P7OB.mjs.map +7 -0
  20. package/dist/lib/neutral/RoutineList-CLDXGQUD.mjs +48 -0
  21. package/dist/lib/neutral/RoutineList-CLDXGQUD.mjs.map +7 -0
  22. package/dist/lib/neutral/TracePanel-HYVPDIAA.mjs +565 -0
  23. package/dist/lib/neutral/TracePanel-HYVPDIAA.mjs.map +7 -0
  24. package/dist/lib/neutral/TriggerStatus-WTFYUIG5.mjs +92 -0
  25. package/dist/lib/neutral/TriggerStatus-WTFYUIG5.mjs.map +7 -0
  26. package/dist/lib/neutral/ai-service-GJXMI5OI.mjs +22 -0
  27. package/dist/lib/neutral/ai-service-GJXMI5OI.mjs.map +7 -0
  28. package/dist/lib/neutral/app-graph-builder-XZJDJ3LJ.mjs +189 -0
  29. package/dist/lib/neutral/app-graph-builder-XZJDJ3LJ.mjs.map +7 -0
  30. package/dist/lib/neutral/blueprint-definition-VXJYQ5AE.mjs +32 -0
  31. package/dist/lib/neutral/blueprint-definition-VXJYQ5AE.mjs.map +7 -0
  32. package/dist/lib/neutral/blueprints/index.mjs +8 -0
  33. package/dist/lib/neutral/capabilities/index.mjs +35 -0
  34. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  35. package/dist/lib/{browser/chunk-WBG5PTSX.mjs → neutral/chunk-4CQZCMRP.mjs} +7 -5
  36. package/dist/lib/neutral/chunk-4CQZCMRP.mjs.map +7 -0
  37. package/dist/lib/neutral/chunk-5H6UJHLF.mjs +30 -0
  38. package/dist/lib/neutral/chunk-5H6UJHLF.mjs.map +7 -0
  39. package/dist/lib/neutral/chunk-CM3XQU2M.mjs +8 -0
  40. package/dist/lib/neutral/chunk-CM3XQU2M.mjs.map +7 -0
  41. package/dist/lib/neutral/chunk-F7VUML5H.mjs +104 -0
  42. package/dist/lib/neutral/chunk-F7VUML5H.mjs.map +7 -0
  43. package/dist/lib/neutral/chunk-VHPTYKYD.mjs +361 -0
  44. package/dist/lib/neutral/chunk-VHPTYKYD.mjs.map +7 -0
  45. package/dist/lib/neutral/companion-chat-provisioner-5N4HWNVJ.mjs +116 -0
  46. package/dist/lib/neutral/companion-chat-provisioner-5N4HWNVJ.mjs.map +7 -0
  47. package/dist/lib/neutral/components/index.mjs +2240 -0
  48. package/dist/lib/neutral/components/index.mjs.map +7 -0
  49. package/dist/lib/neutral/containers/index.mjs +27 -0
  50. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  51. package/dist/lib/neutral/create-chat-AEFFQYHT.mjs +71 -0
  52. package/dist/lib/neutral/create-chat-AEFFQYHT.mjs.map +7 -0
  53. package/dist/lib/neutral/create-object-VV5AO6D2.mjs +93 -0
  54. package/dist/lib/neutral/create-object-VV5AO6D2.mjs.map +7 -0
  55. package/dist/lib/neutral/edge-model-resolver-XDNBZ3US.mjs +21 -0
  56. package/dist/lib/neutral/edge-model-resolver-XDNBZ3US.mjs.map +7 -0
  57. package/dist/lib/neutral/ensure-companion-chat-EWF5GEZI.mjs +58 -0
  58. package/dist/lib/neutral/ensure-companion-chat-EWF5GEZI.mjs.map +7 -0
  59. package/dist/lib/neutral/hooks/index.mjs +930 -0
  60. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  61. package/dist/lib/neutral/index.mjs +32 -0
  62. package/dist/lib/neutral/local-model-resolver-I2BENFFS.mjs +24 -0
  63. package/dist/lib/neutral/local-model-resolver-I2BENFFS.mjs.map +7 -0
  64. package/dist/lib/neutral/markdown-KTBFOMFM.mjs +110 -0
  65. package/dist/lib/neutral/markdown-KTBFOMFM.mjs.map +7 -0
  66. package/dist/lib/neutral/meta.json +1 -0
  67. package/dist/lib/neutral/meta.mjs +12 -0
  68. package/dist/lib/neutral/migrations-LOYUJDNX.mjs +28 -0
  69. package/dist/lib/neutral/migrations-LOYUJDNX.mjs.map +7 -0
  70. package/dist/lib/neutral/on-create-space-Q2R7OSP6.mjs +19 -0
  71. package/dist/lib/neutral/on-create-space-Q2R7OSP6.mjs.map +7 -0
  72. package/dist/lib/neutral/operation-handler-SF36MOB5.mjs +13 -0
  73. package/dist/lib/neutral/operation-handler-SF36MOB5.mjs.map +7 -0
  74. package/dist/lib/neutral/operations/index.mjs +8 -0
  75. package/dist/lib/neutral/plugin.mjs +16 -0
  76. package/dist/lib/neutral/plugin.mjs.map +7 -0
  77. package/dist/lib/neutral/react-surface-JWFECJJ5.mjs +165 -0
  78. package/dist/lib/neutral/react-surface-JWFECJJ5.mjs.map +7 -0
  79. package/dist/lib/neutral/resolve-navigation-targets-VXBSWV5L.mjs +20 -0
  80. package/dist/lib/neutral/resolve-navigation-targets-VXBSWV5L.mjs.map +7 -0
  81. package/dist/lib/neutral/run-prompt-in-new-chat-ZMWSWGXL.mjs +100 -0
  82. package/dist/lib/neutral/run-prompt-in-new-chat-ZMWSWGXL.mjs.map +7 -0
  83. package/dist/lib/neutral/set-current-chat-ZFDCYK5I.mjs +48 -0
  84. package/dist/lib/neutral/set-current-chat-ZFDCYK5I.mjs.map +7 -0
  85. package/dist/lib/neutral/settings-W4BLWQ53.mjs +28 -0
  86. package/dist/lib/neutral/settings-W4BLWQ53.mjs.map +7 -0
  87. package/dist/lib/neutral/state-H3G7QCU6.mjs +28 -0
  88. package/dist/lib/neutral/state-H3G7QCU6.mjs.map +7 -0
  89. package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs +14 -0
  90. package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs.map +7 -0
  91. package/dist/lib/neutral/translations.mjs +173 -0
  92. package/dist/lib/neutral/translations.mjs.map +7 -0
  93. package/dist/lib/neutral/types/index.mjs +20 -0
  94. package/dist/lib/neutral/types/index.mjs.map +7 -0
  95. package/dist/lib/neutral/update-chat-name-ENXRUMDJ.mjs +54 -0
  96. package/dist/lib/neutral/update-chat-name-ENXRUMDJ.mjs.map +7 -0
  97. package/dist/types/src/AssistantPlugin.d.ts +3 -1
  98. package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
  99. package/dist/types/src/AssistantPlugin.node.d.ts +4 -0
  100. package/dist/types/src/AssistantPlugin.node.d.ts.map +1 -0
  101. package/dist/types/src/AssistantPlugin.test.d.ts +2 -0
  102. package/dist/types/src/AssistantPlugin.test.d.ts.map +1 -0
  103. package/dist/types/src/blueprints/assistant/blueprint.d.ts +4 -0
  104. package/dist/types/src/blueprints/assistant/blueprint.d.ts.map +1 -0
  105. package/dist/types/src/blueprints/assistant/blueprint.test.d.ts +2 -0
  106. package/dist/types/src/blueprints/assistant/blueprint.test.d.ts.map +1 -0
  107. package/dist/types/src/blueprints/assistant/index.d.ts +2 -0
  108. package/dist/types/src/blueprints/assistant/index.d.ts.map +1 -0
  109. package/dist/types/src/blueprints/index.d.ts +2 -0
  110. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  111. package/dist/types/src/capabilities/ai-service.d.ts +4 -2
  112. package/dist/types/src/capabilities/ai-service.d.ts.map +1 -1
  113. package/dist/types/src/capabilities/app-graph-builder.d.ts +4 -2
  114. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  115. package/dist/types/src/capabilities/blueprint-definition.d.ts +4 -6
  116. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -1
  117. package/dist/types/src/capabilities/companion-chat-provisioner.d.ts +9 -0
  118. package/dist/types/src/capabilities/companion-chat-provisioner.d.ts.map +1 -0
  119. package/dist/types/src/capabilities/create-object.d.ts +31 -0
  120. package/dist/types/src/capabilities/create-object.d.ts.map +1 -0
  121. package/dist/types/src/capabilities/edge-model-resolver.d.ts +6 -3
  122. package/dist/types/src/capabilities/edge-model-resolver.d.ts.map +1 -1
  123. package/dist/types/src/capabilities/index.d.ts +55 -13
  124. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  125. package/dist/types/src/capabilities/local-model-resolver.d.ts +9 -3
  126. package/dist/types/src/capabilities/local-model-resolver.d.ts.map +1 -1
  127. package/dist/types/src/capabilities/markdown.d.ts +5 -0
  128. package/dist/types/src/capabilities/markdown.d.ts.map +1 -0
  129. package/dist/types/src/capabilities/migrations.d.ts +5 -0
  130. package/dist/types/src/capabilities/migrations.d.ts.map +1 -0
  131. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  132. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  133. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  134. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  135. package/dist/types/src/capabilities/settings.d.ts +4 -2
  136. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  137. package/dist/types/src/capabilities/state.d.ts +19 -2
  138. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  139. package/dist/types/src/capabilities/toolkit.d.ts +4 -2
  140. package/dist/types/src/capabilities/toolkit.d.ts.map +1 -1
  141. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts +4 -4
  142. package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
  143. package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts +15 -0
  144. package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts.map +1 -0
  145. package/dist/types/src/components/AssistantSettings/index.d.ts +1 -1
  146. package/dist/types/src/components/AssistantSettings/index.d.ts.map +1 -1
  147. package/dist/types/src/components/Chat/Chat.d.ts +35 -42
  148. package/dist/types/src/components/Chat/Chat.d.ts.map +1 -1
  149. package/dist/types/src/components/Chat/context.d.ts +29 -0
  150. package/dist/types/src/components/Chat/context.d.ts.map +1 -0
  151. package/dist/types/src/components/Chat/events.d.ts +1 -1
  152. package/dist/types/src/components/Chat/events.d.ts.map +1 -1
  153. package/dist/types/src/components/ChatPrompt/ChatActions.d.ts +2 -1
  154. package/dist/types/src/components/ChatPrompt/ChatActions.d.ts.map +1 -1
  155. package/dist/types/src/components/ChatPrompt/ChatMcpErrors.d.ts +12 -0
  156. package/dist/types/src/components/ChatPrompt/ChatMcpErrors.d.ts.map +1 -0
  157. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts +8 -4
  158. package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts.map +1 -1
  159. package/dist/types/src/components/ChatPrompt/ChatOptions.stories.d.ts +19 -0
  160. package/dist/types/src/components/ChatPrompt/ChatOptions.stories.d.ts.map +1 -0
  161. package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts.map +1 -1
  162. package/dist/types/src/components/ChatPrompt/ChatPrompt.d.ts +28 -0
  163. package/dist/types/src/components/ChatPrompt/ChatPrompt.d.ts.map +1 -0
  164. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +3 -3
  165. package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
  166. package/dist/types/src/components/ChatPrompt/ChatStatus.d.ts +20 -0
  167. package/dist/types/src/components/ChatPrompt/ChatStatus.d.ts.map +1 -0
  168. package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts.map +1 -1
  169. package/dist/types/src/components/ChatPrompt/index.d.ts +3 -0
  170. package/dist/types/src/components/ChatPrompt/index.d.ts.map +1 -1
  171. package/dist/types/src/components/ChatThread/Anchor.stories.d.ts +14 -0
  172. package/dist/types/src/components/ChatThread/Anchor.stories.d.ts.map +1 -0
  173. package/dist/types/src/components/ChatThread/ChatThread.d.ts +8 -5
  174. package/dist/types/src/components/ChatThread/ChatThread.d.ts.map +1 -1
  175. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +9 -314
  176. package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
  177. package/dist/types/src/components/ChatThread/Link.d.ts.map +1 -1
  178. package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts +42 -0
  179. package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts.map +1 -0
  180. package/dist/types/src/components/ChatThread/registry.d.ts +19 -1
  181. package/dist/types/src/components/ChatThread/registry.d.ts.map +1 -1
  182. package/dist/types/src/components/ChatThread/sync.d.ts +45 -18
  183. package/dist/types/src/components/ChatThread/sync.d.ts.map +1 -1
  184. package/dist/types/src/components/ChatThread/tool-widget-state.d.ts +18 -0
  185. package/dist/types/src/components/ChatThread/tool-widget-state.d.ts.map +1 -0
  186. package/dist/types/src/components/ChatThread/tool-widget-state.test.d.ts +2 -0
  187. package/dist/types/src/components/ChatThread/tool-widget-state.test.d.ts.map +1 -0
  188. package/dist/types/src/components/ChatThread/widgets/FallbackWidget.d.ts +8 -0
  189. package/dist/types/src/components/ChatThread/widgets/FallbackWidget.d.ts.map +1 -0
  190. package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.d.ts +25 -0
  191. package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.d.ts.map +1 -0
  192. package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.stories.d.ts +18 -0
  193. package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.stories.d.ts.map +1 -0
  194. package/dist/types/src/components/ChatThread/widgets/ReferenceWidget.d.ts +9 -0
  195. package/dist/types/src/components/ChatThread/widgets/ReferenceWidget.d.ts.map +1 -0
  196. package/dist/types/src/components/ChatThread/widgets/SelectWidget.d.ts +14 -0
  197. package/dist/types/src/components/ChatThread/widgets/SelectWidget.d.ts.map +1 -0
  198. package/dist/types/src/components/ChatThread/widgets/StatsWidget.d.ts +12 -0
  199. package/dist/types/src/components/ChatThread/widgets/StatsWidget.d.ts.map +1 -0
  200. package/dist/types/src/components/ChatThread/widgets/StatusWidget.d.ts +12 -0
  201. package/dist/types/src/components/ChatThread/widgets/StatusWidget.d.ts.map +1 -0
  202. package/dist/types/src/components/ChatThread/widgets/SuggestionWidget.d.ts +11 -0
  203. package/dist/types/src/components/ChatThread/widgets/SuggestionWidget.d.ts.map +1 -0
  204. package/dist/types/src/components/ChatThread/widgets/SummaryWidget.d.ts +5 -0
  205. package/dist/types/src/components/ChatThread/widgets/SummaryWidget.d.ts.map +1 -0
  206. package/dist/types/src/components/ChatThread/widgets/ToolWidget.d.ts +9 -0
  207. package/dist/types/src/components/ChatThread/widgets/ToolWidget.d.ts.map +1 -0
  208. package/dist/types/src/components/ChatThread/widgets/ToolWidget.stories.d.ts +15 -0
  209. package/dist/types/src/components/ChatThread/widgets/ToolWidget.stories.d.ts.map +1 -0
  210. package/dist/types/src/components/ChatThread/widgets/defaults.d.ts +5 -0
  211. package/dist/types/src/components/ChatThread/widgets/defaults.d.ts.map +1 -0
  212. package/dist/types/src/components/ChatThread/widgets/index.d.ts +10 -0
  213. package/dist/types/src/components/ChatThread/widgets/index.d.ts.map +1 -0
  214. package/dist/types/src/components/ProcessTree/ProcessTree.d.ts +11 -0
  215. package/dist/types/src/components/ProcessTree/ProcessTree.d.ts.map +1 -0
  216. package/dist/types/src/components/ProcessTree/ProcessTree.stories.d.ts +7 -0
  217. package/dist/types/src/components/ProcessTree/ProcessTree.stories.d.ts.map +1 -0
  218. package/dist/types/src/components/ProcessTree/index.d.ts +2 -0
  219. package/dist/types/src/components/ProcessTree/index.d.ts.map +1 -0
  220. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts +6 -5
  221. package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
  222. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +1 -305
  223. package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
  224. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +12 -3
  225. package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
  226. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +2 -306
  227. package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -1
  228. package/dist/types/src/components/TemplateEditor/extensions/handlebars-extension.d.ts.map +1 -1
  229. package/dist/types/src/components/TemplateEditor/extensions/xml-extension.d.ts.map +1 -1
  230. package/dist/types/src/components/ToolBlock/ToolBlock.d.ts +5 -14
  231. package/dist/types/src/components/ToolBlock/ToolBlock.d.ts.map +1 -1
  232. package/dist/types/src/components/Toolbox/Toolbox.d.ts +14 -13
  233. package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
  234. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +1 -305
  235. package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
  236. package/dist/types/src/components/index.d.ts +3 -11
  237. package/dist/types/src/components/index.d.ts.map +1 -1
  238. package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts +6 -0
  239. package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts.map +1 -0
  240. package/dist/types/src/containers/AgentArticle/AgentArticle.stories.d.ts +21 -0
  241. package/dist/types/src/containers/AgentArticle/AgentArticle.stories.d.ts.map +1 -0
  242. package/dist/types/src/containers/AgentArticle/index.d.ts +2 -0
  243. package/dist/types/src/containers/AgentArticle/index.d.ts.map +1 -0
  244. package/dist/types/src/containers/AgentProperties/AgentProperties.d.ts +6 -0
  245. package/dist/types/src/containers/AgentProperties/AgentProperties.d.ts.map +1 -0
  246. package/dist/types/src/containers/AgentProperties/AgentProperties.stories.d.ts +16 -0
  247. package/dist/types/src/containers/AgentProperties/AgentProperties.stories.d.ts.map +1 -0
  248. package/dist/types/src/containers/AgentProperties/index.d.ts +2 -0
  249. package/dist/types/src/containers/AgentProperties/index.d.ts.map +1 -0
  250. package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts +6 -0
  251. package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts.map +1 -0
  252. package/dist/types/src/containers/BlueprintArticle/index.d.ts +2 -0
  253. package/dist/types/src/containers/BlueprintArticle/index.d.ts.map +1 -0
  254. package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts +18 -0
  255. package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts.map +1 -0
  256. package/dist/types/src/containers/ChatCompanion/index.d.ts +2 -0
  257. package/dist/types/src/containers/ChatCompanion/index.d.ts.map +1 -0
  258. package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts +12 -0
  259. package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts.map +1 -0
  260. package/dist/types/src/containers/ChatContainer/index.d.ts +2 -0
  261. package/dist/types/src/containers/ChatContainer/index.d.ts.map +1 -0
  262. package/dist/types/src/{components → containers/ChatDialog}/ChatDialog.d.ts +2 -3
  263. package/dist/types/src/containers/ChatDialog/ChatDialog.d.ts.map +1 -0
  264. package/dist/types/src/containers/ChatDialog/index.d.ts +2 -0
  265. package/dist/types/src/containers/ChatDialog/index.d.ts.map +1 -0
  266. package/dist/types/src/containers/RoutineArticle/RoutineArticle.d.ts +6 -0
  267. package/dist/types/src/containers/RoutineArticle/RoutineArticle.d.ts.map +1 -0
  268. package/dist/types/src/containers/RoutineArticle/index.d.ts +2 -0
  269. package/dist/types/src/containers/RoutineArticle/index.d.ts.map +1 -0
  270. package/dist/types/src/containers/RoutineList/RoutineList.d.ts +6 -0
  271. package/dist/types/src/containers/RoutineList/RoutineList.d.ts.map +1 -0
  272. package/dist/types/src/containers/RoutineList/RoutineList.stories.d.ts +21 -0
  273. package/dist/types/src/containers/RoutineList/RoutineList.stories.d.ts.map +1 -0
  274. package/dist/types/src/containers/RoutineList/index.d.ts +2 -0
  275. package/dist/types/src/containers/RoutineList/index.d.ts.map +1 -0
  276. package/dist/types/src/containers/TracePanel/TracePanel.d.ts +8 -0
  277. package/dist/types/src/containers/TracePanel/TracePanel.d.ts.map +1 -0
  278. package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts +13 -0
  279. package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts.map +1 -0
  280. package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts +19 -0
  281. package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts.map +1 -0
  282. package/dist/types/src/containers/TracePanel/dxn-extractor.test.d.ts +2 -0
  283. package/dist/types/src/containers/TracePanel/dxn-extractor.test.d.ts.map +1 -0
  284. package/dist/types/src/containers/TracePanel/execution-graph.d.ts +97 -0
  285. package/dist/types/src/containers/TracePanel/execution-graph.d.ts.map +1 -0
  286. package/dist/types/src/containers/TracePanel/execution-graph.test.d.ts +2 -0
  287. package/dist/types/src/containers/TracePanel/execution-graph.test.d.ts.map +1 -0
  288. package/dist/types/src/containers/TracePanel/index.d.ts +4 -0
  289. package/dist/types/src/containers/TracePanel/index.d.ts.map +1 -0
  290. package/dist/types/src/containers/TracePanel/testing/index.d.ts +3 -0
  291. package/dist/types/src/containers/TracePanel/testing/index.d.ts.map +1 -0
  292. package/dist/types/src/containers/TracePanel/testing/simulated-agent.d.ts +14 -0
  293. package/dist/types/src/containers/TracePanel/testing/simulated-agent.d.ts.map +1 -0
  294. package/dist/types/src/containers/TracePanel/testing/snapshot-playback.d.ts +12 -0
  295. package/dist/types/src/containers/TracePanel/testing/snapshot-playback.d.ts.map +1 -0
  296. package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts +5 -0
  297. package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts.map +1 -0
  298. package/dist/types/src/containers/TriggerStatus/index.d.ts +2 -0
  299. package/dist/types/src/containers/TriggerStatus/index.d.ts.map +1 -0
  300. package/dist/types/src/containers/index.d.ts +12 -0
  301. package/dist/types/src/containers/index.d.ts.map +1 -0
  302. package/dist/types/src/extensions/index.d.ts +2 -0
  303. package/dist/types/src/extensions/index.d.ts.map +1 -0
  304. package/dist/types/src/extensions/prompt-extension.d.ts +10 -0
  305. package/dist/types/src/extensions/prompt-extension.d.ts.map +1 -0
  306. package/dist/types/src/hooks/index.d.ts +2 -0
  307. package/dist/types/src/hooks/index.d.ts.map +1 -1
  308. package/dist/types/src/hooks/useBlueprintRegistry.d.ts +6 -6
  309. package/dist/types/src/hooks/useBlueprintRegistry.d.ts.map +1 -1
  310. package/dist/types/src/hooks/useChatKeymap.d.ts +12 -0
  311. package/dist/types/src/hooks/useChatKeymap.d.ts.map +1 -0
  312. package/dist/types/src/hooks/useChatProcessor.d.ts +8 -7
  313. package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
  314. package/dist/types/src/hooks/useChatServices.d.ts +5 -8
  315. package/dist/types/src/hooks/useChatServices.d.ts.map +1 -1
  316. package/dist/types/src/hooks/useChatToolbarActions.d.ts +3 -3
  317. package/dist/types/src/hooks/useChatToolbarActions.d.ts.map +1 -1
  318. package/dist/types/src/hooks/useContextBinder.d.ts +3 -2
  319. package/dist/types/src/hooks/useContextBinder.d.ts.map +1 -1
  320. package/dist/types/src/hooks/useContextObjects.d.ts +7 -7
  321. package/dist/types/src/hooks/useContextObjects.d.ts.map +1 -1
  322. package/dist/types/src/hooks/useDebug.d.ts +10 -0
  323. package/dist/types/src/hooks/useDebug.d.ts.map +1 -0
  324. package/dist/types/src/hooks/useFilteredTypes.d.ts +2 -3
  325. package/dist/types/src/hooks/useFilteredTypes.d.ts.map +1 -1
  326. package/dist/types/src/hooks/useFlush.d.ts +1 -1
  327. package/dist/types/src/hooks/useFlush.d.ts.map +1 -1
  328. package/dist/types/src/hooks/usePresets.d.ts +1 -1
  329. package/dist/types/src/hooks/usePresets.d.ts.map +1 -1
  330. package/dist/types/src/hooks/useReferencesProvider.d.ts.map +1 -1
  331. package/dist/types/src/index.d.ts +1 -6
  332. package/dist/types/src/index.d.ts.map +1 -1
  333. package/dist/types/src/meta.d.ts +4 -2
  334. package/dist/types/src/meta.d.ts.map +1 -1
  335. package/dist/types/src/operations/create-chat.d.ts +5 -0
  336. package/dist/types/src/operations/create-chat.d.ts.map +1 -0
  337. package/dist/types/src/operations/ensure-companion-chat.d.ts +5 -0
  338. package/dist/types/src/operations/ensure-companion-chat.d.ts.map +1 -0
  339. package/dist/types/src/operations/index.d.ts +3 -0
  340. package/dist/types/src/operations/index.d.ts.map +1 -0
  341. package/dist/types/src/operations/on-create-space.d.ts +5 -0
  342. package/dist/types/src/operations/on-create-space.d.ts.map +1 -0
  343. package/dist/types/src/operations/prompt.test.d.ts +2 -0
  344. package/dist/types/src/operations/prompt.test.d.ts.map +1 -0
  345. package/dist/types/src/operations/resolve-navigation-targets.d.ts +15 -0
  346. package/dist/types/src/operations/resolve-navigation-targets.d.ts.map +1 -0
  347. package/dist/types/src/operations/run-prompt-in-new-chat.d.ts +5 -0
  348. package/dist/types/src/operations/run-prompt-in-new-chat.d.ts.map +1 -0
  349. package/dist/types/src/operations/set-current-chat.d.ts +5 -0
  350. package/dist/types/src/operations/set-current-chat.d.ts.map +1 -0
  351. package/dist/types/src/operations/update-chat-name.d.ts +5 -0
  352. package/dist/types/src/operations/update-chat-name.d.ts.map +1 -0
  353. package/dist/types/src/plugin.d.ts +4 -0
  354. package/dist/types/src/plugin.d.ts.map +1 -0
  355. package/dist/types/src/processor/index.d.ts +0 -1
  356. package/dist/types/src/processor/index.d.ts.map +1 -1
  357. package/dist/types/src/processor/presets.d.ts +1 -1
  358. package/dist/types/src/processor/presets.d.ts.map +1 -1
  359. package/dist/types/src/processor/processor.d.ts +54 -31
  360. package/dist/types/src/processor/processor.d.ts.map +1 -1
  361. package/dist/types/src/queue-logger.d.ts.map +1 -1
  362. package/dist/types/src/testing/index.d.ts +1 -0
  363. package/dist/types/src/testing/index.d.ts.map +1 -1
  364. package/dist/types/src/testing/test-generator.d.ts.map +1 -1
  365. package/dist/types/src/testing/test-generator.test.d.ts +2 -0
  366. package/dist/types/src/testing/test-generator.test.d.ts.map +1 -0
  367. package/dist/types/src/testing/test-services.d.ts +1 -1
  368. package/dist/types/src/testing/test-services.d.ts.map +1 -1
  369. package/dist/types/src/testing/test-trace.d.ts +5 -0
  370. package/dist/types/src/testing/test-trace.d.ts.map +1 -0
  371. package/dist/types/src/testing/trace-timeline.test.d.ts +2 -0
  372. package/dist/types/src/testing/trace-timeline.test.d.ts.map +1 -0
  373. package/dist/types/src/translations.d.ts +2 -305
  374. package/dist/types/src/translations.d.ts.map +1 -1
  375. package/dist/types/src/types/Assistant.d.ts +33 -42
  376. package/dist/types/src/types/Assistant.d.ts.map +1 -1
  377. package/dist/types/src/types/AssistantCapabilities.d.ts +30 -0
  378. package/dist/types/src/types/AssistantCapabilities.d.ts.map +1 -0
  379. package/dist/types/src/types/AssistantEvents.d.ts +3 -0
  380. package/dist/types/src/types/AssistantEvents.d.ts.map +1 -0
  381. package/dist/types/src/types/AssistantOperation.d.ts +142 -0
  382. package/dist/types/src/types/AssistantOperation.d.ts.map +1 -0
  383. package/dist/types/src/types/Settings.d.ts +26 -0
  384. package/dist/types/src/types/Settings.d.ts.map +1 -0
  385. package/dist/types/src/types/index.d.ts +4 -2
  386. package/dist/types/src/types/index.d.ts.map +1 -1
  387. package/dist/types/src/types/service.d.ts +11 -260
  388. package/dist/types/src/types/service.d.ts.map +1 -1
  389. package/dist/types/tsconfig.tsbuildinfo +1 -1
  390. package/package.json +188 -109
  391. package/src/AssistantPlugin.node.ts +44 -0
  392. package/src/AssistantPlugin.test.ts +35 -0
  393. package/src/AssistantPlugin.ts +126 -0
  394. package/src/blueprints/assistant/blueprint.test.ts +46 -0
  395. package/src/blueprints/assistant/blueprint.ts +31 -0
  396. package/src/blueprints/assistant/index.ts +5 -0
  397. package/src/{components/ChatProgress → blueprints}/index.ts +1 -1
  398. package/src/capabilities/ai-service.ts +20 -17
  399. package/src/capabilities/app-graph-builder.ts +169 -185
  400. package/src/capabilities/blueprint-definition.ts +47 -57
  401. package/src/capabilities/companion-chat-provisioner.ts +163 -0
  402. package/src/capabilities/create-object.ts +107 -0
  403. package/src/capabilities/edge-model-resolver.ts +22 -14
  404. package/src/capabilities/index.ts +23 -15
  405. package/src/capabilities/local-model-resolver.ts +31 -13
  406. package/src/capabilities/markdown.ts +40 -0
  407. package/src/capabilities/migrations.ts +28 -0
  408. package/src/capabilities/operation-handler.ts +16 -0
  409. package/src/capabilities/react-surface.tsx +152 -72
  410. package/src/capabilities/settings.ts +24 -12
  411. package/src/capabilities/state.ts +26 -13
  412. package/src/capabilities/toolkit.ts +7 -11
  413. package/src/components/AssistantSettings/AssistantSettings.stories.tsx +35 -0
  414. package/src/components/AssistantSettings/AssistantSettings.tsx +30 -99
  415. package/src/components/AssistantSettings/index.ts +2 -2
  416. package/src/components/Chat/Chat.tsx +97 -258
  417. package/src/components/Chat/context.ts +39 -0
  418. package/src/components/Chat/events.ts +1 -1
  419. package/src/components/ChatPrompt/ChatActions.tsx +34 -14
  420. package/src/components/ChatPrompt/ChatMcpErrors.tsx +50 -0
  421. package/src/components/ChatPrompt/ChatOptions.stories.tsx +136 -0
  422. package/src/components/ChatPrompt/ChatOptions.tsx +294 -84
  423. package/src/components/ChatPrompt/ChatPrompt.tsx +182 -0
  424. package/src/components/ChatPrompt/ChatReferences.tsx +21 -12
  425. package/src/components/ChatPrompt/ChatStatus.tsx +123 -0
  426. package/src/components/ChatPrompt/ChatStatusIndicator.tsx +2 -2
  427. package/src/components/ChatPrompt/index.ts +3 -0
  428. package/src/components/ChatThread/Anchor.stories.tsx +95 -0
  429. package/src/components/ChatThread/ChatThread.stories.tsx +67 -73
  430. package/src/components/ChatThread/ChatThread.tsx +50 -24
  431. package/src/components/ChatThread/DEBUG.md +41 -0
  432. package/src/components/ChatThread/Link.tsx +3 -3
  433. package/src/components/ChatThread/MarkdownStream.stories.tsx +281 -0
  434. package/src/components/ChatThread/registry.tsx +171 -55
  435. package/src/components/ChatThread/sync.test.ts +193 -25
  436. package/src/components/ChatThread/sync.ts +94 -92
  437. package/src/components/ChatThread/testing/reasoning.md +25 -0
  438. package/src/components/ChatThread/testing/thinking.md +21 -0
  439. package/src/components/ChatThread/testing/thread-1.md +30 -0
  440. package/src/components/ChatThread/testing/{thread.md → thread-2.md} +19 -0
  441. package/src/components/ChatThread/testing/thread-widgets.md +79 -0
  442. package/src/components/ChatThread/tool-widget-state.test.ts +34 -0
  443. package/src/components/ChatThread/tool-widget-state.ts +48 -0
  444. package/src/components/ChatThread/widgets/FallbackWidget.tsx +26 -0
  445. package/src/components/ChatThread/widgets/ReasoningWidget.stories.tsx +68 -0
  446. package/src/components/ChatThread/widgets/ReasoningWidget.ts +133 -0
  447. package/src/components/ChatThread/widgets/ReferenceWidget.ts +33 -0
  448. package/src/components/ChatThread/widgets/SelectWidget.ts +39 -0
  449. package/src/components/ChatThread/widgets/StatsWidget.ts +31 -0
  450. package/src/components/ChatThread/widgets/StatusWidget.ts +53 -0
  451. package/src/components/ChatThread/widgets/SuggestionWidget.ts +41 -0
  452. package/src/components/ChatThread/widgets/SummaryWidget.tsx +27 -0
  453. package/src/components/ChatThread/widgets/ToolWidget.stories.tsx +55 -0
  454. package/src/components/ChatThread/widgets/ToolWidget.tsx +156 -0
  455. package/src/components/ChatThread/widgets/defaults.ts +8 -0
  456. package/src/components/ChatThread/widgets/index.ts +13 -0
  457. package/src/components/ProcessTree/ProcessTree.stories.tsx +83 -0
  458. package/src/components/ProcessTree/ProcessTree.tsx +119 -0
  459. package/src/components/ProcessTree/index.ts +5 -0
  460. package/src/components/TemplateEditor/TemplateEditor.stories.tsx +8 -12
  461. package/src/components/TemplateEditor/TemplateEditor.tsx +53 -42
  462. package/src/components/TemplateEditor/TemplateForm.stories.tsx +21 -15
  463. package/src/components/TemplateEditor/TemplateForm.tsx +111 -86
  464. package/src/components/TemplateEditor/extensions/handlebars-extension.ts +15 -10
  465. package/src/components/ToolBlock/ToolBlock.tsx +25 -24
  466. package/src/components/Toolbox/Toolbox.stories.tsx +16 -18
  467. package/src/components/Toolbox/Toolbox.tsx +73 -68
  468. package/src/components/index.ts +3 -7
  469. package/src/containers/AgentArticle/AgentArticle.stories.tsx +120 -0
  470. package/src/containers/AgentArticle/AgentArticle.tsx +200 -0
  471. package/src/containers/AgentArticle/index.ts +5 -0
  472. package/src/containers/AgentProperties/AgentProperties.stories.tsx +101 -0
  473. package/src/containers/AgentProperties/AgentProperties.tsx +127 -0
  474. package/src/containers/AgentProperties/index.ts +5 -0
  475. package/src/containers/BlueprintArticle/BlueprintArticle.tsx +29 -0
  476. package/src/containers/BlueprintArticle/index.ts +5 -0
  477. package/src/containers/ChatCompanion/ChatCompanion.tsx +129 -0
  478. package/src/containers/ChatCompanion/index.ts +5 -0
  479. package/src/containers/ChatContainer/ChatContainer.tsx +105 -0
  480. package/src/containers/ChatContainer/index.ts +5 -0
  481. package/src/{components → containers/ChatDialog}/ChatDialog.tsx +14 -23
  482. package/src/containers/ChatDialog/index.ts +5 -0
  483. package/src/containers/RoutineArticle/RoutineArticle.tsx +59 -0
  484. package/src/containers/RoutineArticle/index.ts +5 -0
  485. package/src/containers/RoutineList/RoutineList.stories.tsx +130 -0
  486. package/src/containers/RoutineList/RoutineList.tsx +50 -0
  487. package/src/containers/RoutineList/index.ts +5 -0
  488. package/src/containers/TracePanel/TracePanel.stories.tsx +285 -0
  489. package/src/containers/TracePanel/TracePanel.tsx +167 -0
  490. package/src/containers/TracePanel/dxn-extractor.test.ts +153 -0
  491. package/src/containers/TracePanel/dxn-extractor.ts +178 -0
  492. package/src/containers/TracePanel/execution-graph.test.ts +382 -0
  493. package/src/containers/TracePanel/execution-graph.ts +621 -0
  494. package/src/containers/TracePanel/index.ts +9 -0
  495. package/src/containers/TracePanel/testing/index.ts +6 -0
  496. package/src/containers/TracePanel/testing/simulated-agent.ts +114 -0
  497. package/src/containers/TracePanel/testing/snapshot-playback.ts +45 -0
  498. package/src/containers/TriggerStatus/TriggerStatus.tsx +129 -0
  499. package/src/containers/TriggerStatus/index.ts +5 -0
  500. package/src/containers/index.ts +16 -0
  501. package/src/extensions/index.ts +5 -0
  502. package/src/extensions/prompt-extension.ts +111 -0
  503. package/src/hooks/index.ts +2 -0
  504. package/src/hooks/useBlueprintRegistry.ts +37 -23
  505. package/src/hooks/useChatKeymap.ts +52 -0
  506. package/src/hooks/useChatProcessor.ts +41 -25
  507. package/src/hooks/useChatServices.ts +8 -33
  508. package/src/hooks/useChatToolbarActions.ts +34 -34
  509. package/src/hooks/useContextBinder.ts +20 -7
  510. package/src/hooks/useContextObjects.ts +16 -24
  511. package/src/hooks/useDebug.ts +38 -0
  512. package/src/hooks/useFilteredTypes.ts +8 -9
  513. package/src/hooks/usePresets.ts +2 -1
  514. package/src/hooks/useReferencesProvider.ts +2 -6
  515. package/src/index.ts +1 -7
  516. package/src/meta.ts +8 -5
  517. package/src/operations/create-chat.ts +78 -0
  518. package/src/operations/ensure-companion-chat.ts +63 -0
  519. package/src/operations/index.ts +15 -0
  520. package/src/operations/on-create-space.ts +24 -0
  521. package/src/operations/prompt.test.ts +77 -0
  522. package/src/operations/resolve-navigation-targets.ts +26 -0
  523. package/src/operations/run-prompt-in-new-chat.ts +112 -0
  524. package/src/operations/set-current-chat.ts +49 -0
  525. package/src/operations/update-chat-name.ts +61 -0
  526. package/src/plugin.ts +11 -0
  527. package/src/processor/index.ts +0 -1
  528. package/src/processor/presets.ts +11 -3
  529. package/src/processor/processor.test.ts +18 -50
  530. package/src/processor/processor.ts +231 -156
  531. package/src/queue-logger.ts +20 -6
  532. package/src/testing/data/trace-timeline.dx.json +4657 -0
  533. package/src/testing/index.ts +1 -0
  534. package/src/testing/test-generator.test.ts +81 -0
  535. package/src/testing/test-generator.ts +79 -42
  536. package/src/testing/test-sequence.ts +3 -3
  537. package/src/testing/test-services.ts +9 -7
  538. package/src/testing/test-trace.ts +20 -0
  539. package/src/testing/trace-timeline.conversations.json +1 -0
  540. package/src/testing/trace-timeline.test.ts +250 -0
  541. package/src/translations.ts +156 -89
  542. package/src/types/Assistant.ts +17 -54
  543. package/src/types/AssistantCapabilities.ts +35 -0
  544. package/src/types/AssistantEvents.ts +11 -0
  545. package/src/types/AssistantOperation.ts +128 -0
  546. package/src/types/Settings.ts +76 -0
  547. package/src/types/index.ts +8 -2
  548. package/src/types/service.ts +14 -11
  549. package/dist/lib/browser/BlueprintArticle-BWSLH6LG.mjs +0 -36
  550. package/dist/lib/browser/BlueprintArticle-BWSLH6LG.mjs.map +0 -7
  551. package/dist/lib/browser/ChatCompanion-U7VMDYO6.mjs +0 -159
  552. package/dist/lib/browser/ChatCompanion-U7VMDYO6.mjs.map +0 -7
  553. package/dist/lib/browser/ChatContainer-JXDZQ2EY.mjs +0 -79
  554. package/dist/lib/browser/ChatContainer-JXDZQ2EY.mjs.map +0 -7
  555. package/dist/lib/browser/ChatDialog-5NNGCRKJ.mjs +0 -90
  556. package/dist/lib/browser/ChatDialog-5NNGCRKJ.mjs.map +0 -7
  557. package/dist/lib/browser/PromptArticle-Q7JYGFQV.mjs +0 -59
  558. package/dist/lib/browser/PromptArticle-Q7JYGFQV.mjs.map +0 -7
  559. package/dist/lib/browser/ai-service-ERTZBTP3.mjs +0 -19
  560. package/dist/lib/browser/ai-service-ERTZBTP3.mjs.map +0 -7
  561. package/dist/lib/browser/app-graph-builder-ADZRPJ3V.mjs +0 -199
  562. package/dist/lib/browser/app-graph-builder-ADZRPJ3V.mjs.map +0 -7
  563. package/dist/lib/browser/blueprint-definition-7HPQPCL7.mjs +0 -12
  564. package/dist/lib/browser/chunk-5JZRYQZL.mjs +0 -229
  565. package/dist/lib/browser/chunk-5JZRYQZL.mjs.map +0 -7
  566. package/dist/lib/browser/chunk-7ZJIXQ2Y.mjs +0 -335
  567. package/dist/lib/browser/chunk-7ZJIXQ2Y.mjs.map +0 -7
  568. package/dist/lib/browser/chunk-F6YX2HHA.mjs +0 -262
  569. package/dist/lib/browser/chunk-F6YX2HHA.mjs.map +0 -7
  570. package/dist/lib/browser/chunk-LRE4VEZV.mjs +0 -16
  571. package/dist/lib/browser/chunk-LRE4VEZV.mjs.map +0 -7
  572. package/dist/lib/browser/chunk-SWEOO227.mjs +0 -1930
  573. package/dist/lib/browser/chunk-SWEOO227.mjs.map +0 -7
  574. package/dist/lib/browser/chunk-WBG5PTSX.mjs.map +0 -7
  575. package/dist/lib/browser/chunk-YDSFERCV.mjs +0 -178
  576. package/dist/lib/browser/chunk-YDSFERCV.mjs.map +0 -7
  577. package/dist/lib/browser/edge-model-resolver-O6OFYIO2.mjs +0 -18
  578. package/dist/lib/browser/edge-model-resolver-O6OFYIO2.mjs.map +0 -7
  579. package/dist/lib/browser/index.mjs +0 -374
  580. package/dist/lib/browser/index.mjs.map +0 -7
  581. package/dist/lib/browser/intent-resolver-Q7TX3MV7.mjs +0 -143
  582. package/dist/lib/browser/intent-resolver-Q7TX3MV7.mjs.map +0 -7
  583. package/dist/lib/browser/local-model-resolver-34MVHRKD.mjs +0 -17
  584. package/dist/lib/browser/local-model-resolver-34MVHRKD.mjs.map +0 -7
  585. package/dist/lib/browser/meta.json +0 -1
  586. package/dist/lib/browser/react-surface-VXXS6ZVC.mjs +0 -100
  587. package/dist/lib/browser/react-surface-VXXS6ZVC.mjs.map +0 -7
  588. package/dist/lib/browser/repair-3MZXLUHO.mjs +0 -44
  589. package/dist/lib/browser/repair-3MZXLUHO.mjs.map +0 -7
  590. package/dist/lib/browser/settings-HD5WA24I.mjs +0 -23
  591. package/dist/lib/browser/settings-HD5WA24I.mjs.map +0 -7
  592. package/dist/lib/browser/state-GG7Z3NB7.mjs +0 -25
  593. package/dist/lib/browser/state-GG7Z3NB7.mjs.map +0 -7
  594. package/dist/lib/browser/toolkit-VYDAWNE4.mjs +0 -17
  595. package/dist/lib/browser/toolkit-VYDAWNE4.mjs.map +0 -7
  596. package/dist/lib/browser/types/index.mjs +0 -19
  597. package/dist/lib/node-esm/BlueprintArticle-R2XYBRCK.mjs +0 -37
  598. package/dist/lib/node-esm/BlueprintArticle-R2XYBRCK.mjs.map +0 -7
  599. package/dist/lib/node-esm/ChatCompanion-O4T7PMMC.mjs +0 -160
  600. package/dist/lib/node-esm/ChatCompanion-O4T7PMMC.mjs.map +0 -7
  601. package/dist/lib/node-esm/ChatContainer-OWAZI6ZF.mjs +0 -80
  602. package/dist/lib/node-esm/ChatContainer-OWAZI6ZF.mjs.map +0 -7
  603. package/dist/lib/node-esm/ChatDialog-IBXH5FRI.mjs +0 -91
  604. package/dist/lib/node-esm/ChatDialog-IBXH5FRI.mjs.map +0 -7
  605. package/dist/lib/node-esm/PromptArticle-IV7O5UZ3.mjs +0 -60
  606. package/dist/lib/node-esm/PromptArticle-IV7O5UZ3.mjs.map +0 -7
  607. package/dist/lib/node-esm/ai-service-MUYLV3NT.mjs +0 -20
  608. package/dist/lib/node-esm/ai-service-MUYLV3NT.mjs.map +0 -7
  609. package/dist/lib/node-esm/app-graph-builder-26KXQ5ZY.mjs +0 -200
  610. package/dist/lib/node-esm/app-graph-builder-26KXQ5ZY.mjs.map +0 -7
  611. package/dist/lib/node-esm/blueprint-definition-S3DNWJFV.mjs +0 -13
  612. package/dist/lib/node-esm/chunk-CKW4IYLY.mjs +0 -336
  613. package/dist/lib/node-esm/chunk-CKW4IYLY.mjs.map +0 -7
  614. package/dist/lib/node-esm/chunk-E4JSYCWZ.mjs +0 -230
  615. package/dist/lib/node-esm/chunk-E4JSYCWZ.mjs.map +0 -7
  616. package/dist/lib/node-esm/chunk-GWKWQSEQ.mjs +0 -264
  617. package/dist/lib/node-esm/chunk-GWKWQSEQ.mjs.map +0 -7
  618. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +0 -11
  619. package/dist/lib/node-esm/chunk-VGSP5WMV.mjs +0 -180
  620. package/dist/lib/node-esm/chunk-VGSP5WMV.mjs.map +0 -7
  621. package/dist/lib/node-esm/chunk-WE6KTH72.mjs +0 -25
  622. package/dist/lib/node-esm/chunk-WE6KTH72.mjs.map +0 -7
  623. package/dist/lib/node-esm/chunk-YWFWT57N.mjs +0 -17
  624. package/dist/lib/node-esm/chunk-YWFWT57N.mjs.map +0 -7
  625. package/dist/lib/node-esm/chunk-ZNSHGWE4.mjs +0 -1931
  626. package/dist/lib/node-esm/chunk-ZNSHGWE4.mjs.map +0 -7
  627. package/dist/lib/node-esm/edge-model-resolver-2ARXDOYS.mjs +0 -19
  628. package/dist/lib/node-esm/edge-model-resolver-2ARXDOYS.mjs.map +0 -7
  629. package/dist/lib/node-esm/index.mjs +0 -375
  630. package/dist/lib/node-esm/index.mjs.map +0 -7
  631. package/dist/lib/node-esm/intent-resolver-LTKMN3YB.mjs +0 -144
  632. package/dist/lib/node-esm/intent-resolver-LTKMN3YB.mjs.map +0 -7
  633. package/dist/lib/node-esm/local-model-resolver-TP2NTSAX.mjs +0 -18
  634. package/dist/lib/node-esm/local-model-resolver-TP2NTSAX.mjs.map +0 -7
  635. package/dist/lib/node-esm/meta.json +0 -1
  636. package/dist/lib/node-esm/react-surface-AOBQALOV.mjs +0 -101
  637. package/dist/lib/node-esm/react-surface-AOBQALOV.mjs.map +0 -7
  638. package/dist/lib/node-esm/repair-RER5H7Y6.mjs +0 -45
  639. package/dist/lib/node-esm/repair-RER5H7Y6.mjs.map +0 -7
  640. package/dist/lib/node-esm/settings-YJQVKHH5.mjs +0 -24
  641. package/dist/lib/node-esm/settings-YJQVKHH5.mjs.map +0 -7
  642. package/dist/lib/node-esm/state-FSUHFMDM.mjs +0 -26
  643. package/dist/lib/node-esm/state-FSUHFMDM.mjs.map +0 -7
  644. package/dist/lib/node-esm/toolkit-HFJZLVIR.mjs +0 -18
  645. package/dist/lib/node-esm/toolkit-HFJZLVIR.mjs.map +0 -7
  646. package/dist/lib/node-esm/types/index.mjs +0 -20
  647. package/dist/types/src/capabilities/capabilities.d.ts +0 -10
  648. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  649. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  650. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  651. package/dist/types/src/capabilities/repair.d.ts +0 -4
  652. package/dist/types/src/capabilities/repair.d.ts.map +0 -1
  653. package/dist/types/src/components/BlueprintArticle.d.ts +0 -7
  654. package/dist/types/src/components/BlueprintArticle.d.ts.map +0 -1
  655. package/dist/types/src/components/ChatCompanion.d.ts +0 -13
  656. package/dist/types/src/components/ChatCompanion.d.ts.map +0 -1
  657. package/dist/types/src/components/ChatContainer.d.ts +0 -19
  658. package/dist/types/src/components/ChatContainer.d.ts.map +0 -1
  659. package/dist/types/src/components/ChatDialog.d.ts.map +0 -1
  660. package/dist/types/src/components/ChatProgress/ChatProgress.d.ts +0 -7
  661. package/dist/types/src/components/ChatProgress/ChatProgress.d.ts.map +0 -1
  662. package/dist/types/src/components/ChatProgress/index.d.ts +0 -2
  663. package/dist/types/src/components/ChatProgress/index.d.ts.map +0 -1
  664. package/dist/types/src/components/ChatThread/reducers.d.ts +0 -40
  665. package/dist/types/src/components/ChatThread/reducers.d.ts.map +0 -1
  666. package/dist/types/src/components/PromptArticle.d.ts +0 -7
  667. package/dist/types/src/components/PromptArticle.d.ts.map +0 -1
  668. package/dist/types/src/events.d.ts +0 -4
  669. package/dist/types/src/events.d.ts.map +0 -1
  670. package/dist/types/src/functions/analysis.d.ts +0 -5
  671. package/dist/types/src/functions/analysis.d.ts.map +0 -1
  672. package/dist/types/src/functions/index.d.ts +0 -4
  673. package/dist/types/src/functions/index.d.ts.map +0 -1
  674. package/dist/types/src/functions/object-list.d.ts +0 -10
  675. package/dist/types/src/functions/object-list.d.ts.map +0 -1
  676. package/dist/types/src/functions/object-load.d.ts +0 -8
  677. package/dist/types/src/functions/object-load.d.ts.map +0 -1
  678. package/dist/types/src/processor/update-name.d.ts +0 -10
  679. package/dist/types/src/processor/update-name.d.ts.map +0 -1
  680. package/dist/types/src/types/AssistantAction.d.ts +0 -129
  681. package/dist/types/src/types/AssistantAction.d.ts.map +0 -1
  682. package/dist/types/src/types/defs.d.ts +0 -2
  683. package/dist/types/src/types/defs.d.ts.map +0 -1
  684. package/src/AssistantPlugin.tsx +0 -164
  685. package/src/capabilities/capabilities.ts +0 -17
  686. package/src/capabilities/intent-resolver.ts +0 -135
  687. package/src/capabilities/repair.ts +0 -49
  688. package/src/components/BlueprintArticle.tsx +0 -29
  689. package/src/components/ChatCompanion.tsx +0 -166
  690. package/src/components/ChatContainer.tsx +0 -62
  691. package/src/components/ChatProgress/ChatProgress.tsx +0 -67
  692. package/src/components/ChatThread/reducers.ts +0 -151
  693. package/src/components/PromptArticle.tsx +0 -51
  694. package/src/events.ts +0 -11
  695. package/src/functions/analysis.ts +0 -22
  696. package/src/functions/index.ts +0 -7
  697. package/src/functions/object-list.ts +0 -49
  698. package/src/functions/object-load.ts +0 -46
  699. package/src/processor/update-name.ts +0 -56
  700. package/src/types/AssistantAction.ts +0 -79
  701. package/src/types/defs.ts +0 -5
  702. /package/dist/lib/{browser/blueprint-definition-7HPQPCL7.mjs.map → neutral/ChatContainer-X3R4ALHT.mjs.map} +0 -0
  703. /package/dist/lib/{browser/types → neutral/blueprints}/index.mjs.map +0 -0
  704. /package/dist/lib/{browser → neutral}/chunk-J5LGTIGS.mjs +0 -0
  705. /package/dist/lib/{browser → neutral}/chunk-J5LGTIGS.mjs.map +0 -0
  706. /package/dist/lib/{node-esm/types → neutral}/index.mjs.map +0 -0
  707. /package/dist/lib/{node-esm/blueprint-definition-S3DNWJFV.mjs.map → neutral/meta.mjs.map} +0 -0
  708. /package/dist/lib/{node-esm/chunk-HSLMI22Q.mjs.map → neutral/operations/index.mjs.map} +0 -0
@@ -1,1930 +0,0 @@
1
- import {
2
- AiChatProcessor,
3
- AiServicePresets
4
- } from "./chunk-F6YX2HHA.mjs";
5
- import {
6
- AssistantAction_exports,
7
- Assistant_exports,
8
- LLM_PROVIDERS,
9
- ServiceType
10
- } from "./chunk-5JZRYQZL.mjs";
11
- import {
12
- meta
13
- } from "./chunk-WBG5PTSX.mjs";
14
-
15
- // src/components/AssistantSettings/AssistantSettings.tsx
16
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
17
- import React from "react";
18
- import { DEFAULT_EDGE_MODELS, DEFAULT_OLLAMA_MODELS } from "@dxos/ai";
19
- import { Input, Select, useTranslation } from "@dxos/react-ui";
20
- import { ControlGroup, ControlItemInput, ControlPage, ControlSection } from "@dxos/react-ui-form";
21
- var DEFAULT_VALUE = "__default";
22
- var LLM_PROVIDER_LABELS = {
23
- edge: "DXOS",
24
- ollama: "Ollama",
25
- lmstudio: "LM Studio"
26
- };
27
- var AssistantSettings = ({ settings }) => {
28
- var _effect = _useSignals();
29
- try {
30
- const { t } = useTranslation(meta.id);
31
- return /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
32
- title: t("settings title", {
33
- ns: meta.id
34
- })
35
- }, /* @__PURE__ */ React.createElement(ControlGroup, null, /* @__PURE__ */ React.createElement(ControlItemInput, {
36
- title: t("settings custom prompts label")
37
- }, /* @__PURE__ */ React.createElement(Input.Switch, {
38
- checked: !!settings.customPrompts,
39
- onCheckedChange: (checked) => settings.customPrompts = checked
40
- })), /* @__PURE__ */ React.createElement(ControlItemInput, {
41
- title: t("settings llm provider label")
42
- }, /* @__PURE__ */ React.createElement(Select.Root, {
43
- value: settings.llmProvider ?? "edge",
44
- onValueChange: (value) => {
45
- settings.llmProvider = value === DEFAULT_VALUE ? void 0 : value;
46
- }
47
- }, /* @__PURE__ */ React.createElement(Select.TriggerButton, {
48
- placeholder: t("settings llm provider label")
49
- }), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, /* @__PURE__ */ React.createElement(Select.Option, {
50
- value: DEFAULT_VALUE
51
- }, t("settings default label")), LLM_PROVIDERS.map((model) => /* @__PURE__ */ React.createElement(Select.Option, {
52
- key: model,
53
- value: model
54
- }, LLM_PROVIDER_LABELS[model]))), /* @__PURE__ */ React.createElement(Select.Arrow, null))))), /* @__PURE__ */ React.createElement(ControlItemInput, {
55
- title: t("settings edge llm model label")
56
- }, /* @__PURE__ */ React.createElement(Select.Root, {
57
- value: settings.edgeModel ?? DEFAULT_VALUE,
58
- onValueChange: (value) => {
59
- settings.edgeModel = value === DEFAULT_VALUE ? void 0 : value;
60
- }
61
- }, /* @__PURE__ */ React.createElement(Select.TriggerButton, {
62
- placeholder: t("settings default llm model label")
63
- }), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, /* @__PURE__ */ React.createElement(Select.Option, {
64
- value: DEFAULT_VALUE
65
- }, t("settings default label")), DEFAULT_EDGE_MODELS.map((model) => /* @__PURE__ */ React.createElement(Select.Option, {
66
- key: model,
67
- value: model
68
- }, model))), /* @__PURE__ */ React.createElement(Select.Arrow, null))))), /* @__PURE__ */ React.createElement(ControlItemInput, {
69
- title: t("settings ollama llm model label")
70
- }, /* @__PURE__ */ React.createElement(Select.Root, {
71
- value: settings.ollamaModel ?? DEFAULT_VALUE,
72
- onValueChange: (value) => {
73
- settings.ollamaModel = value === DEFAULT_VALUE ? void 0 : value;
74
- }
75
- }, /* @__PURE__ */ React.createElement(Select.TriggerButton, {
76
- placeholder: t("settings default llm model label")
77
- }), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, /* @__PURE__ */ React.createElement(Select.Option, {
78
- value: DEFAULT_VALUE
79
- }, t("settings default label")), DEFAULT_OLLAMA_MODELS.map((model) => /* @__PURE__ */ React.createElement(Select.Option, {
80
- key: model,
81
- value: model
82
- }, model))), /* @__PURE__ */ React.createElement(Select.Arrow, null))))))));
83
- } finally {
84
- _effect.f();
85
- }
86
- };
87
-
88
- // src/hooks/useBlueprintRegistry.ts
89
- import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
90
- import { useSignalEffect } from "@preact/signals-react";
91
- import { useCallback, useMemo, useState } from "react";
92
- import { Capabilities } from "@dxos/app-framework";
93
- import { useCapabilities } from "@dxos/app-framework/react";
94
- import { Blueprint } from "@dxos/blueprints";
95
- import { Filter, Obj, Ref } from "@dxos/echo";
96
- import { useQuery } from "@dxos/react-client/echo";
97
- import { distinctBy, isNonNullable } from "@dxos/util";
98
- var useBlueprintRegistry = () => {
99
- const blueprints = useCapabilities(Capabilities.BlueprintDefinition);
100
- return useMemo(() => new Blueprint.Registry(blueprints), [
101
- blueprints
102
- ]);
103
- };
104
- var useBlueprints = ({ blueprintRegistry, space }) => {
105
- const staticBlueprints = useMemo(() => blueprintRegistry?.query() ?? [], [
106
- blueprintRegistry
107
- ]);
108
- const spaceBlueprints = useQuery(space, Filter.type(Blueprint.Blueprint));
109
- return useMemo(() => {
110
- const blueprints = distinctBy([
111
- ...staticBlueprints,
112
- ...spaceBlueprints
113
- ], (b) => b.key);
114
- blueprints.sort(({ name: a }, { name: b }) => a.localeCompare(b));
115
- return blueprints;
116
- }, [
117
- staticBlueprints,
118
- spaceBlueprints
119
- ]);
120
- };
121
- var useActiveBlueprints = ({ context }) => {
122
- var _effect = _useSignals2();
123
- try {
124
- const [active, setActive] = useState(/* @__PURE__ */ new Map());
125
- useSignalEffect(() => {
126
- const refs = [
127
- ...context?.blueprints.value ?? []
128
- ];
129
- const blueprints = refs.map((ref) => ref.target).filter(isNonNullable);
130
- setActive(new Map(blueprints.map((blueprint) => [
131
- blueprint.key,
132
- blueprint
133
- ])));
134
- });
135
- return active;
136
- } finally {
137
- _effect.f();
138
- }
139
- };
140
- var useBlueprintHandlers = ({ space, context, blueprintRegistry }) => {
141
- const onUpdateBlueprint = useCallback(async (key, checked) => {
142
- if (!context || !blueprintRegistry) {
143
- return;
144
- }
145
- const objects = await space.db.query(Filter.type(Blueprint.Blueprint)).run();
146
- let storedBlueprint = objects.find((blueprint) => blueprint.key === key);
147
- if (checked) {
148
- if (!storedBlueprint) {
149
- const blueprint = blueprintRegistry.getByKey(key);
150
- if (!blueprint) {
151
- return;
152
- }
153
- storedBlueprint = space.db.add(Obj.clone(blueprint));
154
- }
155
- await context.bind({
156
- blueprints: [
157
- Ref.make(storedBlueprint)
158
- ]
159
- });
160
- } else if (storedBlueprint) {
161
- await context.unbind({
162
- blueprints: [
163
- Ref.make(storedBlueprint)
164
- ]
165
- });
166
- }
167
- }, [
168
- space,
169
- context,
170
- blueprintRegistry
171
- ]);
172
- return {
173
- onUpdateBlueprint
174
- };
175
- };
176
-
177
- // src/hooks/useChatProcessor.ts
178
- import { RegistryContext } from "@effect-atom/atom-react";
179
- import { useContext, useMemo as useMemo2, useState as useState2 } from "react";
180
- import { AiConversation } from "@dxos/assistant";
181
- import { log } from "@dxos/log";
182
- import { useAsyncEffect } from "@dxos/react-ui";
183
- var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/hooks/useChatProcessor.ts";
184
- var useChatProcessor = ({ space, chat, preset, services, blueprintRegistry, settings }) => {
185
- const observableRegistry = useContext(RegistryContext);
186
- const [conversation, setConversation] = useState2();
187
- useAsyncEffect(async () => {
188
- if (!space || !chat) {
189
- return;
190
- }
191
- const queue = space.queues.get(chat.queue.dxn);
192
- const conversation2 = new AiConversation(queue);
193
- await conversation2.open();
194
- setConversation(conversation2);
195
- return () => {
196
- void conversation2.close();
197
- setConversation(void 0);
198
- };
199
- }, [
200
- space,
201
- chat?.queue.dxn.toString()
202
- ]);
203
- const processor = useMemo2(() => {
204
- if (!services || !conversation) {
205
- return void 0;
206
- }
207
- log("creating processor", {
208
- preset,
209
- model: preset?.model,
210
- settings
211
- }, {
212
- F: __dxlog_file,
213
- L: 65,
214
- S: void 0,
215
- C: (f, a) => f(...a)
216
- });
217
- return new AiChatProcessor(conversation, services, {
218
- observableRegistry,
219
- blueprintRegistry,
220
- model: preset?.model
221
- });
222
- }, [
223
- services,
224
- conversation,
225
- blueprintRegistry,
226
- preset
227
- ]);
228
- return processor;
229
- };
230
-
231
- // src/hooks/useChatServices.ts
232
- import * as Effect from "effect/Effect";
233
- import { useMemo as useMemo3 } from "react";
234
- import { useCapability } from "@dxos/app-framework/react";
235
- import { TracingService } from "@dxos/functions";
236
- import { TracingServiceExt } from "@dxos/functions-runtime";
237
- import { AutomationCapabilities } from "@dxos/plugin-automation";
238
- import { useClient } from "@dxos/react-client";
239
- var useChatServices = ({ space, chat }) => {
240
- const client = useClient();
241
- space ??= client.spaces.default;
242
- const runtimeResolver = useCapability(AutomationCapabilities.ComputeRuntime);
243
- return useMemo3(() => {
244
- const runtime2 = runtimeResolver.getRuntime(space.id);
245
- return () => runtime2.runPromise(Effect.gen(function* () {
246
- return yield* Effect.runtime().pipe(Effect.provide(chat?.traceQueue?.target ? TracingServiceExt.layerQueue(chat.traceQueue?.target) : TracingService.layerNoop));
247
- }));
248
- }, [
249
- space,
250
- chat?.traceQueue?.target
251
- ]);
252
- };
253
-
254
- // src/hooks/useChatToolbarActions.ts
255
- import { Atom } from "@effect-atom/atom-react";
256
- import * as Effect2 from "effect/Effect";
257
- import { useMemo as useMemo10 } from "react";
258
- import { createIntent } from "@dxos/app-framework";
259
- import { useIntentDispatcher } from "@dxos/app-framework/react";
260
- import { Filter as Filter5, Obj as Obj6, Query } from "@dxos/echo";
261
- import { invariant } from "@dxos/invariant";
262
- import { useQuery as useQuery4 } from "@dxos/react-client/echo";
263
- import { MenuBuilder, useMenuActions } from "@dxos/react-ui-menu";
264
-
265
- // src/components/index.ts
266
- import { lazy } from "react";
267
-
268
- // src/components/Chat/Chat.tsx
269
- import { useSignals as _useSignals12 } from "@preact-signals/safe-react/tracking";
270
- import { Prec } from "@codemirror/state";
271
- import { keymap } from "@codemirror/view";
272
- import { useAtomValue } from "@effect-atom/atom-react";
273
- import { createContext } from "@radix-ui/react-context";
274
- import * as Array2 from "effect/Array";
275
- import * as Option2 from "effect/Option";
276
- import React10, { useCallback as useCallback7, useEffect as useEffect6, useMemo as useMemo9, useRef as useRef3, useState as useState11 } from "react";
277
- import { Event } from "@dxos/async";
278
- import { Obj as Obj5 } from "@dxos/echo";
279
- import { useVoiceInput } from "@dxos/plugin-transcription";
280
- import { getSpace, useQueue } from "@dxos/react-client/echo";
281
- import { useIdentity } from "@dxos/react-client/halo";
282
- import { Input as Input2, useDynamicRef, useTranslation as useTranslation6 } from "@dxos/react-ui";
283
- import { ChatEditor } from "@dxos/react-ui-chat";
284
- import { MenuProvider, ToolbarMenu } from "@dxos/react-ui-menu";
285
- import { mx as mx5 } from "@dxos/react-ui-theme";
286
- import { Message } from "@dxos/types";
287
- import { isTruthy } from "@dxos/util";
288
-
289
- // src/hooks/useContextBinder.ts
290
- import { useState as useState3 } from "react";
291
- import { AiContextBinder } from "@dxos/assistant";
292
- import { useAsyncEffect as useAsyncEffect2 } from "@dxos/react-ui";
293
- var useContextBinder = (queue) => {
294
- const [binder, setBinder] = useState3();
295
- useAsyncEffect2(async () => {
296
- if (!queue) {
297
- return;
298
- }
299
- const binder2 = new AiContextBinder(queue);
300
- await binder2.open();
301
- setBinder(binder2);
302
- return () => {
303
- void binder2.close();
304
- };
305
- }, [
306
- queue
307
- ]);
308
- return binder;
309
- };
310
-
311
- // src/hooks/useContextObjects.ts
312
- import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
313
- import { useCallback as useCallback2 } from "react";
314
- import { Ref as Ref2 } from "@dxos/echo";
315
- import { log as log2 } from "@dxos/log";
316
- import { isNonNullable as isNonNullable2 } from "@dxos/util";
317
- var __dxlog_file2 = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/hooks/useContextObjects.ts";
318
- var useContextObjects = ({ space, context }) => {
319
- var _effect = _useSignals3();
320
- try {
321
- const objects = context?.objects.value.map((ref) => ref.target).filter(isNonNullable2) ?? [];
322
- const handleUpdateObject = useCallback2(async (dxn, checked) => {
323
- if (!space || !context) {
324
- return;
325
- }
326
- const id = dxn.asEchoDXN();
327
- const object = id && space.db.getObjectById(id.echoId);
328
- if (!object) {
329
- log2.warn("Object not found", {
330
- dxn,
331
- id
332
- }, {
333
- F: __dxlog_file2,
334
- L: 40,
335
- S: void 0,
336
- C: (f, a) => f(...a)
337
- });
338
- return;
339
- }
340
- const ref = Ref2.fromDXN(dxn);
341
- if (checked) {
342
- await context.bind({
343
- objects: [
344
- ref
345
- ]
346
- });
347
- } else {
348
- await context.unbind({
349
- objects: [
350
- ref
351
- ]
352
- });
353
- }
354
- }, [
355
- space,
356
- context
357
- ]);
358
- return {
359
- objects,
360
- onUpdateObject: handleUpdateObject
361
- };
362
- } finally {
363
- _effect.f();
364
- }
365
- };
366
-
367
- // src/hooks/useFilteredTypes.ts
368
- import * as Option from "effect/Option";
369
- import { useEffect, useState as useState4 } from "react";
370
- import { EntityKind, SystemTypeAnnotation, getTypeAnnotation } from "@dxos/echo/internal";
371
- var useFilteredTypes = (space) => {
372
- const [types, setTypes] = useState4([]);
373
- useEffect(() => {
374
- if (!space) {
375
- return;
376
- }
377
- return space.db.schemaRegistry.query().subscribe((query) => {
378
- const types2 = Array.from(new Set([
379
- ...space.db.graph.schemaRegistry.schemas,
380
- ...query.results
381
- ].filter((schema) => getTypeAnnotation(schema)?.kind !== EntityKind.Relation).filter((schema) => SystemTypeAnnotation.get(schema).pipe(Option.getOrElse(() => false)))));
382
- setTypes(types2);
383
- }, {
384
- fire: true
385
- });
386
- }, [
387
- space
388
- ]);
389
- return types;
390
- };
391
-
392
- // src/hooks/useFlush.ts
393
- import { useCallback as useCallback3, useRef, useState as useState5 } from "react";
394
- var useFlush = (space) => {
395
- const [state, setState] = useState5("idle");
396
- const resetTimer = useRef(null);
397
- const handleFlush = useCallback3(() => {
398
- if (!space) {
399
- return;
400
- }
401
- queueMicrotask(async () => {
402
- if (resetTimer.current) {
403
- clearTimeout(resetTimer.current);
404
- }
405
- setState("flushing");
406
- await space.db.flush();
407
- setState("flushed");
408
- resetTimer.current = setTimeout(() => {
409
- setState("idle");
410
- resetTimer.current = null;
411
- }, 1e3);
412
- });
413
- }, [
414
- space
415
- ]);
416
- return {
417
- state,
418
- handleFlush
419
- };
420
- };
421
-
422
- // src/hooks/useOnline.ts
423
- import { useState as useState6 } from "react";
424
- var useOnline = () => {
425
- const [online, setOnline] = useState6(true);
426
- return [
427
- online,
428
- setOnline
429
- ];
430
- };
431
-
432
- // src/hooks/usePresets.ts
433
- import { useCallback as useCallback4, useEffect as useEffect2, useMemo as useMemo4, useState as useState7 } from "react";
434
- var usePresets = (online) => {
435
- const [preset, setPreset] = useState7();
436
- const presets = useMemo4(() => AiServicePresets.filter((preset2) => online === (preset2.provider === "dxos-remote")), [
437
- online
438
- ]);
439
- const presetOptions = useMemo4(() => presets.map(({ id, model, label }) => ({
440
- id,
441
- label: label ?? model
442
- })), [
443
- presets
444
- ]);
445
- useEffect2(() => {
446
- setPreset(presets[0]);
447
- }, [
448
- presets
449
- ]);
450
- const handlePresetChange = useCallback4((id) => {
451
- const preset2 = presets.find((preset3) => preset3.id === id);
452
- if (preset2) {
453
- setPreset(preset2);
454
- }
455
- }, [
456
- presets
457
- ]);
458
- return {
459
- preset,
460
- presets: presetOptions,
461
- onPresetChange: handlePresetChange
462
- };
463
- };
464
-
465
- // src/hooks/useReferencesProvider.ts
466
- import { useMemo as useMemo5 } from "react";
467
- import { Capabilities as Capabilities2 } from "@dxos/app-framework";
468
- import { useCapabilities as useCapabilities2 } from "@dxos/app-framework/react";
469
- import { Filter as Filter2, Obj as Obj2 } from "@dxos/echo";
470
- var useReferencesProvider = (space) => {
471
- const blueprints = useCapabilities2(Capabilities2.BlueprintDefinition);
472
- return useMemo5(() => {
473
- if (!space) {
474
- return void 0;
475
- }
476
- return {
477
- getReferences: async ({ query }) => {
478
- const objects = await space.db.query(Filter2.everything()).run();
479
- return objects.filter((object) => stringMatch(query, Obj2.getLabel(object) ?? "")).filter((object) => !!Obj2.getDXN(object)).map((object) => ({
480
- uri: Obj2.getDXN(object).toString(),
481
- label: Obj2.getLabel(object) ?? ""
482
- }));
483
- },
484
- resolveReference: async ({ uri }) => {
485
- const object = await space.db.query(Filter2.id(uri)).first();
486
- return {
487
- uri,
488
- label: Obj2.getLabel(object) ?? ""
489
- };
490
- }
491
- };
492
- }, [
493
- space,
494
- blueprints
495
- ]);
496
- };
497
- var stringMatch = (query, label) => label.toLowerCase().startsWith(query.toLowerCase());
498
-
499
- // src/components/ChatPrompt/ChatActions.tsx
500
- import { useSignals as _useSignals4 } from "@preact-signals/safe-react/tracking";
501
- import React2 from "react";
502
- import { IconButton, useTranslation as useTranslation2 } from "@dxos/react-ui";
503
- import { mx } from "@dxos/react-ui-theme";
504
- var ChatActions = ({ classNames, children, microphone, recording, processing, onEvent }) => {
505
- var _effect = _useSignals4();
506
- try {
507
- const { t } = useTranslation2(meta.id);
508
- return /* @__PURE__ */ React2.createElement("div", {
509
- className: mx("flex items-center mie-1", classNames)
510
- }, children, /* @__PURE__ */ React2.createElement(IconButton, {
511
- disabled: !processing,
512
- variant: "ghost",
513
- icon: "ph--x--regular",
514
- iconOnly: true,
515
- label: t("cancel processing button"),
516
- onClick: () => onEvent?.({
517
- type: "cancel"
518
- })
519
- }), microphone && /* @__PURE__ */ React2.createElement(IconButton, {
520
- disabled: !processing,
521
- classNames: mx(recording && "bg-primary-500"),
522
- variant: "ghost",
523
- icon: "ph--microphone--regular",
524
- iconOnly: true,
525
- noTooltip: true,
526
- label: t("microphone button"),
527
- onMouseDown: () => onEvent?.({
528
- type: "record-start"
529
- }),
530
- onMouseUp: () => onEvent?.({
531
- type: "record-stop"
532
- }),
533
- onTouchStart: () => onEvent?.({
534
- type: "record-start"
535
- }),
536
- onTouchEnd: () => onEvent?.({
537
- type: "record-stop"
538
- })
539
- }));
540
- } finally {
541
- _effect.f();
542
- }
543
- };
544
-
545
- // src/components/ChatPrompt/ChatOptions.tsx
546
- import { useSignals as _useSignals5 } from "@preact-signals/safe-react/tracking";
547
- import React3, { useMemo as useMemo6, useState as useState8 } from "react";
548
- import { Filter as Filter3, Obj as Obj3, Type } from "@dxos/echo";
549
- import { useQuery as useQuery2 } from "@dxos/react-client/echo";
550
- import { Icon, IconButton as IconButton2, Popover, Select as Select2, useTranslation as useTranslation3 } from "@dxos/react-ui";
551
- import { Listbox, SearchList } from "@dxos/react-ui-searchlist";
552
- import { Tabs } from "@dxos/react-ui-tabs";
553
- var panelClassNames = "is-[calc(100dvw-.5rem)] sm:is-max md:is-72 max-is-[--text-content]";
554
- var ChatOptions = ({ space, context, blueprintRegistry, presets, preset, onPresetChange }) => {
555
- var _effect = _useSignals5();
556
- try {
557
- const { t } = useTranslation3(meta.id);
558
- return /* @__PURE__ */ React3.createElement("div", {
559
- role: "none",
560
- className: "flex p-2"
561
- }, /* @__PURE__ */ React3.createElement(Popover.Root, null, /* @__PURE__ */ React3.createElement(Popover.Trigger, {
562
- asChild: true
563
- }, /* @__PURE__ */ React3.createElement(IconButton2, {
564
- variant: "ghost",
565
- icon: "ph--plus--regular",
566
- iconOnly: true,
567
- label: t("context objects button")
568
- })), /* @__PURE__ */ React3.createElement(Popover.Portal, null, /* @__PURE__ */ React3.createElement(Popover.Content, {
569
- side: "top",
570
- classNames: panelClassNames
571
- }, /* @__PURE__ */ React3.createElement(Popover.Viewport, null, /* @__PURE__ */ React3.createElement(ObjectsPanel, {
572
- space,
573
- context
574
- })), /* @__PURE__ */ React3.createElement(Popover.Arrow, null)))), /* @__PURE__ */ React3.createElement(Popover.Root, null, /* @__PURE__ */ React3.createElement(Popover.Trigger, {
575
- asChild: true
576
- }, /* @__PURE__ */ React3.createElement(IconButton2, {
577
- variant: "ghost",
578
- icon: "ph--sliders-horizontal--regular",
579
- iconOnly: true,
580
- label: t("context settings button")
581
- })), /* @__PURE__ */ React3.createElement(Popover.Portal, null, /* @__PURE__ */ React3.createElement(Popover.Content, {
582
- side: "top",
583
- classNames: panelClassNames
584
- }, /* @__PURE__ */ React3.createElement(Popover.Viewport, null, /* @__PURE__ */ React3.createElement(Tabs.Root, {
585
- orientation: "horizontal",
586
- defaultValue: "blueprints",
587
- defaultActivePart: "list",
588
- tabIndex: -1
589
- }, /* @__PURE__ */ React3.createElement(Tabs.Viewport, {
590
- classNames: 'max-bs-[--radix-popover-content-available-height] grid grid-rows-[1fr_min-content] [&_[cmdk-root]]:contents [&_[role="tabpanel"]]:grid [&_[role="tabpanel"]]:grid-rows-[1fr_min-content] [&_[role="listbox"]]:min-bs-0 [&_[role="listbox"]]:overflow-y-auto [&_[role="tabpanel"]]:min-bs-0 [&_[role="tabpanel"]]:pli-cardSpacingChrome [&_[role="tabpanel"][data-state="active"]]:order-first [&_[role="tabpanel"][data-state="inactive"]]:hidden'
591
- }, /* @__PURE__ */ React3.createElement(Tabs.Tabpanel, {
592
- value: "blueprints",
593
- tabIndex: -1,
594
- classNames: "dx-focus-ring-inset"
595
- }, /* @__PURE__ */ React3.createElement(BlueprintsPanel, {
596
- blueprintRegistry,
597
- space,
598
- context
599
- })), /* @__PURE__ */ React3.createElement(Tabs.Tabpanel, {
600
- value: "model",
601
- tabIndex: -1,
602
- classNames: "dx-focus-ring-inset !pli-0"
603
- }, /* @__PURE__ */ React3.createElement(ModelsPanel, {
604
- presets,
605
- preset,
606
- onPresetChange
607
- })), /* @__PURE__ */ React3.createElement(Tabs.Tablist, {
608
- classNames: "sm:overflow-x-hidden justify-center p-[--dx-cardSpacingChrome] border-bs border-subduedSeparator order-last"
609
- }, /* @__PURE__ */ React3.createElement(Tabs.IconTab, {
610
- value: "blueprints",
611
- icon: "ph--blueprint--regular",
612
- label: t("blueprints in context title")
613
- }), /* @__PURE__ */ React3.createElement(Tabs.IconTab, {
614
- value: "model",
615
- label: t("chat model title"),
616
- icon: "ph--cpu--regular"
617
- }))))), /* @__PURE__ */ React3.createElement(Popover.Arrow, null)))));
618
- } finally {
619
- _effect.f();
620
- }
621
- };
622
- var BlueprintsPanel = ({ blueprintRegistry, space, context }) => {
623
- var _effect = _useSignals5();
624
- try {
625
- const { t } = useTranslation3(meta.id);
626
- const blueprints = useBlueprints({
627
- blueprintRegistry,
628
- space
629
- });
630
- const activeBlueprints = useActiveBlueprints({
631
- context
632
- });
633
- const { onUpdateBlueprint } = useBlueprintHandlers({
634
- space,
635
- context,
636
- blueprintRegistry
637
- });
638
- return /* @__PURE__ */ React3.createElement(SearchList.Root, null, /* @__PURE__ */ React3.createElement(SearchList.Content, {
639
- classNames: "plb-cardSpacingChrome"
640
- }, blueprints.map((blueprint) => {
641
- const isActive = activeBlueprints.has(blueprint.key);
642
- return /* @__PURE__ */ React3.createElement(SearchList.Item, {
643
- classNames: "flex items-center overflow-hidden",
644
- key: blueprint.key,
645
- value: blueprint.name,
646
- onSelect: () => onUpdateBlueprint?.(blueprint.key, !isActive)
647
- }, /* @__PURE__ */ React3.createElement("div", {
648
- className: "grow truncate"
649
- }, blueprint.name), /* @__PURE__ */ React3.createElement(Icon, {
650
- icon: "ph--check--regular",
651
- classNames: [
652
- !isActive && "invisible"
653
- ]
654
- }));
655
- })), /* @__PURE__ */ React3.createElement(SearchList.Input, {
656
- placeholder: t("search placeholder"),
657
- classNames: "mbe-cardSpacingChrome",
658
- autoFocus: true
659
- }));
660
- } finally {
661
- _effect.f();
662
- }
663
- };
664
- var ModelsPanel = ({ presets, preset, onPresetChange }) => {
665
- var _effect = _useSignals5();
666
- try {
667
- return /* @__PURE__ */ React3.createElement(Listbox.Root, {
668
- value: preset,
669
- onValueChange: onPresetChange,
670
- autoFocus: true
671
- }, presets?.map(({ id, label }) => {
672
- return /* @__PURE__ */ React3.createElement(Listbox.Option, {
673
- key: id,
674
- value: id
675
- }, /* @__PURE__ */ React3.createElement(Listbox.OptionLabel, null, label), /* @__PURE__ */ React3.createElement(Listbox.OptionIndicator, null));
676
- }));
677
- } finally {
678
- _effect.f();
679
- }
680
- };
681
- var ANY = "__any__";
682
- var ObjectsPanel = ({ space, context }) => {
683
- var _effect = _useSignals5();
684
- try {
685
- const { t } = useTranslation3(meta.id);
686
- const types = useFilteredTypes(space);
687
- const typenames = useMemo6(() => {
688
- const typenames2 = types.map((type) => {
689
- const typename2 = Type.getTypename(type);
690
- return {
691
- typename: typename2,
692
- label: t("typename label", {
693
- ns: typename2,
694
- defaultValue: typename2
695
- })
696
- };
697
- });
698
- typenames2.sort((a, b) => a.label.localeCompare(b.label));
699
- return typenames2;
700
- }, [
701
- types
702
- ]);
703
- const [typename, setTypename] = useState8(ANY);
704
- const anyFilter = useMemo6(() => Filter3.or(...typenames.map(({ typename: typename2 }) => Filter3.typename(typename2))), [
705
- typenames
706
- ]);
707
- const objects = useQuery2(space, typename === ANY ? anyFilter : Filter3.typename(typename));
708
- const { objects: contextObjects, onUpdateObject } = useContextObjects({
709
- space,
710
- context
711
- });
712
- return /* @__PURE__ */ React3.createElement(SearchList.Root, null, /* @__PURE__ */ React3.createElement(SearchList.Content, {
713
- classNames: "p-cardSpacingChrome [&:has([cmdk-list-sizer]:empty)]:plb-0"
714
- }, objects.length ? objects.map((object) => {
715
- const label = Obj3.getLabel(object) ?? Obj3.getTypename(object) ?? object.id;
716
- const isActive = contextObjects.findIndex((obj) => obj.id === object.id) !== -1;
717
- return /* @__PURE__ */ React3.createElement(SearchList.Item, {
718
- classNames: "flex items-center overflow-hidden",
719
- key: object.id,
720
- value: object.id,
721
- onSelect: () => onUpdateObject?.(Obj3.getDXN(object), !isActive)
722
- }, /* @__PURE__ */ React3.createElement("div", {
723
- className: "grow truncate"
724
- }, label), /* @__PURE__ */ React3.createElement(Icon, {
725
- icon: "ph--check--regular",
726
- classNames: [
727
- !isActive && "invisible"
728
- ]
729
- }));
730
- }) : /* @__PURE__ */ React3.createElement(SearchList.Item, null, t("no results"))), /* @__PURE__ */ React3.createElement("div", {
731
- role: "none",
732
- className: "grid grid-cols-[min-content_1fr] gap-2 pli-cardSpacingChrome mbe-cardSpacingChrome"
733
- }, /* @__PURE__ */ React3.createElement(Select2.Root, {
734
- value: typename === ANY ? void 0 : typename,
735
- onValueChange: setTypename
736
- }, /* @__PURE__ */ React3.createElement(Select2.TriggerButton, {
737
- density: "fine",
738
- placeholder: t("type filter placeholder")
739
- }), /* @__PURE__ */ React3.createElement(Select2.Portal, null, /* @__PURE__ */ React3.createElement(Select2.Content, null, /* @__PURE__ */ React3.createElement(Select2.ScrollUpButton, null), /* @__PURE__ */ React3.createElement(Select2.Viewport, null, /* @__PURE__ */ React3.createElement(Select2.Option, {
740
- value: ANY
741
- }, t("any type filter label")), typenames.map(({ typename: typename2, label }) => /* @__PURE__ */ React3.createElement(Select2.Option, {
742
- key: typename2,
743
- value: typename2
744
- }, label))), /* @__PURE__ */ React3.createElement(Select2.ScrollDownButton, null), /* @__PURE__ */ React3.createElement(Select2.Arrow, null)))), /* @__PURE__ */ React3.createElement(SearchList.Input, {
745
- placeholder: t("search placeholder"),
746
- classNames: "mbe-0",
747
- autoFocus: true
748
- })));
749
- } finally {
750
- _effect.f();
751
- }
752
- };
753
-
754
- // src/components/ChatPrompt/ChatPresets.tsx
755
- import { useSignals as _useSignals6 } from "@preact-signals/safe-react/tracking";
756
- import React4 from "react";
757
- import { Select as Select3 } from "@dxos/react-ui";
758
-
759
- // src/components/ChatPrompt/ChatReferences.tsx
760
- import { useSignals as _useSignals7 } from "@preact-signals/safe-react/tracking";
761
- import React5 from "react";
762
- import { Obj as Obj4 } from "@dxos/echo";
763
- import { IconButton as IconButton3, toLocalizedString, useTranslation as useTranslation4 } from "@dxos/react-ui";
764
- import { mx as mx2 } from "@dxos/react-ui-theme";
765
- var ChatReferences = ({ classNames, context, space }) => {
766
- var _effect = _useSignals7();
767
- try {
768
- const { t } = useTranslation4(meta.id);
769
- const { objects, onUpdateObject } = useContextObjects({
770
- space,
771
- context
772
- });
773
- return /* @__PURE__ */ React5.createElement("ul", {
774
- className: mx2("flex", classNames)
775
- }, objects.map((obj) => {
776
- const dxn = Obj4.getDXN(obj);
777
- const typename = Obj4.getTypename(obj);
778
- const label = Obj4.getLabel(obj) ?? (typename ? [
779
- "object name placeholder",
780
- {
781
- ns: typename
782
- }
783
- ] : obj.id);
784
- return /* @__PURE__ */ React5.createElement("li", {
785
- key: dxn.toString(),
786
- className: "dx-tag plb-0 pis-2 flex items-center",
787
- "data-hue": "neutral"
788
- }, toLocalizedString(label, t), /* @__PURE__ */ React5.createElement(IconButton3, {
789
- icon: "ph--x--bold",
790
- iconOnly: true,
791
- variant: "ghost",
792
- label: t("remove object in context label"),
793
- classNames: "p-0 hover:bg-transparent",
794
- size: 3,
795
- onClick: () => onUpdateObject?.(dxn, false)
796
- }));
797
- }));
798
- } finally {
799
- _effect.f();
800
- }
801
- };
802
-
803
- // src/components/ChatPrompt/ChatStatusIndicator.tsx
804
- import { useSignals as _useSignals8 } from "@preact-signals/safe-react/tracking";
805
- import React6, { useEffect as useEffect3, useState as useState9 } from "react";
806
- import { Tooltip, useTimeout } from "@dxos/react-ui";
807
- import { Spinner } from "@dxos/react-ui-sfx";
808
- import { mx as mx3 } from "@dxos/react-ui-theme";
809
- var period = 3e3;
810
- var ChatStatusIndicator = ({ classNames, preset, processing, error, ...props }) => {
811
- var _effect = _useSignals8();
812
- try {
813
- const [init, setInit] = useState9(false);
814
- useEffect3(() => setInit(false), [
815
- preset
816
- ]);
817
- useTimeout(async () => {
818
- setInit(true);
819
- }, period / 2, [
820
- preset
821
- ]);
822
- return /* @__PURE__ */ React6.createElement("div", {
823
- role: "none",
824
- className: mx3("relative flex", classNames)
825
- }, /* @__PURE__ */ React6.createElement(Spinner, {
826
- duration: period,
827
- state: !init ? "flash" : error ? "error" : processing ? "spin" : "pulse",
828
- ...props
829
- }), error && /* @__PURE__ */ React6.createElement(Tooltip.Trigger, {
830
- asChild: true,
831
- content: error.message
832
- }, /* @__PURE__ */ React6.createElement("div", {
833
- className: "absolute inset-0"
834
- })));
835
- } finally {
836
- _effect.f();
837
- }
838
- };
839
-
840
- // src/components/ChatThread/ChatThread.tsx
841
- import { useSignals as _useSignals11 } from "@preact-signals/safe-react/tracking";
842
- import React9, { forwardRef, useCallback as useCallback6, useEffect as useEffect5, useMemo as useMemo8 } from "react";
843
- import { PublicKey } from "@dxos/keys";
844
- import { useForwardedRef } from "@dxos/react-ui";
845
- import { MarkdownStream } from "@dxos/react-ui-components";
846
- import { mx as mx4 } from "@dxos/react-ui-theme";
847
- import { keyToFallback } from "@dxos/util";
848
-
849
- // src/components/ChatThread/registry.tsx
850
- import { useSignals as _useSignals10 } from "@preact-signals/safe-react/tracking";
851
- import React8 from "react";
852
- import { log as log3 } from "@dxos/log";
853
- import { ToggleContainer as ToggleContainer2 } from "@dxos/react-ui-components";
854
- import { PromptWidget, ReferenceWidget, SelectWidget, SuggestionWidget, SummaryWidget } from "@dxos/react-ui-components";
855
- import { getXmlTextChild } from "@dxos/react-ui-editor";
856
- import { Json as Json2 } from "@dxos/react-ui-syntax-highlighter";
857
- import { ContentBlock } from "@dxos/types";
858
-
859
- // src/components/ToolBlock/ToolBlock.tsx
860
- import { useSignals as _useSignals9 } from "@preact-signals/safe-react/tracking";
861
- import React7, { useCallback as useCallback5, useEffect as useEffect4, useMemo as useMemo7, useRef as useRef2, useState as useState10 } from "react";
862
- import { useTranslation as useTranslation5 } from "@dxos/react-ui";
863
- import { NumericTabs, TextCrawl, ToggleContainer } from "@dxos/react-ui-components";
864
- import { Json } from "@dxos/react-ui-syntax-highlighter";
865
- import { isNonNullable as isNonNullable3, safeParseJson } from "@dxos/util";
866
- var ToolBlock = ({ view, blocks = [] }) => {
867
- var _effect = _useSignals9();
868
- try {
869
- const { t } = useTranslation5(meta.id);
870
- const items = useMemo7(() => {
871
- let lastToolCall;
872
- const tools = [];
873
- return blocks.filter((block) => block._tag === "toolCall" || block._tag === "toolResult" || block._tag === "summary").map((block) => {
874
- switch (block._tag) {
875
- case "toolCall": {
876
- if (block.pending && lastToolCall?.block.toolCallId === block.toolCallId) {
877
- return null;
878
- }
879
- const tool = tools.find((tool2) => tool2.name === block.name);
880
- lastToolCall = {
881
- tool,
882
- block
883
- };
884
- return {
885
- title: tool?.description ?? [
886
- t("tool call label"),
887
- tool?.name
888
- ].join(" "),
889
- content: {
890
- ...block,
891
- input: safeParseJson(block.input)
892
- }
893
- };
894
- }
895
- case "toolResult": {
896
- if (block.error) {
897
- return {
898
- title: t("tool error label"),
899
- content: block
900
- };
901
- }
902
- const title = lastToolCall?.tool?.description ?? [
903
- t("tool result label"),
904
- lastToolCall?.tool?.name
905
- ].join(" ");
906
- lastToolCall = void 0;
907
- return {
908
- title,
909
- content: {
910
- ...block,
911
- result: safeParseJson(block.result)
912
- }
913
- };
914
- }
915
- case "summary": {
916
- if (!lastToolCall) {
917
- return null;
918
- }
919
- return {
920
- title: t("summary label"),
921
- content: block
922
- };
923
- }
924
- }
925
- }).filter(isNonNullable3);
926
- }, [
927
- blocks
928
- ]);
929
- const handleChangeOpen = useCallback5(() => {
930
- setTimeout(() => {
931
- view?.requestMeasure();
932
- }, 1e3);
933
- }, [
934
- view
935
- ]);
936
- if (!items.length) {
937
- return null;
938
- }
939
- return /* @__PURE__ */ React7.createElement(ToolContainer, {
940
- items,
941
- onChangeOpen: handleChangeOpen
942
- });
943
- } finally {
944
- _effect.f();
945
- }
946
- };
947
- ToolBlock.displayName = "ToolBlock";
948
- var ToolContainer = ({ items, onChangeOpen }) => {
949
- var _effect = _useSignals9();
950
- try {
951
- const tabsRef = useRef2(null);
952
- const [selected, setSelected] = useState10(0);
953
- const [open, setOpen] = useState10(false);
954
- useEffect4(() => {
955
- onChangeOpen?.(open);
956
- if (open) {
957
- tabsRef.current?.focus();
958
- }
959
- }, [
960
- open,
961
- onChangeOpen
962
- ]);
963
- const handleSelect = (index) => {
964
- setSelected(index);
965
- };
966
- return /* @__PURE__ */ React7.createElement(ToggleContainer.Root, {
967
- classNames: "mbs-2 is-full rounded-sm",
968
- open,
969
- onChangeOpen: setOpen
970
- }, /* @__PURE__ */ React7.createElement(ToggleContainer.Header, {
971
- classNames: "text-sm text-placeholder"
972
- }, /* @__PURE__ */ React7.createElement(TextCrawl, {
973
- key: "status-roll",
974
- lines: items.map((item) => item.title),
975
- autoAdvance: true,
976
- greedy: true
977
- })), /* @__PURE__ */ React7.createElement(ToggleContainer.Content, {
978
- classNames: "grid grid-cols-[32px_1fr]"
979
- }, /* @__PURE__ */ React7.createElement(NumericTabs, {
980
- ref: tabsRef,
981
- classNames: "p-1",
982
- length: items.length,
983
- selected,
984
- onSelect: handleSelect
985
- }), /* @__PURE__ */ React7.createElement(Json, {
986
- data: items[selected]?.content,
987
- classNames: "p-1 text-xs bg-transparent",
988
- replacer: {
989
- maxDepth: 3,
990
- maxArrayLen: 10,
991
- maxStringLen: 128
992
- }
993
- })));
994
- } finally {
995
- _effect.f();
996
- }
997
- };
998
-
999
- // src/components/ChatThread/registry.tsx
1000
- var __dxlog_file3 = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/components/ChatThread/registry.tsx";
1001
- var Fallback = ({ _tag, ...props }) => {
1002
- var _effect = _useSignals10();
1003
- try {
1004
- return /* @__PURE__ */ React8.createElement(ToggleContainer2.Root, {
1005
- classNames: "rounded-sm"
1006
- }, /* @__PURE__ */ React8.createElement(ToggleContainer2.Header, {
1007
- classNames: "bg-groupSurface"
1008
- }, _tag), /* @__PURE__ */ React8.createElement(ToggleContainer2.Content, {
1009
- classNames: "bg-modalSurface"
1010
- }, /* @__PURE__ */ React8.createElement(Json2, {
1011
- classNames: "!p-2 text-sm",
1012
- data: props
1013
- })));
1014
- } finally {
1015
- _effect.f();
1016
- }
1017
- };
1018
- var componentRegistry = {
1019
- //
1020
- // Widgets
1021
- //
1022
- ["prompt"]: {
1023
- block: true,
1024
- factory: ({ children }) => {
1025
- const text = getXmlTextChild(children);
1026
- return text ? new PromptWidget(text) : null;
1027
- }
1028
- },
1029
- ["reference"]: {
1030
- block: false,
1031
- factory: ({ children, ref }) => {
1032
- const text = getXmlTextChild(children);
1033
- return text && ref ? new ReferenceWidget(text, ref) : null;
1034
- }
1035
- },
1036
- ["select"]: {
1037
- block: true,
1038
- factory: ({ children }) => {
1039
- const options = children?.map((option) => option._tag === "option" && getXmlTextChild(option.children)).filter(Boolean);
1040
- return options?.length ? new SelectWidget(options) : null;
1041
- }
1042
- },
1043
- ["suggestion"]: {
1044
- block: true,
1045
- factory: ({ children }) => {
1046
- const text = getXmlTextChild(children);
1047
- return text ? new SuggestionWidget(text) : null;
1048
- }
1049
- },
1050
- ["summary"]: {
1051
- block: true,
1052
- factory: ({ children }) => {
1053
- const text = getXmlTextChild(children);
1054
- return text ? new SummaryWidget(text) : null;
1055
- }
1056
- },
1057
- //
1058
- // React
1059
- //
1060
- ["toolCall"]: {
1061
- block: true,
1062
- Component: ToolBlock
1063
- },
1064
- ["toolResult"]: {
1065
- block: true,
1066
- Component: Fallback
1067
- },
1068
- ["toolkit"]: {
1069
- block: true,
1070
- Component: Fallback
1071
- },
1072
- //
1073
- // Fallback
1074
- //
1075
- ["json"]: {
1076
- block: true,
1077
- Component: Fallback
1078
- }
1079
- };
1080
- var blockToMarkdown = (context, message, block) => {
1081
- let str = blockToMarkdownImpl(context, message, block);
1082
- if (str && !block.pending) {
1083
- return str += "\n";
1084
- }
1085
- return str;
1086
- };
1087
- var blockToMarkdownImpl = (context, message, block) => {
1088
- log3("blockToMarkdown", {
1089
- block: JSON.stringify(block)
1090
- }, {
1091
- F: __dxlog_file3,
1092
- L: 125,
1093
- S: void 0,
1094
- C: (f, a) => f(...a)
1095
- });
1096
- switch (block._tag) {
1097
- case "text": {
1098
- if (message.sender.role === "user") {
1099
- return `<prompt>${block.text}</prompt>`;
1100
- } else {
1101
- const text = block.text.trim();
1102
- if (text.length > 0) {
1103
- return text;
1104
- }
1105
- }
1106
- break;
1107
- }
1108
- case "reference": {
1109
- const dxn = block.reference.dxn;
1110
- return `<reference ref="${dxn.toString()}">${context.getObjectLabel(dxn)}</reference>`;
1111
- }
1112
- case "suggestion": {
1113
- if (block.pending) {
1114
- return;
1115
- }
1116
- return `<suggestion>${block.text}</suggestion>`;
1117
- }
1118
- case "select": {
1119
- if (block.pending || block.options.length === 0) {
1120
- return;
1121
- }
1122
- return `<select>${block.options.map((option) => `<option>${option}</option>`).join("")}</select>`;
1123
- }
1124
- case "toolCall": {
1125
- context.updateWidget(block.toolCallId, {
1126
- blocks: [
1127
- block
1128
- ]
1129
- });
1130
- return `<toolCall id="${block.toolCallId}" />`;
1131
- }
1132
- case "toolResult": {
1133
- context.updateWidget(block.toolCallId, ({ blocks = [] }) => ({
1134
- blocks: [
1135
- ...blocks,
1136
- block
1137
- ]
1138
- }));
1139
- break;
1140
- }
1141
- case "summary": {
1142
- return `<summary>${ContentBlock.createSummaryMessage(block)}</summary>`;
1143
- }
1144
- default: {
1145
- return `<json id="${message.id}">
1146
- ${JSON.stringify(block)}
1147
- </json>`;
1148
- }
1149
- }
1150
- };
1151
-
1152
- // src/components/ChatThread/sync.ts
1153
- import { log as log4 } from "@dxos/log";
1154
- var __dxlog_file4 = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/components/ChatThread/sync.ts";
1155
- var MessageThreadContext = class {
1156
- _widgetState;
1157
- constructor(_widgetState) {
1158
- this._widgetState = _widgetState;
1159
- }
1160
- updateWidget(id, value) {
1161
- this._widgetState?.updateWidget(id, value);
1162
- }
1163
- // TODO(burdon): Resolve from hypergraph.
1164
- getObjectLabel(_id) {
1165
- return "Object";
1166
- }
1167
- };
1168
- var MessageSyncer = class {
1169
- _model;
1170
- _blockRenderer;
1171
- _initialMessageId;
1172
- _currentMessageIndex = 0;
1173
- _currentBlockIndex = 0;
1174
- _currentBlockContent;
1175
- _context;
1176
- constructor(_model, _blockRenderer) {
1177
- this._model = _model;
1178
- this._blockRenderer = _blockRenderer;
1179
- this._context = new MessageThreadContext(this._model);
1180
- }
1181
- get context() {
1182
- return this._context;
1183
- }
1184
- reset() {
1185
- log4("reset", void 0, {
1186
- F: __dxlog_file4,
1187
- L: 64,
1188
- S: this,
1189
- C: (f, a) => f(...a)
1190
- });
1191
- this._initialMessageId = void 0;
1192
- this._currentMessageIndex = 0;
1193
- this._currentBlockIndex = 0;
1194
- this._currentBlockContent = void 0;
1195
- void this._model.reset("");
1196
- }
1197
- /**
1198
- * Syncs messages with the editor.
1199
- */
1200
- append(messages, flush = false) {
1201
- if (this._initialMessageId !== messages[0]?.id) {
1202
- this.reset();
1203
- this._initialMessageId = messages[0]?.id;
1204
- }
1205
- if (flush && this._model.view?.state.doc.length === 0) {
1206
- const buffer = [];
1207
- this.process(messages, (content2) => {
1208
- buffer.push(content2);
1209
- });
1210
- const content = buffer.join("");
1211
- this._model.view?.dispatch({
1212
- changes: [
1213
- {
1214
- from: 0,
1215
- to: this._model.view?.state.doc.length ?? 0,
1216
- insert: content
1217
- }
1218
- ],
1219
- selection: {
1220
- anchor: content.length
1221
- }
1222
- });
1223
- return true;
1224
- } else {
1225
- this.process(messages, (content) => {
1226
- void this._model.append(content);
1227
- });
1228
- return false;
1229
- }
1230
- }
1231
- process(messages, append) {
1232
- log4("sync", {
1233
- doc: this._model.view?.state.doc.length,
1234
- messages: messages.map((message) => message.blocks.length),
1235
- currentMessageIndex: this._currentMessageIndex,
1236
- currentBlockIndex: this._currentBlockIndex,
1237
- currentBlockContent: this._currentBlockContent
1238
- }, {
1239
- F: __dxlog_file4,
1240
- L: 105,
1241
- S: this,
1242
- C: (f, a) => f(...a)
1243
- });
1244
- let i = this._currentMessageIndex;
1245
- for (const message of messages.slice(this._currentMessageIndex)) {
1246
- if (i > this._currentMessageIndex) {
1247
- this._currentBlockIndex = 0;
1248
- }
1249
- this._currentMessageIndex = i;
1250
- let j = this._currentBlockIndex;
1251
- for (const block of message.blocks.slice(this._currentBlockIndex)) {
1252
- this._currentBlockIndex = j;
1253
- const currentBlockContent = this._blockRenderer(this._context, message, block);
1254
- if (currentBlockContent) {
1255
- let content = "";
1256
- if (this._currentBlockContent && currentBlockContent.startsWith(this._currentBlockContent)) {
1257
- content = currentBlockContent.slice(this._currentBlockContent.length);
1258
- } else {
1259
- content = currentBlockContent;
1260
- }
1261
- log4("append", {
1262
- message: i,
1263
- block: j,
1264
- content
1265
- }, {
1266
- F: __dxlog_file4,
1267
- L: 132,
1268
- S: this,
1269
- C: (f, a) => f(...a)
1270
- });
1271
- this._currentBlockContent = currentBlockContent;
1272
- append(content);
1273
- }
1274
- if (block.pending) {
1275
- return;
1276
- } else {
1277
- this._currentBlockContent = void 0;
1278
- this._currentBlockIndex++;
1279
- }
1280
- j++;
1281
- }
1282
- i++;
1283
- }
1284
- }
1285
- };
1286
-
1287
- // src/components/ChatThread/ChatThread.tsx
1288
- var ChatThread = /* @__PURE__ */ forwardRef(({ classNames, identity, messages = [], error, cursor = false, fadeIn = true, debug = false, onEvent }, forwardedRef) => {
1289
- var _effect = _useSignals11();
1290
- try {
1291
- const controllerRef = useForwardedRef(forwardedRef);
1292
- const controller = controllerRef.current;
1293
- const userHue = useMemo8(() => identity?.profile?.data?.hue || keyToFallback(identity?.identityKey ?? PublicKey.random()).hue, [
1294
- identity
1295
- ]);
1296
- useEffect5(() => {
1297
- controller?.scrollToBottom();
1298
- }, [
1299
- controller,
1300
- error
1301
- ]);
1302
- const syncer = useMemo8(() => controller && new MessageSyncer(controller, blockToMarkdown), [
1303
- controller
1304
- ]);
1305
- useEffect5(() => {
1306
- const reset = syncer?.append(messages, true);
1307
- if (reset) {
1308
- controller?.scrollToBottom("instant");
1309
- }
1310
- }, [
1311
- syncer,
1312
- messages
1313
- ]);
1314
- const handleEvent = useCallback6(({ type, value }) => {
1315
- switch (type) {
1316
- case "submit": {
1317
- value && onEvent?.({
1318
- type,
1319
- text: value
1320
- });
1321
- break;
1322
- }
1323
- }
1324
- }, [
1325
- onEvent
1326
- ]);
1327
- return /* @__PURE__ */ React9.createElement("div", {
1328
- role: "none",
1329
- className: mx4("flex bs-full is-full justify-center overflow-hidden", classNames),
1330
- style: {
1331
- "--user-fill": `var(--dx-${userHue}Fill)`
1332
- }
1333
- }, /* @__PURE__ */ React9.createElement(MarkdownStream, {
1334
- ref: controllerRef,
1335
- registry: componentRegistry,
1336
- cursor,
1337
- fadeIn,
1338
- debug,
1339
- onEvent: handleEvent
1340
- }));
1341
- } finally {
1342
- _effect.f();
1343
- }
1344
- });
1345
-
1346
- // src/components/Chat/Chat.tsx
1347
- var [ChatContextProvider, useChatContext] = createContext("Chat");
1348
- var ChatRoot = ({ children, chat, processor, onEvent, ...props }) => {
1349
- var _effect = _useSignals12();
1350
- try {
1351
- const [debug, setDebug] = useState11(false);
1352
- const pending = useAtomValue(processor.messages);
1353
- const streaming = useAtomValue(processor.streaming);
1354
- const lastPrompt = useRef3(void 0);
1355
- const queue = useQueue(chat?.queue.dxn);
1356
- const messages = useMemo9(() => {
1357
- const queueMessages = queue?.objects?.filter(Obj5.instanceOf(Message.Message)) ?? [];
1358
- return Array2.dedupeWith([
1359
- ...queueMessages,
1360
- ...pending
1361
- ], ({ id: a }, { id: b }) => a === b);
1362
- }, [
1363
- queue?.objects,
1364
- pending
1365
- ]);
1366
- const event = useMemo9(() => new Event(), []);
1367
- useEffect6(() => {
1368
- return event.on((ev) => {
1369
- switch (ev.type) {
1370
- case "toggle-debug": {
1371
- setDebug((current) => !current);
1372
- break;
1373
- }
1374
- case "submit": {
1375
- const text = ev.text.trim();
1376
- if (!streaming && text.length) {
1377
- lastPrompt.current = ev.text;
1378
- void processor.request({
1379
- message: text
1380
- });
1381
- }
1382
- break;
1383
- }
1384
- case "retry": {
1385
- if (!streaming) {
1386
- void processor.retry();
1387
- }
1388
- break;
1389
- }
1390
- case "cancel": {
1391
- if (streaming) {
1392
- void processor.cancel();
1393
- if (lastPrompt.current) {
1394
- event.emit({
1395
- type: "update-prompt",
1396
- text: lastPrompt.current
1397
- });
1398
- }
1399
- }
1400
- break;
1401
- }
1402
- }
1403
- onEvent?.(ev);
1404
- });
1405
- }, [
1406
- event,
1407
- processor,
1408
- streaming,
1409
- onEvent
1410
- ]);
1411
- const space = props.space ?? getSpace(chat);
1412
- return /* @__PURE__ */ React10.createElement(ChatContextProvider, {
1413
- debug,
1414
- event,
1415
- space,
1416
- chat,
1417
- messages,
1418
- processor,
1419
- ...props
1420
- }, children);
1421
- } finally {
1422
- _effect.f();
1423
- }
1424
- };
1425
- ChatRoot.displayName = "Chat.Root";
1426
- var ChatViewport = ({ classNames, children }) => {
1427
- var _effect = _useSignals12();
1428
- try {
1429
- return /* @__PURE__ */ React10.createElement("div", {
1430
- role: "none",
1431
- className: mx5("flex flex-col bs-full is-full", classNames)
1432
- }, children);
1433
- } finally {
1434
- _effect.f();
1435
- }
1436
- };
1437
- var ChatPrompt = ({ classNames, outline, settings = true, placeholder, expandable, online, presets, preset, onPresetChange, onOnlineChange }) => {
1438
- var _effect = _useSignals12();
1439
- try {
1440
- const { t } = useTranslation6(meta.id);
1441
- const { space, processor, event } = useChatContext(ChatPrompt.displayName);
1442
- const error = useAtomValue(processor.error).pipe(Option2.getOrUndefined);
1443
- const streaming = useAtomValue(processor.streaming);
1444
- const active = useAtomValue(processor.active);
1445
- const activeRef = useDynamicRef(active);
1446
- const editorRef = useRef3(null);
1447
- const [recordingState, setRecordingState] = useState11(false);
1448
- useEffect6(() => {
1449
- return event.on((event2) => {
1450
- switch (event2.type) {
1451
- case "update-prompt":
1452
- if (!editorRef.current?.getText()?.length) {
1453
- editorRef.current?.setText(event2.text);
1454
- editorRef.current?.focus();
1455
- }
1456
- break;
1457
- case "record-start":
1458
- setRecordingState(true);
1459
- break;
1460
- case "record-stop":
1461
- setRecordingState(false);
1462
- break;
1463
- }
1464
- });
1465
- }, [
1466
- event
1467
- ]);
1468
- const { recording } = useVoiceInput({
1469
- active: recordingState,
1470
- onUpdate: (text) => {
1471
- editorRef.current?.setText(text);
1472
- editorRef.current?.focus();
1473
- }
1474
- });
1475
- const extensions = useMemo9(() => {
1476
- return [
1477
- Prec.highest(keymap.of([
1478
- {
1479
- key: "Mod-d",
1480
- preventDefault: true,
1481
- run: () => {
1482
- event.emit({
1483
- type: "toggle-debug"
1484
- });
1485
- return true;
1486
- }
1487
- },
1488
- {
1489
- key: "Mod-ArrowUp",
1490
- preventDefault: true,
1491
- run: () => {
1492
- event.emit({
1493
- type: "nav-previous"
1494
- });
1495
- return true;
1496
- },
1497
- shift: () => {
1498
- event.emit({
1499
- type: "thread-open"
1500
- });
1501
- return true;
1502
- }
1503
- },
1504
- {
1505
- key: "Mod-ArrowDown",
1506
- preventDefault: true,
1507
- run: () => {
1508
- event.emit({
1509
- type: "nav-next"
1510
- });
1511
- return true;
1512
- },
1513
- shift: () => {
1514
- event.emit({
1515
- type: "thread-close"
1516
- });
1517
- return true;
1518
- }
1519
- }
1520
- ]))
1521
- ].filter(isTruthy);
1522
- }, [
1523
- event,
1524
- expandable
1525
- ]);
1526
- const handleSubmit = useCallback7((text) => {
1527
- if (!activeRef.current) {
1528
- event.emit({
1529
- type: "submit",
1530
- text
1531
- });
1532
- return true;
1533
- }
1534
- }, [
1535
- event
1536
- ]);
1537
- const handleEvent = useCallback7((ev) => {
1538
- event.emit(ev);
1539
- }, [
1540
- event
1541
- ]);
1542
- return /* @__PURE__ */ React10.createElement("div", {
1543
- role: "group",
1544
- className: mx5("flex flex-col is-full density-fine", outline && "bg-groupSurface border border-subduedSeparator transition transition-border [&:has(.cm-content:focus)]:border-separator rounded", classNames)
1545
- }, /* @__PURE__ */ React10.createElement("div", {
1546
- role: "none",
1547
- className: "flex p-2 gap-2"
1548
- }, /* @__PURE__ */ React10.createElement(ChatStatusIndicator, {
1549
- classNames: "p-1",
1550
- preset,
1551
- error,
1552
- processing: streaming
1553
- }), /* @__PURE__ */ React10.createElement(ChatEditor, {
1554
- ref: editorRef,
1555
- autoFocus: true,
1556
- lineWrapping: true,
1557
- classNames: "col-span-2 pbs-0.5",
1558
- placeholder: placeholder ?? t("prompt placeholder"),
1559
- extensions,
1560
- onSubmit: handleSubmit
1561
- })), space && settings && /* @__PURE__ */ React10.createElement("div", {
1562
- role: "none",
1563
- className: "flex items-center overflow-hidden"
1564
- }, /* @__PURE__ */ React10.createElement(ChatOptions, {
1565
- space,
1566
- blueprintRegistry: processor.blueprintRegistry,
1567
- context: processor.context,
1568
- preset,
1569
- presets,
1570
- onPresetChange
1571
- }), /* @__PURE__ */ React10.createElement("div", {
1572
- role: "none",
1573
- className: "flex grow overflow-x-auto scrollbar-none"
1574
- }, /* @__PURE__ */ React10.createElement(ChatReferences, {
1575
- space,
1576
- context: processor.context
1577
- })), /* @__PURE__ */ React10.createElement(ChatActions, {
1578
- classNames: "col-span-2",
1579
- microphone: true,
1580
- recording,
1581
- processing: streaming,
1582
- onEvent: handleEvent
1583
- }, online !== void 0 && /* @__PURE__ */ React10.createElement(Input2.Root, null, /* @__PURE__ */ React10.createElement(Input2.Label, {
1584
- srOnly: true
1585
- }, t("online switch label")), /* @__PURE__ */ React10.createElement(Input2.Switch, {
1586
- classNames: "mli-2",
1587
- checked: online,
1588
- onCheckedChange: onOnlineChange
1589
- })))));
1590
- } finally {
1591
- _effect.f();
1592
- }
1593
- };
1594
- ChatPrompt.displayName = "Chat.Prompt";
1595
- var ChatThread2 = (props) => {
1596
- var _effect = _useSignals12();
1597
- try {
1598
- const { debug, event, messages, processor } = useChatContext(ChatThread2.displayName);
1599
- const identity = useIdentity();
1600
- const error = useAtomValue(processor.error).pipe(Option2.getOrUndefined);
1601
- const controllerRef = useRef3(null);
1602
- useEffect6(() => {
1603
- return event.on((event2) => {
1604
- switch (event2.type) {
1605
- case "submit":
1606
- case "scroll-to-bottom":
1607
- controllerRef.current?.scrollToBottom();
1608
- break;
1609
- case "nav-previous":
1610
- controllerRef.current?.navigatePrevious();
1611
- break;
1612
- case "nav-next":
1613
- controllerRef.current?.navigateNext();
1614
- break;
1615
- }
1616
- });
1617
- }, [
1618
- event
1619
- ]);
1620
- const handleEvent = useCallback7((ev) => {
1621
- event.emit(ev);
1622
- }, [
1623
- event
1624
- ]);
1625
- if (!identity) {
1626
- return null;
1627
- }
1628
- return /* @__PURE__ */ React10.createElement(ChatThread, {
1629
- ...props,
1630
- identity,
1631
- messages,
1632
- error,
1633
- debug,
1634
- onEvent: handleEvent,
1635
- ref: controllerRef
1636
- });
1637
- } finally {
1638
- _effect.f();
1639
- }
1640
- };
1641
- ChatThread2.displayName = "Chat.Thread";
1642
- var ChatToolbar = ({ classNames, companionTo }) => {
1643
- var _effect = _useSignals12();
1644
- try {
1645
- const { chat } = useChatContext(ChatToolbar.displayName);
1646
- const menu = useChatToolbarActions({
1647
- chat,
1648
- companionTo
1649
- });
1650
- return /* @__PURE__ */ React10.createElement(MenuProvider, {
1651
- ...menu,
1652
- attendableId: companionTo ? Obj5.getDXN(companionTo).toString() : chat ? Obj5.getDXN(chat).toString() : ""
1653
- }, /* @__PURE__ */ React10.createElement(ToolbarMenu, {
1654
- classNames,
1655
- textBlockWidth: true
1656
- }));
1657
- } finally {
1658
- _effect.f();
1659
- }
1660
- };
1661
- ChatToolbar.displayName = "Chat.Toolbar";
1662
- var Chat = {
1663
- Root: ChatRoot,
1664
- Viewport: ChatViewport,
1665
- Prompt: ChatPrompt,
1666
- Thread: ChatThread2,
1667
- Toolbar: ChatToolbar
1668
- };
1669
-
1670
- // src/components/Toolbox/Toolbox.tsx
1671
- import { useSignals as _useSignals13 } from "@preact-signals/safe-react/tracking";
1672
- import React11, { Fragment, useEffect as useEffect7, useState as useState12 } from "react";
1673
- import { Function } from "@dxos/functions";
1674
- import { log as log5 } from "@dxos/log";
1675
- import { Filter as Filter4, useQuery as useQuery3 } from "@dxos/react-client/echo";
1676
- import { useTranslation as useTranslation7 } from "@dxos/react-ui";
1677
- import { mx as mx6 } from "@dxos/react-ui-theme";
1678
- var __dxlog_file5 = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/components/Toolbox/Toolbox.tsx";
1679
- var Toolbox = ({ classNames, functions, services, blueprints, activeBlueprints }) => {
1680
- var _effect = _useSignals13();
1681
- try {
1682
- const { t } = useTranslation7(meta.id);
1683
- return /* @__PURE__ */ React11.createElement("div", {
1684
- className: mx6("flex flex-col overflow-y-auto box-content", classNames)
1685
- }, blueprints && blueprints.length > 0 && /* @__PURE__ */ React11.createElement(Section, {
1686
- title: "Blueprints",
1687
- items: blueprints.map(({ target }) => ({
1688
- name: target?.name ?? "",
1689
- description: target?.description ?? "",
1690
- subitems: target?.tools.map((toolId) => ({
1691
- name: `\u2219 ${safeToolId(toolId)}`
1692
- }))
1693
- }))
1694
- }), activeBlueprints && activeBlueprints.length > 0 && /* @__PURE__ */ React11.createElement(Section, {
1695
- title: "Blueprints",
1696
- items: activeBlueprints.map(({ target }) => ({
1697
- name: target?.name ?? "",
1698
- description: target?.description ?? "",
1699
- subitems: target?.tools.map((toolId) => ({
1700
- name: `\u2219 ${safeToolId(toolId)}`
1701
- }))
1702
- }))
1703
- }), services && services.length > 0 && /* @__PURE__ */ React11.createElement(Section, {
1704
- title: "Services",
1705
- items: services.map(({ service: { serviceId, name, description } }) => ({
1706
- name: name ?? serviceId,
1707
- description
1708
- }))
1709
- }), functions && functions.length > 0 && /* @__PURE__ */ React11.createElement(Section, {
1710
- title: "Functions",
1711
- items: functions.map(({ name, description }) => ({
1712
- name,
1713
- description
1714
- }))
1715
- }));
1716
- } finally {
1717
- _effect.f();
1718
- }
1719
- };
1720
- var Section = ({ title, items, striped }) => {
1721
- var _effect = _useSignals13();
1722
- try {
1723
- const stripeClassNames = "odd:bg-neutral-50 dark:odd:bg-neutral-800";
1724
- const gridClassNames = "grid grid-cols-[8rem_1fr]";
1725
- const subGridClassNames = mx6("col-span-full grid grid-cols-subgrid text-xs pli-2", striped && stripeClassNames);
1726
- return /* @__PURE__ */ React11.createElement("div", null, /* @__PURE__ */ React11.createElement("h1", {
1727
- className: "pli-2 text-sm"
1728
- }, title), /* @__PURE__ */ React11.createElement("div", {
1729
- className: gridClassNames
1730
- }, items.map(({ name, description, subitems }, i) => /* @__PURE__ */ React11.createElement(Fragment, {
1731
- key: i
1732
- }, name && /* @__PURE__ */ React11.createElement("div", {
1733
- className: subGridClassNames
1734
- }, /* @__PURE__ */ React11.createElement("div", {
1735
- className: "truncate text-primary-500"
1736
- }, name), /* @__PURE__ */ React11.createElement("div", {
1737
- className: "line-clamp-2"
1738
- }, description)), subitems?.map(({ name: name2, description: description2 }, i2) => /* @__PURE__ */ React11.createElement("div", {
1739
- key: i2,
1740
- className: mx6(subGridClassNames, striped && stripeClassNames)
1741
- }, /* @__PURE__ */ React11.createElement("div", {
1742
- className: "truncate"
1743
- }, name2), /* @__PURE__ */ React11.createElement("div", {
1744
- className: "line-clamp-3 text-subdued"
1745
- }, description2)))))));
1746
- } finally {
1747
- _effect.f();
1748
- }
1749
- };
1750
- var ToolboxContainer = ({ classNames, space, processor }) => {
1751
- var _effect = _useSignals13();
1752
- try {
1753
- const services = useQuery3(space, Filter4.type(ServiceType));
1754
- const [serviceTools, setServiceTools] = useState12([]);
1755
- useEffect7(() => {
1756
- log5("creating service tools...", {
1757
- services: services.length
1758
- }, {
1759
- F: __dxlog_file5,
1760
- L: 117,
1761
- S: void 0,
1762
- C: (f, a) => f(...a)
1763
- });
1764
- queueMicrotask(async () => {
1765
- });
1766
- }, [
1767
- services
1768
- ]);
1769
- const functions = useQuery3(space, Filter4.type(Function.Function));
1770
- return /* @__PURE__ */ React11.createElement(Toolbox, {
1771
- classNames,
1772
- blueprints: processor?.context.blueprints.value,
1773
- services: serviceTools,
1774
- functions
1775
- });
1776
- } finally {
1777
- _effect.f();
1778
- }
1779
- };
1780
- var safeToolId = (name) => {
1781
- return name.split("_").pop();
1782
- };
1783
-
1784
- // src/components/index.ts
1785
- var BlueprintArticle = lazy(() => import("./BlueprintArticle-BWSLH6LG.mjs"));
1786
- var ChatCompanion = lazy(() => import("./ChatCompanion-U7VMDYO6.mjs"));
1787
- var ChatContainer = lazy(() => import("./ChatContainer-JXDZQ2EY.mjs"));
1788
- var ChatDialog = lazy(() => import("./ChatDialog-5NNGCRKJ.mjs"));
1789
- var PromptArticle = lazy(() => import("./PromptArticle-Q7JYGFQV.mjs"));
1790
-
1791
- // src/hooks/useChatToolbarActions.ts
1792
- var __dxlog_file6 = "/__w/dxos/dxos/packages/plugins/plugin-assistant/src/hooks/useChatToolbarActions.ts";
1793
- var useChatToolbarActions = ({ chat, companionTo }) => {
1794
- const { dispatch } = useIntentDispatcher();
1795
- const { space } = useChatContext("useChatToolbarActions");
1796
- const query = companionTo ? Query.select(Filter5.id(companionTo.id)).targetOf(Assistant_exports.CompanionTo).source() : Query.select(Filter5.nothing());
1797
- const chats = useQuery4(space, query);
1798
- return useMenuActions(useMemo10(() => {
1799
- return Atom.make(() => {
1800
- const builder = MenuBuilder.make().root({
1801
- label: [
1802
- "chat toolbar title",
1803
- {
1804
- ns: meta.id
1805
- }
1806
- ]
1807
- }).action("new", {
1808
- label: [
1809
- "new thread button",
1810
- {
1811
- ns: meta.id
1812
- }
1813
- ],
1814
- icon: "ph--plus--regular",
1815
- type: "new"
1816
- }, () => dispatch(createIntent(AssistantAction_exports.SetCurrentChat, {
1817
- companionTo,
1818
- chat: void 0
1819
- })).pipe(Effect2.runPromise)).action("rename", {
1820
- label: [
1821
- "rename thread button",
1822
- {
1823
- ns: meta.id
1824
- }
1825
- ],
1826
- icon: "ph--magic-wand--regular",
1827
- type: "rename",
1828
- disabled: !chat
1829
- }, () => Effect2.gen(function* () {
1830
- invariant(chat, void 0, {
1831
- F: __dxlog_file6,
1832
- L: 68,
1833
- S: this,
1834
- A: [
1835
- "chat",
1836
- ""
1837
- ]
1838
- });
1839
- yield* dispatch(createIntent(AssistantAction_exports.UpdateChatName, {
1840
- chat
1841
- }));
1842
- }).pipe(Effect2.runPromise)).action("branch", {
1843
- label: [
1844
- "button branch thread",
1845
- {
1846
- ns: meta.id
1847
- }
1848
- ],
1849
- icon: "ph--git-branch--regular",
1850
- type: "branch",
1851
- disabled: true
1852
- }, () => {
1853
- });
1854
- if (chats.length > 0) {
1855
- builder.group("chats", {
1856
- label: [
1857
- "chat history label",
1858
- {
1859
- ns: meta.id
1860
- }
1861
- ],
1862
- icon: "ph--clock-counter-clockwise--regular",
1863
- selectCardinality: "single",
1864
- variant: "dropdownMenu"
1865
- }, (builder2) => {
1866
- chats.toSorted((a, b) => a.id.localeCompare(b.id)).forEach((chat2) => {
1867
- builder2.action(chat2.id, {
1868
- label: Obj6.getLabel(chat2) ?? [
1869
- "object name placeholder",
1870
- {
1871
- ns: Assistant_exports.Chat.typename
1872
- }
1873
- ]
1874
- }, () => Effect2.gen(function* () {
1875
- invariant(companionTo, void 0, {
1876
- F: __dxlog_file6,
1877
- L: 104,
1878
- S: this,
1879
- A: [
1880
- "companionTo",
1881
- ""
1882
- ]
1883
- });
1884
- yield* dispatch(createIntent(AssistantAction_exports.SetCurrentChat, {
1885
- companionTo,
1886
- chat: chat2
1887
- }));
1888
- }).pipe(Effect2.runPromise));
1889
- });
1890
- });
1891
- }
1892
- return builder.build();
1893
- });
1894
- }, [
1895
- chats.length,
1896
- space?.id,
1897
- companionTo?.id,
1898
- chat?.id,
1899
- dispatch
1900
- ]));
1901
- };
1902
-
1903
- export {
1904
- AssistantSettings,
1905
- useBlueprintRegistry,
1906
- useBlueprints,
1907
- useActiveBlueprints,
1908
- useBlueprintHandlers,
1909
- useChatProcessor,
1910
- useChatServices,
1911
- useChatToolbarActions,
1912
- useContextBinder,
1913
- useContextObjects,
1914
- useFilteredTypes,
1915
- useFlush,
1916
- useOnline,
1917
- usePresets,
1918
- useReferencesProvider,
1919
- ChatContextProvider,
1920
- useChatContext,
1921
- Chat,
1922
- Toolbox,
1923
- ToolboxContainer,
1924
- BlueprintArticle,
1925
- ChatCompanion,
1926
- ChatContainer,
1927
- ChatDialog,
1928
- PromptArticle
1929
- };
1930
- //# sourceMappingURL=chunk-SWEOO227.mjs.map