@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,148 @@
1
+ import { CopyButton } from "@mariozechner/mini-lit/dist/CopyButton.js";
2
+ import { DownloadButton } from "@mariozechner/mini-lit/dist/DownloadButton.js";
3
+ import hljs from "highlight.js";
4
+ import { html } from "lit";
5
+ import { customElement, property } from "lit/decorators.js";
6
+ import { unsafeHTML } from "lit/directives/unsafe-html.js";
7
+ import { i18n } from "../../utils/i18n.js";
8
+ import { ArtifactElement } from "./ArtifactElement.js";
9
+
10
+ // Known code file extensions for highlighting
11
+ const CODE_EXTENSIONS = [
12
+ "js",
13
+ "javascript",
14
+ "ts",
15
+ "typescript",
16
+ "jsx",
17
+ "tsx",
18
+ "py",
19
+ "python",
20
+ "java",
21
+ "c",
22
+ "cpp",
23
+ "cs",
24
+ "php",
25
+ "rb",
26
+ "ruby",
27
+ "go",
28
+ "rust",
29
+ "swift",
30
+ "kotlin",
31
+ "scala",
32
+ "dart",
33
+ "html",
34
+ "css",
35
+ "scss",
36
+ "sass",
37
+ "less",
38
+ "json",
39
+ "xml",
40
+ "yaml",
41
+ "yml",
42
+ "toml",
43
+ "sql",
44
+ "sh",
45
+ "bash",
46
+ "ps1",
47
+ "bat",
48
+ "r",
49
+ "matlab",
50
+ "julia",
51
+ "lua",
52
+ "perl",
53
+ "vue",
54
+ "svelte",
55
+ ];
56
+
57
+ @customElement("text-artifact")
58
+ export class TextArtifact extends ArtifactElement {
59
+ @property() override filename = "";
60
+
61
+ private _content = "";
62
+ override get content(): string {
63
+ return this._content;
64
+ }
65
+ override set content(value: string) {
66
+ this._content = value;
67
+ this.requestUpdate();
68
+ }
69
+
70
+ protected override createRenderRoot(): HTMLElement | DocumentFragment {
71
+ return this; // light DOM
72
+ }
73
+
74
+ private isCode(): boolean {
75
+ const ext = this.filename.split(".").pop()?.toLowerCase() || "";
76
+ return CODE_EXTENSIONS.includes(ext);
77
+ }
78
+
79
+ private getLanguageFromExtension(ext: string): string {
80
+ const languageMap: Record<string, string> = {
81
+ js: "javascript",
82
+ ts: "typescript",
83
+ py: "python",
84
+ rb: "ruby",
85
+ yml: "yaml",
86
+ ps1: "powershell",
87
+ bat: "batch",
88
+ };
89
+ return languageMap[ext] || ext;
90
+ }
91
+
92
+ private getMimeType(): string {
93
+ const ext = this.filename.split(".").pop()?.toLowerCase() || "";
94
+ if (ext === "svg") return "image/svg+xml";
95
+ if (ext === "md" || ext === "markdown") return "text/markdown";
96
+ return "text/plain";
97
+ }
98
+
99
+ public getHeaderButtons() {
100
+ const copyButton = new CopyButton();
101
+ copyButton.text = this.content;
102
+ copyButton.title = i18n("Copy");
103
+ copyButton.showText = false;
104
+
105
+ return html`
106
+ <div class="flex items-center gap-1">
107
+ ${copyButton}
108
+ ${DownloadButton({
109
+ content: this.content,
110
+ filename: this.filename,
111
+ mimeType: this.getMimeType(),
112
+ title: i18n("Download"),
113
+ })}
114
+ </div>
115
+ `;
116
+ }
117
+
118
+ override render() {
119
+ const isCode = this.isCode();
120
+ const ext = this.filename.split(".").pop() || "";
121
+ return html`
122
+ <div class="h-full flex flex-col">
123
+ <div class="flex-1 overflow-auto">
124
+ ${
125
+ isCode
126
+ ? html`
127
+ <pre class="m-0 p-4 text-xs"><code class="hljs language-${this.getLanguageFromExtension(
128
+ ext.toLowerCase(),
129
+ )}">${unsafeHTML(
130
+ hljs.highlight(this.content, {
131
+ language: this.getLanguageFromExtension(ext.toLowerCase()),
132
+ ignoreIllegals: true,
133
+ }).value,
134
+ )}</code></pre>
135
+ `
136
+ : html` <pre class="m-0 p-4 text-xs font-mono">${this.content}</pre> `
137
+ }
138
+ </div>
139
+ </div>
140
+ `;
141
+ }
142
+ }
143
+
144
+ declare global {
145
+ interface HTMLElementTagNameMap {
146
+ "text-artifact": TextArtifact;
147
+ }
148
+ }
@@ -0,0 +1,310 @@
1
+ import "@mariozechner/mini-lit/dist/CodeBlock.js";
2
+ import type { ToolResultMessage } from "@draht/ai";
3
+ import { createRef, ref } from "lit/directives/ref.js";
4
+ import { FileCode2 } from "lucide";
5
+ import "../../components/ConsoleBlock.js";
6
+ import { Diff } from "@mariozechner/mini-lit/dist/Diff.js";
7
+ import { html, type TemplateResult } from "lit";
8
+ import { i18n } from "../../utils/i18n.js";
9
+ import { renderCollapsibleHeader, renderHeader } from "../renderer-registry.js";
10
+ import type { ToolRenderer, ToolRenderResult } from "../types.js";
11
+ import { ArtifactPill } from "./ArtifactPill.js";
12
+ import type { ArtifactsPanel, ArtifactsParams } from "./artifacts.js";
13
+
14
+ // Helper to extract text from content blocks
15
+ function getTextOutput(result: ToolResultMessage<any> | undefined): string {
16
+ if (!result) return "";
17
+ return (
18
+ result.content
19
+ ?.filter((c) => c.type === "text")
20
+ .map((c: any) => c.text)
21
+ .join("\n") || ""
22
+ );
23
+ }
24
+
25
+ // Helper to determine language for syntax highlighting
26
+ function getLanguageFromFilename(filename?: string): string {
27
+ if (!filename) return "text";
28
+ const ext = filename.split(".").pop()?.toLowerCase();
29
+ const languageMap: Record<string, string> = {
30
+ js: "javascript",
31
+ jsx: "javascript",
32
+ ts: "typescript",
33
+ tsx: "typescript",
34
+ html: "html",
35
+ css: "css",
36
+ scss: "scss",
37
+ json: "json",
38
+ py: "python",
39
+ md: "markdown",
40
+ svg: "xml",
41
+ xml: "xml",
42
+ yaml: "yaml",
43
+ yml: "yaml",
44
+ sh: "bash",
45
+ bash: "bash",
46
+ sql: "sql",
47
+ java: "java",
48
+ c: "c",
49
+ cpp: "cpp",
50
+ cs: "csharp",
51
+ go: "go",
52
+ rs: "rust",
53
+ php: "php",
54
+ rb: "ruby",
55
+ swift: "swift",
56
+ kt: "kotlin",
57
+ r: "r",
58
+ };
59
+ return languageMap[ext || ""] || "text";
60
+ }
61
+
62
+ export class ArtifactsToolRenderer implements ToolRenderer<ArtifactsParams, undefined> {
63
+ constructor(public artifactsPanel?: ArtifactsPanel) {}
64
+
65
+ render(
66
+ params: ArtifactsParams | undefined,
67
+ result: ToolResultMessage<undefined> | undefined,
68
+ isStreaming?: boolean,
69
+ ): ToolRenderResult {
70
+ const state = result ? (result.isError ? "error" : "complete") : isStreaming ? "inprogress" : "complete";
71
+
72
+ // Create refs for collapsible sections
73
+ const contentRef = createRef<HTMLDivElement>();
74
+ const chevronRef = createRef<HTMLSpanElement>();
75
+
76
+ // Helper to get command labels
77
+ const getCommandLabels = (command: string): { streaming: string; complete: string } => {
78
+ const labels: Record<string, { streaming: string; complete: string }> = {
79
+ create: { streaming: i18n("Creating artifact"), complete: i18n("Created artifact") },
80
+ update: { streaming: i18n("Updating artifact"), complete: i18n("Updated artifact") },
81
+ rewrite: { streaming: i18n("Rewriting artifact"), complete: i18n("Rewrote artifact") },
82
+ get: { streaming: i18n("Getting artifact"), complete: i18n("Got artifact") },
83
+ delete: { streaming: i18n("Deleting artifact"), complete: i18n("Deleted artifact") },
84
+ logs: { streaming: i18n("Getting logs"), complete: i18n("Got logs") },
85
+ };
86
+ return labels[command] || { streaming: i18n("Processing artifact"), complete: i18n("Processed artifact") };
87
+ };
88
+
89
+ // Helper to render header text with inline artifact pill
90
+ const renderHeaderWithPill = (labelText: string, filename?: string): TemplateResult => {
91
+ if (filename) {
92
+ return html`<span>${labelText} ${ArtifactPill(filename, this.artifactsPanel)}</span>`;
93
+ }
94
+ return html`<span>${labelText}</span>`;
95
+ };
96
+
97
+ // Error handling
98
+ if (result?.isError) {
99
+ const command = params?.command;
100
+ const filename = params?.filename;
101
+ const labels = command
102
+ ? getCommandLabels(command)
103
+ : { streaming: i18n("Processing artifact"), complete: i18n("Processed artifact") };
104
+ const headerText = labels.streaming;
105
+
106
+ // For create/update/rewrite errors, show code block + console/error
107
+ if (command === "create" || command === "update" || command === "rewrite") {
108
+ const content = params?.content || "";
109
+ const { old_str, new_str } = params || {};
110
+ const isDiff = command === "update";
111
+ const diffContent =
112
+ old_str !== undefined && new_str !== undefined ? Diff({ oldText: old_str, newText: new_str }) : "";
113
+
114
+ const isHtml = filename?.endsWith(".html");
115
+
116
+ return {
117
+ content: html`
118
+ <div>
119
+ ${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
120
+ <div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300 space-y-3">
121
+ ${isDiff ? diffContent : content ? html`<code-block .code=${content} language=${getLanguageFromFilename(filename)}></code-block>` : ""}
122
+ ${
123
+ isHtml
124
+ ? html`<console-block .content=${getTextOutput(result) || i18n("An error occurred")} variant="error"></console-block>`
125
+ : html`<div class="text-sm text-destructive">${getTextOutput(result) || i18n("An error occurred")}</div>`
126
+ }
127
+ </div>
128
+ </div>
129
+ `,
130
+ isCustom: false,
131
+ };
132
+ }
133
+
134
+ // For other errors, just show error message
135
+ return {
136
+ content: html`
137
+ <div class="space-y-3">
138
+ ${renderHeader(state, FileCode2, headerText)}
139
+ <div class="text-sm text-destructive">${getTextOutput(result) || i18n("An error occurred")}</div>
140
+ </div>
141
+ `,
142
+ isCustom: false,
143
+ };
144
+ }
145
+
146
+ // Full params + result
147
+ if (result && params) {
148
+ const { command, filename, content } = params;
149
+ const labels = command
150
+ ? getCommandLabels(command)
151
+ : { streaming: i18n("Processing artifact"), complete: i18n("Processed artifact") };
152
+ const headerText = labels.complete;
153
+
154
+ // GET command: show code block with file content
155
+ if (command === "get") {
156
+ const fileContent = getTextOutput(result) || i18n("(no output)");
157
+ return {
158
+ content: html`
159
+ <div>
160
+ ${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
161
+ <div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300">
162
+ <code-block .code=${fileContent} language=${getLanguageFromFilename(filename)}></code-block>
163
+ </div>
164
+ </div>
165
+ `,
166
+ isCustom: false,
167
+ };
168
+ }
169
+
170
+ // LOGS command: show console block
171
+ if (command === "logs") {
172
+ const logs = getTextOutput(result) || i18n("(no output)");
173
+ return {
174
+ content: html`
175
+ <div>
176
+ ${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
177
+ <div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300">
178
+ <console-block .content=${logs}></console-block>
179
+ </div>
180
+ </div>
181
+ `,
182
+ isCustom: false,
183
+ };
184
+ }
185
+
186
+ // CREATE/UPDATE/REWRITE: always show code block, + console block for .html files
187
+ if (command === "create" || command === "rewrite") {
188
+ const codeContent = content || "";
189
+ const isHtml = filename?.endsWith(".html");
190
+ const logs = getTextOutput(result) || "";
191
+
192
+ return {
193
+ content: html`
194
+ <div>
195
+ ${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
196
+ <div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300 space-y-3">
197
+ ${codeContent ? html`<code-block .code=${codeContent} language=${getLanguageFromFilename(filename)}></code-block>` : ""}
198
+ ${isHtml && logs ? html`<console-block .content=${logs}></console-block>` : ""}
199
+ </div>
200
+ </div>
201
+ `,
202
+ isCustom: false,
203
+ };
204
+ }
205
+
206
+ if (command === "update") {
207
+ const isHtml = filename?.endsWith(".html");
208
+ const logs = getTextOutput(result) || "";
209
+ return {
210
+ content: html`
211
+ <div>
212
+ ${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
213
+ <div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300 space-y-3">
214
+ ${Diff({ oldText: params.old_str || "", newText: params.new_str || "" })}
215
+ ${isHtml && logs ? html`<console-block .content=${logs}></console-block>` : ""}
216
+ </div>
217
+ </div>
218
+ `,
219
+ isCustom: false,
220
+ };
221
+ }
222
+
223
+ // For DELETE, just show header
224
+ return {
225
+ content: html`
226
+ <div class="space-y-3">
227
+ ${renderHeader(state, FileCode2, renderHeaderWithPill(headerText, filename))}
228
+ </div>
229
+ `,
230
+ isCustom: false,
231
+ };
232
+ }
233
+
234
+ // Params only (streaming or waiting for result)
235
+ if (params) {
236
+ const { command, filename, content, old_str, new_str } = params;
237
+
238
+ // If no command yet
239
+ if (!command) {
240
+ return { content: renderHeader(state, FileCode2, i18n("Preparing artifact...")), isCustom: false };
241
+ }
242
+
243
+ const labels = getCommandLabels(command);
244
+ const headerText = labels.streaming;
245
+
246
+ // Render based on command type
247
+ switch (command) {
248
+ case "create":
249
+ case "rewrite":
250
+ return {
251
+ content: html`
252
+ <div>
253
+ ${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
254
+ <div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300">
255
+ ${
256
+ content
257
+ ? html`<code-block .code=${content} language=${getLanguageFromFilename(filename)}></code-block>`
258
+ : ""
259
+ }
260
+ </div>
261
+ </div>
262
+ `,
263
+ isCustom: false,
264
+ };
265
+
266
+ case "update":
267
+ return {
268
+ content: html`
269
+ <div>
270
+ ${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
271
+ <div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300">
272
+ ${
273
+ old_str !== undefined && new_str !== undefined
274
+ ? Diff({ oldText: old_str, newText: new_str })
275
+ : ""
276
+ }
277
+ </div>
278
+ </div>
279
+ `,
280
+ isCustom: false,
281
+ };
282
+
283
+ case "get":
284
+ case "logs":
285
+ return {
286
+ content: html`
287
+ <div>
288
+ ${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
289
+ <div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300"></div>
290
+ </div>
291
+ `,
292
+ isCustom: false,
293
+ };
294
+
295
+ default:
296
+ return {
297
+ content: html`
298
+ <div>
299
+ ${renderHeader(state, FileCode2, renderHeaderWithPill(headerText, filename))}
300
+ </div>
301
+ `,
302
+ isCustom: false,
303
+ };
304
+ }
305
+ }
306
+
307
+ // No params or result yet
308
+ return { content: renderHeader(state, FileCode2, i18n("Preparing artifact...")), isCustom: false };
309
+ }
310
+ }