@draht/web-ui 2026.3.2-2

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 (372) hide show
  1. package/CHANGELOG.md +276 -0
  2. package/README.md +601 -0
  3. package/dist/ChatPanel.d.ts +28 -0
  4. package/dist/ChatPanel.d.ts.map +1 -0
  5. package/dist/ChatPanel.js +193 -0
  6. package/dist/ChatPanel.js.map +1 -0
  7. package/dist/app.css +2 -0
  8. package/dist/components/AgentInterface.d.ts +39 -0
  9. package/dist/components/AgentInterface.d.ts.map +1 -0
  10. package/dist/components/AgentInterface.js +384 -0
  11. package/dist/components/AgentInterface.js.map +1 -0
  12. package/dist/components/AttachmentTile.d.ts +12 -0
  13. package/dist/components/AttachmentTile.d.ts.map +1 -0
  14. package/dist/components/AttachmentTile.js +110 -0
  15. package/dist/components/AttachmentTile.js.map +1 -0
  16. package/dist/components/ConsoleBlock.d.ts +12 -0
  17. package/dist/components/ConsoleBlock.d.ts.map +1 -0
  18. package/dist/components/ConsoleBlock.js +81 -0
  19. package/dist/components/ConsoleBlock.js.map +1 -0
  20. package/dist/components/CustomProviderCard.d.ts +17 -0
  21. package/dist/components/CustomProviderCard.d.ts.map +1 -0
  22. package/dist/components/CustomProviderCard.js +112 -0
  23. package/dist/components/CustomProviderCard.js.map +1 -0
  24. package/dist/components/ExpandableSection.d.ts +15 -0
  25. package/dist/components/ExpandableSection.d.ts.map +1 -0
  26. package/dist/components/ExpandableSection.js +61 -0
  27. package/dist/components/ExpandableSection.js.map +1 -0
  28. package/dist/components/Input.d.ts +26 -0
  29. package/dist/components/Input.d.ts.map +1 -0
  30. package/dist/components/Input.js +57 -0
  31. package/dist/components/Input.js.map +1 -0
  32. package/dist/components/MessageEditor.d.ts +44 -0
  33. package/dist/components/MessageEditor.d.ts.map +1 -0
  34. package/dist/components/MessageEditor.js +418 -0
  35. package/dist/components/MessageEditor.js.map +1 -0
  36. package/dist/components/MessageList.d.ts +14 -0
  37. package/dist/components/MessageList.d.ts.map +1 -0
  38. package/dist/components/MessageList.js +104 -0
  39. package/dist/components/MessageList.js.map +1 -0
  40. package/dist/components/Messages.d.ts +95 -0
  41. package/dist/components/Messages.d.ts.map +1 -0
  42. package/dist/components/Messages.js +363 -0
  43. package/dist/components/Messages.js.map +1 -0
  44. package/dist/components/ProviderKeyInput.d.ts +16 -0
  45. package/dist/components/ProviderKeyInput.d.ts.map +1 -0
  46. package/dist/components/ProviderKeyInput.js +168 -0
  47. package/dist/components/ProviderKeyInput.js.map +1 -0
  48. package/dist/components/SandboxedIframe.d.ts +85 -0
  49. package/dist/components/SandboxedIframe.d.ts.map +1 -0
  50. package/dist/components/SandboxedIframe.js +518 -0
  51. package/dist/components/SandboxedIframe.js.map +1 -0
  52. package/dist/components/StreamingMessageContainer.d.ts +19 -0
  53. package/dist/components/StreamingMessageContainer.d.ts.map +1 -0
  54. package/dist/components/StreamingMessageContainer.js +117 -0
  55. package/dist/components/StreamingMessageContainer.js.map +1 -0
  56. package/dist/components/ThinkingBlock.d.ts +11 -0
  57. package/dist/components/ThinkingBlock.d.ts.map +1 -0
  58. package/dist/components/ThinkingBlock.js +56 -0
  59. package/dist/components/ThinkingBlock.js.map +1 -0
  60. package/dist/components/message-renderer-registry.d.ts +12 -0
  61. package/dist/components/message-renderer-registry.d.ts.map +1 -0
  62. package/dist/components/message-renderer-registry.js +12 -0
  63. package/dist/components/message-renderer-registry.js.map +1 -0
  64. package/dist/components/sandbox/ArtifactsRuntimeProvider.d.ts +35 -0
  65. package/dist/components/sandbox/ArtifactsRuntimeProvider.d.ts.map +1 -0
  66. package/dist/components/sandbox/ArtifactsRuntimeProvider.js +192 -0
  67. package/dist/components/sandbox/ArtifactsRuntimeProvider.js.map +1 -0
  68. package/dist/components/sandbox/AttachmentsRuntimeProvider.d.ts +17 -0
  69. package/dist/components/sandbox/AttachmentsRuntimeProvider.d.ts.map +1 -0
  70. package/dist/components/sandbox/AttachmentsRuntimeProvider.js +65 -0
  71. package/dist/components/sandbox/AttachmentsRuntimeProvider.js.map +1 -0
  72. package/dist/components/sandbox/ConsoleRuntimeProvider.d.ts +42 -0
  73. package/dist/components/sandbox/ConsoleRuntimeProvider.d.ts.map +1 -0
  74. package/dist/components/sandbox/ConsoleRuntimeProvider.js +159 -0
  75. package/dist/components/sandbox/ConsoleRuntimeProvider.js.map +1 -0
  76. package/dist/components/sandbox/FileDownloadRuntimeProvider.d.ts +30 -0
  77. package/dist/components/sandbox/FileDownloadRuntimeProvider.d.ts.map +1 -0
  78. package/dist/components/sandbox/FileDownloadRuntimeProvider.js +95 -0
  79. package/dist/components/sandbox/FileDownloadRuntimeProvider.js.map +1 -0
  80. package/dist/components/sandbox/RuntimeMessageBridge.d.ts +19 -0
  81. package/dist/components/sandbox/RuntimeMessageBridge.d.ts.map +1 -0
  82. package/dist/components/sandbox/RuntimeMessageBridge.js +74 -0
  83. package/dist/components/sandbox/RuntimeMessageBridge.js.map +1 -0
  84. package/dist/components/sandbox/RuntimeMessageRouter.d.ts +65 -0
  85. package/dist/components/sandbox/RuntimeMessageRouter.d.ts.map +1 -0
  86. package/dist/components/sandbox/RuntimeMessageRouter.js +166 -0
  87. package/dist/components/sandbox/RuntimeMessageRouter.js.map +1 -0
  88. package/dist/components/sandbox/SandboxRuntimeProvider.d.ts +48 -0
  89. package/dist/components/sandbox/SandboxRuntimeProvider.d.ts.map +1 -0
  90. package/dist/components/sandbox/SandboxRuntimeProvider.js +2 -0
  91. package/dist/components/sandbox/SandboxRuntimeProvider.js.map +1 -0
  92. package/dist/dialogs/ApiKeyPromptDialog.d.ts +15 -0
  93. package/dist/dialogs/ApiKeyPromptDialog.d.ts.map +1 -0
  94. package/dist/dialogs/ApiKeyPromptDialog.js +77 -0
  95. package/dist/dialogs/ApiKeyPromptDialog.js.map +1 -0
  96. package/dist/dialogs/AttachmentOverlay.d.ts +32 -0
  97. package/dist/dialogs/AttachmentOverlay.d.ts.map +1 -0
  98. package/dist/dialogs/AttachmentOverlay.js +576 -0
  99. package/dist/dialogs/AttachmentOverlay.js.map +1 -0
  100. package/dist/dialogs/CustomProviderDialog.d.ts +25 -0
  101. package/dist/dialogs/CustomProviderDialog.d.ts.map +1 -0
  102. package/dist/dialogs/CustomProviderDialog.js +270 -0
  103. package/dist/dialogs/CustomProviderDialog.js.map +1 -0
  104. package/dist/dialogs/ModelSelector.d.ts +27 -0
  105. package/dist/dialogs/ModelSelector.d.ts.map +1 -0
  106. package/dist/dialogs/ModelSelector.js +320 -0
  107. package/dist/dialogs/ModelSelector.js.map +1 -0
  108. package/dist/dialogs/PersistentStorageDialog.d.ts +17 -0
  109. package/dist/dialogs/PersistentStorageDialog.d.ts.map +1 -0
  110. package/dist/dialogs/PersistentStorageDialog.js +144 -0
  111. package/dist/dialogs/PersistentStorageDialog.js.map +1 -0
  112. package/dist/dialogs/ProvidersModelsTab.d.ts +20 -0
  113. package/dist/dialogs/ProvidersModelsTab.d.ts.map +1 -0
  114. package/dist/dialogs/ProvidersModelsTab.js +188 -0
  115. package/dist/dialogs/ProvidersModelsTab.js.map +1 -0
  116. package/dist/dialogs/SessionListDialog.d.ts +19 -0
  117. package/dist/dialogs/SessionListDialog.d.ts.map +1 -0
  118. package/dist/dialogs/SessionListDialog.js +152 -0
  119. package/dist/dialogs/SessionListDialog.js.map +1 -0
  120. package/dist/dialogs/SettingsDialog.d.ts +30 -0
  121. package/dist/dialogs/SettingsDialog.d.ts.map +1 -0
  122. package/dist/dialogs/SettingsDialog.js +222 -0
  123. package/dist/dialogs/SettingsDialog.js.map +1 -0
  124. package/dist/index.d.ts +67 -0
  125. package/dist/index.d.ts.map +1 -0
  126. package/dist/index.js +70 -0
  127. package/dist/index.js.map +1 -0
  128. package/dist/prompts/prompts.d.ts +11 -0
  129. package/dist/prompts/prompts.d.ts.map +1 -0
  130. package/dist/prompts/prompts.js +272 -0
  131. package/dist/prompts/prompts.js.map +1 -0
  132. package/dist/storage/app-storage.d.ts +33 -0
  133. package/dist/storage/app-storage.d.ts.map +1 -0
  134. package/dist/storage/app-storage.js +43 -0
  135. package/dist/storage/app-storage.js.map +1 -0
  136. package/dist/storage/backends/indexeddb-storage-backend.d.ts +27 -0
  137. package/dist/storage/backends/indexeddb-storage-backend.d.ts.map +1 -0
  138. package/dist/storage/backends/indexeddb-storage-backend.js +167 -0
  139. package/dist/storage/backends/indexeddb-storage-backend.js.map +1 -0
  140. package/dist/storage/store.d.ts +23 -0
  141. package/dist/storage/store.d.ts.map +1 -0
  142. package/dist/storage/store.js +24 -0
  143. package/dist/storage/store.js.map +1 -0
  144. package/dist/storage/stores/custom-providers-store.d.ts +25 -0
  145. package/dist/storage/stores/custom-providers-store.d.ts.map +1 -0
  146. package/dist/storage/stores/custom-providers-store.js +35 -0
  147. package/dist/storage/stores/custom-providers-store.js.map +1 -0
  148. package/dist/storage/stores/provider-keys-store.d.ts +14 -0
  149. package/dist/storage/stores/provider-keys-store.d.ts.map +1 -0
  150. package/dist/storage/stores/provider-keys-store.js +27 -0
  151. package/dist/storage/stores/provider-keys-store.js.map +1 -0
  152. package/dist/storage/stores/sessions-store.d.ts +32 -0
  153. package/dist/storage/stores/sessions-store.d.ts.map +1 -0
  154. package/dist/storage/stores/sessions-store.js +113 -0
  155. package/dist/storage/stores/sessions-store.js.map +1 -0
  156. package/dist/storage/stores/settings-store.d.ts +14 -0
  157. package/dist/storage/stores/settings-store.d.ts.map +1 -0
  158. package/dist/storage/stores/settings-store.js +28 -0
  159. package/dist/storage/stores/settings-store.js.map +1 -0
  160. package/dist/storage/types.d.ts +176 -0
  161. package/dist/storage/types.d.ts.map +1 -0
  162. package/dist/storage/types.js +2 -0
  163. package/dist/storage/types.js.map +1 -0
  164. package/dist/tools/artifacts/ArtifactElement.d.ts +9 -0
  165. package/dist/tools/artifacts/ArtifactElement.d.ts.map +1 -0
  166. package/dist/tools/artifacts/ArtifactElement.js +8 -0
  167. package/dist/tools/artifacts/ArtifactElement.js.map +1 -0
  168. package/dist/tools/artifacts/ArtifactPill.d.ts +4 -0
  169. package/dist/tools/artifacts/ArtifactPill.d.ts.map +1 -0
  170. package/dist/tools/artifacts/ArtifactPill.js +23 -0
  171. package/dist/tools/artifacts/ArtifactPill.js.map +1 -0
  172. package/dist/tools/artifacts/Console.d.ts +18 -0
  173. package/dist/tools/artifacts/Console.d.ts.map +1 -0
  174. package/dist/tools/artifacts/Console.js +92 -0
  175. package/dist/tools/artifacts/Console.js.map +1 -0
  176. package/dist/tools/artifacts/DocxArtifact.d.ts +22 -0
  177. package/dist/tools/artifacts/DocxArtifact.d.ts.map +1 -0
  178. package/dist/tools/artifacts/DocxArtifact.js +205 -0
  179. package/dist/tools/artifacts/DocxArtifact.js.map +1 -0
  180. package/dist/tools/artifacts/ExcelArtifact.d.ts +24 -0
  181. package/dist/tools/artifacts/ExcelArtifact.d.ts.map +1 -0
  182. package/dist/tools/artifacts/ExcelArtifact.js +213 -0
  183. package/dist/tools/artifacts/ExcelArtifact.js.map +1 -0
  184. package/dist/tools/artifacts/GenericArtifact.d.ts +19 -0
  185. package/dist/tools/artifacts/GenericArtifact.d.ts.map +1 -0
  186. package/dist/tools/artifacts/GenericArtifact.js +114 -0
  187. package/dist/tools/artifacts/GenericArtifact.js.map +1 -0
  188. package/dist/tools/artifacts/HtmlArtifact.d.ts +27 -0
  189. package/dist/tools/artifacts/HtmlArtifact.d.ts.map +1 -0
  190. package/dist/tools/artifacts/HtmlArtifact.js +187 -0
  191. package/dist/tools/artifacts/HtmlArtifact.js.map +1 -0
  192. package/dist/tools/artifacts/ImageArtifact.d.ts +20 -0
  193. package/dist/tools/artifacts/ImageArtifact.d.ts.map +1 -0
  194. package/dist/tools/artifacts/ImageArtifact.js +117 -0
  195. package/dist/tools/artifacts/ImageArtifact.js.map +1 -0
  196. package/dist/tools/artifacts/MarkdownArtifact.d.ts +19 -0
  197. package/dist/tools/artifacts/MarkdownArtifact.d.ts.map +1 -0
  198. package/dist/tools/artifacts/MarkdownArtifact.js +79 -0
  199. package/dist/tools/artifacts/MarkdownArtifact.js.map +1 -0
  200. package/dist/tools/artifacts/PdfArtifact.d.ts +25 -0
  201. package/dist/tools/artifacts/PdfArtifact.d.ts.map +1 -0
  202. package/dist/tools/artifacts/PdfArtifact.js +181 -0
  203. package/dist/tools/artifacts/PdfArtifact.js.map +1 -0
  204. package/dist/tools/artifacts/SvgArtifact.d.ts +18 -0
  205. package/dist/tools/artifacts/SvgArtifact.d.ts.map +1 -0
  206. package/dist/tools/artifacts/SvgArtifact.js +75 -0
  207. package/dist/tools/artifacts/SvgArtifact.js.map +1 -0
  208. package/dist/tools/artifacts/TextArtifact.d.ts +19 -0
  209. package/dist/tools/artifacts/TextArtifact.d.ts.map +1 -0
  210. package/dist/tools/artifacts/TextArtifact.js +141 -0
  211. package/dist/tools/artifacts/TextArtifact.js.map +1 -0
  212. package/dist/tools/artifacts/artifacts-tool-renderer.d.ts +11 -0
  213. package/dist/tools/artifacts/artifacts-tool-renderer.d.ts.map +1 -0
  214. package/dist/tools/artifacts/artifacts-tool-renderer.js +273 -0
  215. package/dist/tools/artifacts/artifacts-tool-renderer.js.map +1 -0
  216. package/dist/tools/artifacts/artifacts.d.ts +63 -0
  217. package/dist/tools/artifacts/artifacts.d.ts.map +1 -0
  218. package/dist/tools/artifacts/artifacts.js +664 -0
  219. package/dist/tools/artifacts/artifacts.js.map +1 -0
  220. package/dist/tools/artifacts/index.d.ts +8 -0
  221. package/dist/tools/artifacts/index.d.ts.map +1 -0
  222. package/dist/tools/artifacts/index.js +8 -0
  223. package/dist/tools/artifacts/index.js.map +1 -0
  224. package/dist/tools/extract-document.d.ts +24 -0
  225. package/dist/tools/extract-document.d.ts.map +1 -0
  226. package/dist/tools/extract-document.js +216 -0
  227. package/dist/tools/extract-document.js.map +1 -0
  228. package/dist/tools/index.d.ts +16 -0
  229. package/dist/tools/index.d.ts.map +1 -0
  230. package/dist/tools/index.js +33 -0
  231. package/dist/tools/index.js.map +1 -0
  232. package/dist/tools/javascript-repl.d.ts +44 -0
  233. package/dist/tools/javascript-repl.d.ts.map +1 -0
  234. package/dist/tools/javascript-repl.js +224 -0
  235. package/dist/tools/javascript-repl.js.map +1 -0
  236. package/dist/tools/renderer-registry.d.ts +23 -0
  237. package/dist/tools/renderer-registry.d.ts.map +1 -0
  238. package/dist/tools/renderer-registry.js +107 -0
  239. package/dist/tools/renderer-registry.js.map +1 -0
  240. package/dist/tools/renderers/BashRenderer.d.ts +10 -0
  241. package/dist/tools/renderers/BashRenderer.d.ts.map +1 -0
  242. package/dist/tools/renderers/BashRenderer.js +42 -0
  243. package/dist/tools/renderers/BashRenderer.js.map +1 -0
  244. package/dist/tools/renderers/CalculateRenderer.d.ts +10 -0
  245. package/dist/tools/renderers/CalculateRenderer.d.ts.map +1 -0
  246. package/dist/tools/renderers/CalculateRenderer.js +45 -0
  247. package/dist/tools/renderers/CalculateRenderer.js.map +1 -0
  248. package/dist/tools/renderers/DefaultRenderer.d.ts +6 -0
  249. package/dist/tools/renderers/DefaultRenderer.d.ts.map +1 -0
  250. package/dist/tools/renderers/DefaultRenderer.js +94 -0
  251. package/dist/tools/renderers/DefaultRenderer.js.map +1 -0
  252. package/dist/tools/renderers/GetCurrentTimeRenderer.d.ts +10 -0
  253. package/dist/tools/renderers/GetCurrentTimeRenderer.d.ts.map +1 -0
  254. package/dist/tools/renderers/GetCurrentTimeRenderer.js +72 -0
  255. package/dist/tools/renderers/GetCurrentTimeRenderer.js.map +1 -0
  256. package/dist/tools/types.d.ts +10 -0
  257. package/dist/tools/types.d.ts.map +1 -0
  258. package/dist/tools/types.js +2 -0
  259. package/dist/tools/types.js.map +1 -0
  260. package/dist/utils/attachment-utils.d.ts +19 -0
  261. package/dist/utils/attachment-utils.d.ts.map +1 -0
  262. package/dist/utils/attachment-utils.js +415 -0
  263. package/dist/utils/attachment-utils.js.map +1 -0
  264. package/dist/utils/auth-token.d.ts +3 -0
  265. package/dist/utils/auth-token.d.ts.map +1 -0
  266. package/dist/utils/auth-token.js +19 -0
  267. package/dist/utils/auth-token.js.map +1 -0
  268. package/dist/utils/format.d.ts +6 -0
  269. package/dist/utils/format.d.ts.map +1 -0
  270. package/dist/utils/format.js +47 -0
  271. package/dist/utils/format.js.map +1 -0
  272. package/dist/utils/i18n.d.ts +636 -0
  273. package/dist/utils/i18n.d.ts.map +1 -0
  274. package/dist/utils/i18n.js +418 -0
  275. package/dist/utils/i18n.js.map +1 -0
  276. package/dist/utils/model-discovery.d.ts +38 -0
  277. package/dist/utils/model-discovery.d.ts.map +1 -0
  278. package/dist/utils/model-discovery.js +243 -0
  279. package/dist/utils/model-discovery.js.map +1 -0
  280. package/dist/utils/proxy-utils.d.ts +45 -0
  281. package/dist/utils/proxy-utils.d.ts.map +1 -0
  282. package/dist/utils/proxy-utils.js +116 -0
  283. package/dist/utils/proxy-utils.js.map +1 -0
  284. package/dist/utils/test-sessions.d.ts +359 -0
  285. package/dist/utils/test-sessions.d.ts.map +1 -0
  286. package/dist/utils/test-sessions.js +2325 -0
  287. package/dist/utils/test-sessions.js.map +1 -0
  288. package/example/README.md +61 -0
  289. package/example/index.html +13 -0
  290. package/example/package.json +25 -0
  291. package/example/src/app.css +1 -0
  292. package/example/src/custom-messages.ts +99 -0
  293. package/example/src/env.d.ts +1 -0
  294. package/example/src/main.ts +421 -0
  295. package/example/tsconfig.json +23 -0
  296. package/example/vite.config.ts +6 -0
  297. package/package.json +53 -0
  298. package/scripts/count-prompt-tokens.ts +88 -0
  299. package/src/ChatPanel.ts +207 -0
  300. package/src/app.css +68 -0
  301. package/src/components/AgentInterface.ts +388 -0
  302. package/src/components/AttachmentTile.ts +107 -0
  303. package/src/components/ConsoleBlock.ts +72 -0
  304. package/src/components/CustomProviderCard.ts +100 -0
  305. package/src/components/ExpandableSection.ts +46 -0
  306. package/src/components/Input.ts +113 -0
  307. package/src/components/MessageEditor.ts +400 -0
  308. package/src/components/MessageList.ts +95 -0
  309. package/src/components/Messages.ts +383 -0
  310. package/src/components/ProviderKeyInput.ts +153 -0
  311. package/src/components/SandboxedIframe.ts +626 -0
  312. package/src/components/StreamingMessageContainer.ts +103 -0
  313. package/src/components/ThinkingBlock.ts +43 -0
  314. package/src/components/message-renderer-registry.ts +28 -0
  315. package/src/components/sandbox/ArtifactsRuntimeProvider.ts +219 -0
  316. package/src/components/sandbox/AttachmentsRuntimeProvider.ts +66 -0
  317. package/src/components/sandbox/ConsoleRuntimeProvider.ts +186 -0
  318. package/src/components/sandbox/FileDownloadRuntimeProvider.ts +110 -0
  319. package/src/components/sandbox/RuntimeMessageBridge.ts +82 -0
  320. package/src/components/sandbox/RuntimeMessageRouter.ts +216 -0
  321. package/src/components/sandbox/SandboxRuntimeProvider.ts +52 -0
  322. package/src/dialogs/ApiKeyPromptDialog.ts +75 -0
  323. package/src/dialogs/AttachmentOverlay.ts +636 -0
  324. package/src/dialogs/CustomProviderDialog.ts +274 -0
  325. package/src/dialogs/ModelSelector.ts +313 -0
  326. package/src/dialogs/PersistentStorageDialog.ts +144 -0
  327. package/src/dialogs/ProvidersModelsTab.ts +212 -0
  328. package/src/dialogs/SessionListDialog.ts +150 -0
  329. package/src/dialogs/SettingsDialog.ts +214 -0
  330. package/src/index.ts +119 -0
  331. package/src/prompts/prompts.ts +282 -0
  332. package/src/storage/app-storage.ts +60 -0
  333. package/src/storage/backends/indexeddb-storage-backend.ts +193 -0
  334. package/src/storage/store.ts +33 -0
  335. package/src/storage/stores/custom-providers-store.ts +62 -0
  336. package/src/storage/stores/provider-keys-store.ts +33 -0
  337. package/src/storage/stores/sessions-store.ts +136 -0
  338. package/src/storage/stores/settings-store.ts +34 -0
  339. package/src/storage/types.ts +206 -0
  340. package/src/tools/artifacts/ArtifactElement.ts +14 -0
  341. package/src/tools/artifacts/ArtifactPill.ts +26 -0
  342. package/src/tools/artifacts/Console.ts +93 -0
  343. package/src/tools/artifacts/DocxArtifact.ts +213 -0
  344. package/src/tools/artifacts/ExcelArtifact.ts +231 -0
  345. package/src/tools/artifacts/GenericArtifact.ts +117 -0
  346. package/src/tools/artifacts/HtmlArtifact.ts +195 -0
  347. package/src/tools/artifacts/ImageArtifact.ts +116 -0
  348. package/src/tools/artifacts/MarkdownArtifact.ts +82 -0
  349. package/src/tools/artifacts/PdfArtifact.ts +201 -0
  350. package/src/tools/artifacts/SvgArtifact.ts +78 -0
  351. package/src/tools/artifacts/TextArtifact.ts +148 -0
  352. package/src/tools/artifacts/artifacts-tool-renderer.ts +310 -0
  353. package/src/tools/artifacts/artifacts.ts +713 -0
  354. package/src/tools/artifacts/index.ts +7 -0
  355. package/src/tools/extract-document.ts +275 -0
  356. package/src/tools/index.ts +46 -0
  357. package/src/tools/javascript-repl.ts +293 -0
  358. package/src/tools/renderer-registry.ts +130 -0
  359. package/src/tools/renderers/BashRenderer.ts +52 -0
  360. package/src/tools/renderers/CalculateRenderer.ts +58 -0
  361. package/src/tools/renderers/DefaultRenderer.ts +103 -0
  362. package/src/tools/renderers/GetCurrentTimeRenderer.ts +92 -0
  363. package/src/tools/types.ts +15 -0
  364. package/src/utils/attachment-utils.ts +472 -0
  365. package/src/utils/auth-token.ts +22 -0
  366. package/src/utils/format.ts +42 -0
  367. package/src/utils/i18n.ts +653 -0
  368. package/src/utils/model-discovery.ts +277 -0
  369. package/src/utils/proxy-utils.ts +134 -0
  370. package/src/utils/test-sessions.ts +2357 -0
  371. package/tsconfig.build.json +20 -0
  372. package/tsconfig.json +7 -0
@@ -0,0 +1,418 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { icon } from "@mariozechner/mini-lit";
8
+ import { Button } from "@mariozechner/mini-lit/dist/Button.js";
9
+ import { Select } from "@mariozechner/mini-lit/dist/Select.js";
10
+ import { html, LitElement } from "lit";
11
+ import { customElement, property, state } from "lit/decorators.js";
12
+ import { createRef, ref } from "lit/directives/ref.js";
13
+ import { Brain, Loader2, Paperclip, Send, Sparkles, Square } from "lucide";
14
+ import { loadAttachment } from "../utils/attachment-utils.js";
15
+ import { i18n } from "../utils/i18n.js";
16
+ import "./AttachmentTile.js";
17
+ let MessageEditor = class MessageEditor extends LitElement {
18
+ _value = "";
19
+ textareaRef = createRef();
20
+ get value() {
21
+ return this._value;
22
+ }
23
+ set value(val) {
24
+ const oldValue = this._value;
25
+ this._value = val;
26
+ this.requestUpdate("value", oldValue);
27
+ }
28
+ isStreaming = false;
29
+ currentModel;
30
+ thinkingLevel = "off";
31
+ showAttachmentButton = true;
32
+ showModelSelector = true;
33
+ showThinkingSelector = true;
34
+ onInput;
35
+ onSend;
36
+ onAbort;
37
+ onModelSelect;
38
+ onThinkingChange;
39
+ onFilesChange;
40
+ attachments = [];
41
+ maxFiles = 10;
42
+ maxFileSize = 20 * 1024 * 1024; // 20MB
43
+ acceptedTypes = "image/*,application/pdf,.docx,.pptx,.xlsx,.xls,.txt,.md,.json,.xml,.html,.css,.js,.ts,.jsx,.tsx,.yml,.yaml";
44
+ processingFiles = false;
45
+ isDragging = false;
46
+ fileInputRef = createRef();
47
+ createRenderRoot() {
48
+ return this;
49
+ }
50
+ handleTextareaInput = (e) => {
51
+ const textarea = e.target;
52
+ this.value = textarea.value;
53
+ this.onInput?.(this.value);
54
+ };
55
+ handleKeyDown = (e) => {
56
+ if (e.key === "Enter" && !e.shiftKey) {
57
+ e.preventDefault();
58
+ if (!this.isStreaming && !this.processingFiles && (this.value.trim() || this.attachments.length > 0)) {
59
+ this.handleSend();
60
+ }
61
+ }
62
+ else if (e.key === "Escape" && this.isStreaming) {
63
+ e.preventDefault();
64
+ this.onAbort?.();
65
+ }
66
+ };
67
+ handlePaste = async (e) => {
68
+ const items = e.clipboardData?.items;
69
+ if (!items)
70
+ return;
71
+ const imageFiles = [];
72
+ // Check for image items in clipboard
73
+ for (let i = 0; i < items.length; i++) {
74
+ const item = items[i];
75
+ if (item.type.startsWith("image/")) {
76
+ const file = item.getAsFile();
77
+ if (file) {
78
+ imageFiles.push(file);
79
+ }
80
+ }
81
+ }
82
+ // If we found images, process them
83
+ if (imageFiles.length > 0) {
84
+ e.preventDefault(); // Prevent default paste behavior
85
+ if (imageFiles.length + this.attachments.length > this.maxFiles) {
86
+ alert(`Maximum ${this.maxFiles} files allowed`);
87
+ return;
88
+ }
89
+ this.processingFiles = true;
90
+ const newAttachments = [];
91
+ for (const file of imageFiles) {
92
+ try {
93
+ if (file.size > this.maxFileSize) {
94
+ alert(`Image exceeds maximum size of ${Math.round(this.maxFileSize / 1024 / 1024)}MB`);
95
+ continue;
96
+ }
97
+ const attachment = await loadAttachment(file);
98
+ newAttachments.push(attachment);
99
+ }
100
+ catch (error) {
101
+ console.error("Error processing pasted image:", error);
102
+ alert(`Failed to process pasted image: ${String(error)}`);
103
+ }
104
+ }
105
+ this.attachments = [...this.attachments, ...newAttachments];
106
+ this.onFilesChange?.(this.attachments);
107
+ this.processingFiles = false;
108
+ }
109
+ };
110
+ handleSend = () => {
111
+ this.onSend?.(this.value, this.attachments);
112
+ };
113
+ handleAttachmentClick = () => {
114
+ this.fileInputRef.value?.click();
115
+ };
116
+ async handleFilesSelected(e) {
117
+ const input = e.target;
118
+ const files = Array.from(input.files || []);
119
+ if (files.length === 0)
120
+ return;
121
+ if (files.length + this.attachments.length > this.maxFiles) {
122
+ alert(`Maximum ${this.maxFiles} files allowed`);
123
+ input.value = "";
124
+ return;
125
+ }
126
+ this.processingFiles = true;
127
+ const newAttachments = [];
128
+ for (const file of files) {
129
+ try {
130
+ if (file.size > this.maxFileSize) {
131
+ alert(`${file.name} exceeds maximum size of ${Math.round(this.maxFileSize / 1024 / 1024)}MB`);
132
+ continue;
133
+ }
134
+ const attachment = await loadAttachment(file);
135
+ newAttachments.push(attachment);
136
+ }
137
+ catch (error) {
138
+ console.error(`Error processing ${file.name}:`, error);
139
+ alert(`Failed to process ${file.name}: ${String(error)}`);
140
+ }
141
+ }
142
+ this.attachments = [...this.attachments, ...newAttachments];
143
+ this.onFilesChange?.(this.attachments);
144
+ this.processingFiles = false;
145
+ input.value = ""; // Reset input
146
+ }
147
+ removeFile(fileId) {
148
+ this.attachments = this.attachments.filter((f) => f.id !== fileId);
149
+ this.onFilesChange?.(this.attachments);
150
+ }
151
+ handleDragOver = (e) => {
152
+ e.preventDefault();
153
+ e.stopPropagation();
154
+ if (!this.isDragging) {
155
+ this.isDragging = true;
156
+ }
157
+ };
158
+ handleDragLeave = (e) => {
159
+ e.preventDefault();
160
+ e.stopPropagation();
161
+ // Only set isDragging to false if we're leaving the entire component
162
+ const rect = e.currentTarget.getBoundingClientRect();
163
+ const x = e.clientX;
164
+ const y = e.clientY;
165
+ if (x <= rect.left || x >= rect.right || y <= rect.top || y >= rect.bottom) {
166
+ this.isDragging = false;
167
+ }
168
+ };
169
+ handleDrop = async (e) => {
170
+ e.preventDefault();
171
+ e.stopPropagation();
172
+ this.isDragging = false;
173
+ const files = Array.from(e.dataTransfer?.files || []);
174
+ if (files.length === 0)
175
+ return;
176
+ if (files.length + this.attachments.length > this.maxFiles) {
177
+ alert(`Maximum ${this.maxFiles} files allowed`);
178
+ return;
179
+ }
180
+ this.processingFiles = true;
181
+ const newAttachments = [];
182
+ for (const file of files) {
183
+ try {
184
+ if (file.size > this.maxFileSize) {
185
+ alert(`${file.name} exceeds maximum size of ${Math.round(this.maxFileSize / 1024 / 1024)}MB`);
186
+ continue;
187
+ }
188
+ const attachment = await loadAttachment(file);
189
+ newAttachments.push(attachment);
190
+ }
191
+ catch (error) {
192
+ console.error(`Error processing ${file.name}:`, error);
193
+ alert(`Failed to process ${file.name}: ${String(error)}`);
194
+ }
195
+ }
196
+ this.attachments = [...this.attachments, ...newAttachments];
197
+ this.onFilesChange?.(this.attachments);
198
+ this.processingFiles = false;
199
+ };
200
+ firstUpdated() {
201
+ const textarea = this.textareaRef.value;
202
+ if (textarea) {
203
+ textarea.focus();
204
+ }
205
+ }
206
+ render() {
207
+ // Check if current model supports thinking/reasoning
208
+ const model = this.currentModel;
209
+ const supportsThinking = model?.reasoning === true; // Models with reasoning:true support thinking
210
+ return html `
211
+ <div
212
+ class="bg-card rounded-xl border shadow-sm relative ${this.isDragging ? "border-primary border-2 bg-primary/5" : "border-border"}"
213
+ @dragover=${this.handleDragOver}
214
+ @dragleave=${this.handleDragLeave}
215
+ @drop=${this.handleDrop}
216
+ >
217
+ <!-- Drag overlay -->
218
+ ${this.isDragging
219
+ ? html `
220
+ <div class="absolute inset-0 bg-primary/10 rounded-xl pointer-events-none z-10 flex items-center justify-center">
221
+ <div class="text-primary font-medium">${i18n("Drop files here")}</div>
222
+ </div>
223
+ `
224
+ : ""}
225
+
226
+ <!-- Attachments -->
227
+ ${this.attachments.length > 0
228
+ ? html `
229
+ <div class="px-4 pt-3 pb-2 flex flex-wrap gap-2">
230
+ ${this.attachments.map((attachment) => html `
231
+ <attachment-tile
232
+ .attachment=${attachment}
233
+ .showDelete=${true}
234
+ .onDelete=${() => this.removeFile(attachment.id)}
235
+ ></attachment-tile>
236
+ `)}
237
+ </div>
238
+ `
239
+ : ""}
240
+
241
+ <textarea
242
+ class="w-full bg-transparent p-4 text-foreground placeholder-muted-foreground outline-none resize-none overflow-y-auto"
243
+ placeholder=${i18n("Type a message...")}
244
+ rows="1"
245
+ style="max-height: 200px; field-sizing: content; min-height: 1lh; height: auto;"
246
+ .value=${this.value}
247
+ @input=${this.handleTextareaInput}
248
+ @keydown=${this.handleKeyDown}
249
+ @paste=${this.handlePaste}
250
+ ${ref(this.textareaRef)}
251
+ ></textarea>
252
+
253
+ <!-- Hidden file input -->
254
+ <input
255
+ type="file"
256
+ ${ref(this.fileInputRef)}
257
+ @change=${this.handleFilesSelected}
258
+ accept=${this.acceptedTypes}
259
+ multiple
260
+ style="display: none;"
261
+ />
262
+
263
+ <!-- Button Row -->
264
+ <div class="px-2 pb-2 flex items-center justify-between">
265
+ <!-- Left side - attachment and thinking selector -->
266
+ <div class="flex gap-2 items-center">
267
+ ${this.showAttachmentButton
268
+ ? this.processingFiles
269
+ ? html `
270
+ <div class="h-8 w-8 flex items-center justify-center">
271
+ ${icon(Loader2, "sm", "animate-spin text-muted-foreground")}
272
+ </div>
273
+ `
274
+ : html `
275
+ ${Button({
276
+ variant: "ghost",
277
+ size: "icon",
278
+ className: "h-8 w-8",
279
+ onClick: this.handleAttachmentClick,
280
+ children: icon(Paperclip, "sm"),
281
+ })}
282
+ `
283
+ : ""}
284
+ ${supportsThinking && this.showThinkingSelector
285
+ ? html `
286
+ ${Select({
287
+ value: this.thinkingLevel,
288
+ placeholder: i18n("Off"),
289
+ options: [
290
+ { value: "off", label: i18n("Off"), icon: icon(Brain, "sm") },
291
+ { value: "minimal", label: i18n("Minimal"), icon: icon(Brain, "sm") },
292
+ { value: "low", label: i18n("Low"), icon: icon(Brain, "sm") },
293
+ { value: "medium", label: i18n("Medium"), icon: icon(Brain, "sm") },
294
+ { value: "high", label: i18n("High"), icon: icon(Brain, "sm") },
295
+ ],
296
+ onChange: (value) => {
297
+ this.onThinkingChange?.(value);
298
+ },
299
+ width: "80px",
300
+ size: "sm",
301
+ variant: "ghost",
302
+ fitContent: true,
303
+ })}
304
+ `
305
+ : ""}
306
+ </div>
307
+
308
+ <!-- Model selector and send on the right -->
309
+ <div class="flex gap-2 items-center">
310
+ ${this.showModelSelector && this.currentModel
311
+ ? html `
312
+ ${Button({
313
+ variant: "ghost",
314
+ size: "sm",
315
+ onClick: () => {
316
+ // Focus textarea before opening model selector so focus returns there
317
+ this.textareaRef.value?.focus();
318
+ // Wait for next frame to ensure focus takes effect before dialog captures it
319
+ requestAnimationFrame(() => {
320
+ this.onModelSelect?.();
321
+ });
322
+ },
323
+ children: html `
324
+ ${icon(Sparkles, "sm")}
325
+ <span class="ml-1">${this.currentModel.id}</span>
326
+ `,
327
+ className: "h-8 text-xs truncate",
328
+ })}
329
+ `
330
+ : ""}
331
+ ${this.isStreaming
332
+ ? html `
333
+ ${Button({
334
+ variant: "ghost",
335
+ size: "icon",
336
+ onClick: this.onAbort,
337
+ children: icon(Square, "sm"),
338
+ className: "h-8 w-8",
339
+ })}
340
+ `
341
+ : html `
342
+ ${Button({
343
+ variant: "ghost",
344
+ size: "icon",
345
+ onClick: this.handleSend,
346
+ disabled: (!this.value.trim() && this.attachments.length === 0) || this.processingFiles,
347
+ children: html `<div style="transform: rotate(-45deg)">${icon(Send, "sm")}</div>`,
348
+ className: "h-8 w-8",
349
+ })}
350
+ `}
351
+ </div>
352
+ </div>
353
+ </div>
354
+ `;
355
+ }
356
+ };
357
+ __decorate([
358
+ property()
359
+ ], MessageEditor.prototype, "value", null);
360
+ __decorate([
361
+ property()
362
+ ], MessageEditor.prototype, "isStreaming", void 0);
363
+ __decorate([
364
+ property()
365
+ ], MessageEditor.prototype, "currentModel", void 0);
366
+ __decorate([
367
+ property()
368
+ ], MessageEditor.prototype, "thinkingLevel", void 0);
369
+ __decorate([
370
+ property()
371
+ ], MessageEditor.prototype, "showAttachmentButton", void 0);
372
+ __decorate([
373
+ property()
374
+ ], MessageEditor.prototype, "showModelSelector", void 0);
375
+ __decorate([
376
+ property()
377
+ ], MessageEditor.prototype, "showThinkingSelector", void 0);
378
+ __decorate([
379
+ property()
380
+ ], MessageEditor.prototype, "onInput", void 0);
381
+ __decorate([
382
+ property()
383
+ ], MessageEditor.prototype, "onSend", void 0);
384
+ __decorate([
385
+ property()
386
+ ], MessageEditor.prototype, "onAbort", void 0);
387
+ __decorate([
388
+ property()
389
+ ], MessageEditor.prototype, "onModelSelect", void 0);
390
+ __decorate([
391
+ property()
392
+ ], MessageEditor.prototype, "onThinkingChange", void 0);
393
+ __decorate([
394
+ property()
395
+ ], MessageEditor.prototype, "onFilesChange", void 0);
396
+ __decorate([
397
+ property()
398
+ ], MessageEditor.prototype, "attachments", void 0);
399
+ __decorate([
400
+ property()
401
+ ], MessageEditor.prototype, "maxFiles", void 0);
402
+ __decorate([
403
+ property()
404
+ ], MessageEditor.prototype, "maxFileSize", void 0);
405
+ __decorate([
406
+ property()
407
+ ], MessageEditor.prototype, "acceptedTypes", void 0);
408
+ __decorate([
409
+ state()
410
+ ], MessageEditor.prototype, "processingFiles", void 0);
411
+ __decorate([
412
+ state()
413
+ ], MessageEditor.prototype, "isDragging", void 0);
414
+ MessageEditor = __decorate([
415
+ customElement("message-editor")
416
+ ], MessageEditor);
417
+ export { MessageEditor };
418
+ //# sourceMappingURL=MessageEditor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageEditor.js","sourceRoot":"","sources":["../../src/components/MessageEditor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import type { AgentMessage, AgentTool } from "@draht/agent-core";
2
+ import { LitElement, type TemplateResult } from "lit";
3
+ export declare class MessageList extends LitElement {
4
+ messages: AgentMessage[];
5
+ tools: AgentTool[];
6
+ pendingToolCalls?: Set<string>;
7
+ isStreaming: boolean;
8
+ onCostClick?: () => void;
9
+ protected createRenderRoot(): HTMLElement | DocumentFragment;
10
+ connectedCallback(): void;
11
+ private buildRenderItems;
12
+ render(): TemplateResult<1>;
13
+ }
14
+ //# sourceMappingURL=MessageList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageList.d.ts","sourceRoot":"","sources":["../../src/components/MessageList.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEjE,OAAO,EAAQ,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAK5D,qBAAa,WAAY,SAAQ,UAAU;IACf,QAAQ,EAAE,YAAY,EAAE,CAAM;IAC9B,KAAK,EAAE,SAAS,EAAE,CAAM;IACvB,gBAAgB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAC9B,WAAW,EAAE,OAAO,CAAS;IAC1B,WAAW,CAAC,EAAE,MAAM,IAAI,CAAC;IAEzD,UAAmB,gBAAgB,IAAI,WAAW,GAAG,gBAAgB,CAEpE;IAEQ,iBAAiB,IAAI,IAAI,CAGjC;IAED,OAAO,CAAC,gBAAgB;IAwDf,MAAM,sBASd;CACD"}
@@ -0,0 +1,104 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { html, LitElement } from "lit";
8
+ import { property } from "lit/decorators.js";
9
+ import { repeat } from "lit/directives/repeat.js";
10
+ import { renderMessage } from "./message-renderer-registry.js";
11
+ export class MessageList extends LitElement {
12
+ messages = [];
13
+ tools = [];
14
+ pendingToolCalls;
15
+ isStreaming = false;
16
+ onCostClick;
17
+ createRenderRoot() {
18
+ return this;
19
+ }
20
+ connectedCallback() {
21
+ super.connectedCallback();
22
+ this.style.display = "block";
23
+ }
24
+ buildRenderItems() {
25
+ // Map tool results by call id for quick lookup
26
+ const resultByCallId = new Map();
27
+ for (const message of this.messages) {
28
+ if (message.role === "toolResult") {
29
+ resultByCallId.set(message.toolCallId, message);
30
+ }
31
+ }
32
+ const items = [];
33
+ let index = 0;
34
+ for (const msg of this.messages) {
35
+ // Skip artifact messages - they're for session persistence only, not UI display
36
+ if (msg.role === "artifact") {
37
+ continue;
38
+ }
39
+ // Try custom renderer first
40
+ const customTemplate = renderMessage(msg);
41
+ if (customTemplate) {
42
+ items.push({ key: `msg:${index}`, template: customTemplate });
43
+ index++;
44
+ continue;
45
+ }
46
+ // Fall back to built-in renderers
47
+ if (msg.role === "user" || msg.role === "user-with-attachments") {
48
+ items.push({
49
+ key: `msg:${index}`,
50
+ template: html `<user-message .message=${msg}></user-message>`,
51
+ });
52
+ index++;
53
+ }
54
+ else if (msg.role === "assistant") {
55
+ const amsg = msg;
56
+ items.push({
57
+ key: `msg:${index}`,
58
+ template: html `<assistant-message
59
+ .message=${amsg}
60
+ .tools=${this.tools}
61
+ .isStreaming=${false}
62
+ .pendingToolCalls=${this.pendingToolCalls}
63
+ .toolResultsById=${resultByCallId}
64
+ .hideToolCalls=${false}
65
+ .hidePendingToolCalls=${this.isStreaming}
66
+ .onCostClick=${this.onCostClick}
67
+ ></assistant-message>`,
68
+ });
69
+ index++;
70
+ }
71
+ else {
72
+ // Skip standalone toolResult messages; they are rendered via paired tool-message above
73
+ // Skip unknown roles
74
+ }
75
+ }
76
+ return items;
77
+ }
78
+ render() {
79
+ const items = this.buildRenderItems();
80
+ return html `<div class="flex flex-col gap-3">
81
+ ${repeat(items, (it) => it.key, (it) => it.template)}
82
+ </div>`;
83
+ }
84
+ }
85
+ __decorate([
86
+ property({ type: Array })
87
+ ], MessageList.prototype, "messages", void 0);
88
+ __decorate([
89
+ property({ type: Array })
90
+ ], MessageList.prototype, "tools", void 0);
91
+ __decorate([
92
+ property({ type: Object })
93
+ ], MessageList.prototype, "pendingToolCalls", void 0);
94
+ __decorate([
95
+ property({ type: Boolean })
96
+ ], MessageList.prototype, "isStreaming", void 0);
97
+ __decorate([
98
+ property({ attribute: false })
99
+ ], MessageList.prototype, "onCostClick", void 0);
100
+ // Register custom element
101
+ if (!customElements.get("message-list")) {
102
+ customElements.define("message-list", MessageList);
103
+ }
104
+ //# sourceMappingURL=MessageList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageList.js","sourceRoot":"","sources":["../../src/components/MessageList.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,95 @@
1
+ import type { AssistantMessage as AssistantMessageType, ImageContent, TextContent, ToolCall, ToolResultMessage as ToolResultMessageType, UserMessage as UserMessageType } from "@draht/ai";
2
+ import { LitElement, type TemplateResult } from "lit";
3
+ import type { Attachment } from "../utils/attachment-utils.js";
4
+ import "./ThinkingBlock.js";
5
+ import type { AgentTool } from "@draht/agent-core";
6
+ export type UserMessageWithAttachments = {
7
+ role: "user-with-attachments";
8
+ content: string | (TextContent | ImageContent)[];
9
+ timestamp: number;
10
+ attachments?: Attachment[];
11
+ };
12
+ export interface ArtifactMessage {
13
+ role: "artifact";
14
+ action: "create" | "update" | "delete";
15
+ filename: string;
16
+ content?: string;
17
+ title?: string;
18
+ timestamp: string;
19
+ }
20
+ declare module "@draht/agent-core" {
21
+ interface CustomAgentMessages {
22
+ "user-with-attachments": UserMessageWithAttachments;
23
+ artifact: ArtifactMessage;
24
+ }
25
+ }
26
+ export declare class UserMessage extends LitElement {
27
+ message: UserMessageWithAttachments | UserMessageType;
28
+ protected createRenderRoot(): HTMLElement | DocumentFragment;
29
+ connectedCallback(): void;
30
+ render(): TemplateResult<1>;
31
+ }
32
+ export declare class AssistantMessage extends LitElement {
33
+ message: AssistantMessageType;
34
+ tools?: AgentTool<any>[];
35
+ pendingToolCalls?: Set<string>;
36
+ hideToolCalls: boolean;
37
+ toolResultsById?: Map<string, ToolResultMessageType>;
38
+ isStreaming: boolean;
39
+ hidePendingToolCalls: boolean;
40
+ onCostClick?: () => void;
41
+ protected createRenderRoot(): HTMLElement | DocumentFragment;
42
+ connectedCallback(): void;
43
+ render(): TemplateResult<1>;
44
+ }
45
+ export declare class ToolMessageDebugView extends LitElement {
46
+ callArgs: any;
47
+ result?: ToolResultMessageType;
48
+ hasResult: boolean;
49
+ protected createRenderRoot(): HTMLElement | DocumentFragment;
50
+ connectedCallback(): void;
51
+ private pretty;
52
+ render(): TemplateResult<1>;
53
+ }
54
+ export declare class ToolMessage extends LitElement {
55
+ toolCall: ToolCall;
56
+ tool?: AgentTool<any>;
57
+ result?: ToolResultMessageType;
58
+ pending: boolean;
59
+ aborted: boolean;
60
+ isStreaming: boolean;
61
+ protected createRenderRoot(): HTMLElement | DocumentFragment;
62
+ connectedCallback(): void;
63
+ render(): TemplateResult;
64
+ }
65
+ export declare class AbortedMessage extends LitElement {
66
+ protected createRenderRoot(): HTMLElement | DocumentFragment;
67
+ connectedCallback(): void;
68
+ protected render(): unknown;
69
+ }
70
+ import type { AgentMessage } from "@draht/agent-core";
71
+ import type { Message } from "@draht/ai";
72
+ /**
73
+ * Convert attachments to content blocks for LLM.
74
+ * - Images become ImageContent blocks
75
+ * - Documents with extractedText become TextContent blocks with filename header
76
+ */
77
+ export declare function convertAttachments(attachments: Attachment[]): (TextContent | ImageContent)[];
78
+ /**
79
+ * Check if a message is a UserMessageWithAttachments.
80
+ */
81
+ export declare function isUserMessageWithAttachments(msg: AgentMessage): msg is UserMessageWithAttachments;
82
+ /**
83
+ * Check if a message is an ArtifactMessage.
84
+ */
85
+ export declare function isArtifactMessage(msg: AgentMessage): msg is ArtifactMessage;
86
+ /**
87
+ * Default convertToLlm for web-ui apps.
88
+ *
89
+ * Handles:
90
+ * - UserMessageWithAttachments: converts to user message with content blocks
91
+ * - ArtifactMessage: filtered out (UI-only, for session reconstruction)
92
+ * - Standard LLM messages (user, assistant, toolResult): passed through
93
+ */
94
+ export declare function defaultConvertToLlm(messages: AgentMessage[]): Message[];
95
+ //# sourceMappingURL=Messages.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Messages.d.ts","sourceRoot":"","sources":["../../src/components/Messages.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACX,gBAAgB,IAAI,oBAAoB,EACxC,YAAY,EACZ,WAAW,EACX,QAAQ,EACR,iBAAiB,IAAI,qBAAqB,EAC1C,WAAW,IAAI,eAAe,EAC9B,MAAM,WAAW,CAAC;AACnB,OAAO,EAAQ,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG5D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAG/D,OAAO,oBAAoB,CAAC;AAC5B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAEnD,MAAM,MAAM,0BAA0B,GAAG;IACxC,IAAI,EAAE,uBAAuB,CAAC;IAC9B,OAAO,EAAE,MAAM,GAAG,CAAC,WAAW,GAAG,YAAY,CAAC,EAAE,CAAC;IACjD,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,UAAU,EAAE,CAAC;CAC3B,CAAC;AAGF,MAAM,WAAW,eAAe;IAC/B,IAAI,EAAE,UAAU,CAAC;IACjB,MAAM,EAAE,QAAQ,GAAG,QAAQ,GAAG,QAAQ,CAAC;IACvC,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;CAClB;AAED,OAAO,QAAQ,mBAAmB,CAAC,CAAC;IACnC,UAAU,mBAAmB;QAC5B,uBAAuB,EAAE,0BAA0B,CAAC;QACpD,QAAQ,EAAE,eAAe,CAAC;KAC1B;CACD;AAED,qBACa,WAAY,SAAQ,UAAU;IACd,OAAO,EAAG,0BAA0B,GAAG,eAAe,CAAC;IAEnF,UAAmB,gBAAgB,IAAI,WAAW,GAAG,gBAAgB,CAEpE;IAEQ,iBAAiB,IAAI,IAAI,CAGjC;IAEQ,MAAM,sBA0Bd;CACD;AAED,qBACa,gBAAiB,SAAQ,UAAU;IACnB,OAAO,EAAG,oBAAoB,CAAC;IAChC,KAAK,CAAC,EAAE,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;IACxB,gBAAgB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAC9B,aAAa,UAAS;IACvB,eAAe,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,qBAAqB,CAAC,CAAC;IACpD,WAAW,EAAE,OAAO,CAAS;IAC7B,oBAAoB,UAAS;IAC1B,WAAW,CAAC,EAAE,MAAM,IAAI,CAAC;IAEzD,UAAmB,gBAAgB,IAAI,WAAW,GAAG,gBAAgB,CAEpE;IAEQ,iBAAiB,IAAI,IAAI,CAGjC;IAEQ,MAAM,sBA+Dd;CACD;AAED,qBACa,oBAAqB,SAAQ,UAAU;IACvB,QAAQ,EAAE,GAAG,CAAC;IACd,MAAM,CAAC,EAAE,qBAAqB,CAAC;IAC9B,SAAS,EAAE,OAAO,CAAS;IAExD,UAAmB,gBAAgB,IAAI,WAAW,GAAG,gBAAgB,CAEpE;IAEQ,iBAAiB,IAAI,IAAI,CAGjC;IAED,OAAO,CAAC,MAAM;IAYL,MAAM,sBA0Bd;CACD;AAED,qBACa,WAAY,SAAQ,UAAU;IACd,QAAQ,EAAG,QAAQ,CAAC;IACpB,IAAI,CAAC,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC;IACtB,MAAM,CAAC,EAAE,qBAAqB,CAAC;IAC9B,OAAO,EAAE,OAAO,CAAS;IACzB,OAAO,EAAE,OAAO,CAAS;IACzB,WAAW,EAAE,OAAO,CAAS;IAE1D,UAAmB,gBAAgB,IAAI,WAAW,GAAG,gBAAgB,CAEpE;IAEQ,iBAAiB,IAAI,IAAI,CAGjC;IAEQ,MAAM,mBAgCd;CACD;AAED,qBACa,cAAe,SAAQ,UAAU;IAC7C,UAAmB,gBAAgB,IAAI,WAAW,GAAG,gBAAgB,CAEpE;IAEQ,iBAAiB,IAAI,IAAI,CAGjC;IAED,UAAmB,MAAM,IAAI,OAAO,CAEnC;CACD;AAMD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEzC;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,WAAW,EAAE,UAAU,EAAE,GAAG,CAAC,WAAW,GAAG,YAAY,CAAC,EAAE,CAiB5F;AAED;;GAEG;AACH,wBAAgB,4BAA4B,CAAC,GAAG,EAAE,YAAY,GAAG,GAAG,IAAI,0BAA0B,CAEjG;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,YAAY,GAAG,GAAG,IAAI,eAAe,CAE3E;AAED;;;;;;;GAOG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,YAAY,EAAE,GAAG,OAAO,EAAE,CAmCvE"}