@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,107 @@
1
+ import { icon } from "@mariozechner/mini-lit/dist/icons.js";
2
+ import { LitElement } from "lit";
3
+ import { customElement, property } from "lit/decorators.js";
4
+ import { html } from "lit/html.js";
5
+ import { FileSpreadsheet, FileText, X } from "lucide";
6
+ import { AttachmentOverlay } from "../dialogs/AttachmentOverlay.js";
7
+ import type { Attachment } from "../utils/attachment-utils.js";
8
+ import { i18n } from "../utils/i18n.js";
9
+
10
+ @customElement("attachment-tile")
11
+ export class AttachmentTile extends LitElement {
12
+ @property({ type: Object }) attachment!: Attachment;
13
+ @property({ type: Boolean }) showDelete = false;
14
+ @property() onDelete?: () => void;
15
+
16
+ protected override createRenderRoot(): HTMLElement | DocumentFragment {
17
+ return this;
18
+ }
19
+
20
+ override connectedCallback(): void {
21
+ super.connectedCallback();
22
+ this.style.display = "block";
23
+ this.classList.add("max-h-16");
24
+ }
25
+
26
+ private handleClick = () => {
27
+ AttachmentOverlay.open(this.attachment);
28
+ };
29
+
30
+ override render() {
31
+ const hasPreview = !!this.attachment.preview;
32
+ const isImage = this.attachment.type === "image";
33
+ const isPdf = this.attachment.mimeType === "application/pdf";
34
+ const isExcel =
35
+ this.attachment.mimeType?.includes("spreadsheetml") ||
36
+ this.attachment.fileName.toLowerCase().endsWith(".xlsx") ||
37
+ this.attachment.fileName.toLowerCase().endsWith(".xls");
38
+
39
+ // Choose the appropriate icon
40
+ const getDocumentIcon = () => {
41
+ if (isExcel) return icon(FileSpreadsheet, "md");
42
+ return icon(FileText, "md");
43
+ };
44
+
45
+ return html`
46
+ <div class="relative group inline-block">
47
+ ${
48
+ hasPreview
49
+ ? html`
50
+ <div class="relative">
51
+ <img
52
+ src="data:${isImage ? this.attachment.mimeType : "image/png"};base64,${this.attachment.preview}"
53
+ class="w-16 h-16 object-cover rounded-lg border border-input cursor-pointer hover:opacity-80 transition-opacity"
54
+ alt="${this.attachment.fileName}"
55
+ title="${this.attachment.fileName}"
56
+ @click=${this.handleClick}
57
+ />
58
+ ${
59
+ isPdf
60
+ ? html`
61
+ <!-- PDF badge overlay -->
62
+ <div class="absolute bottom-0 left-0 right-0 bg-background/90 px-1 py-0.5 rounded-b-lg">
63
+ <div class="text-[10px] text-muted-foreground text-center font-medium">${i18n("PDF")}</div>
64
+ </div>
65
+ `
66
+ : ""
67
+ }
68
+ </div>
69
+ `
70
+ : html`
71
+ <!-- Fallback: document icon + filename -->
72
+ <div
73
+ class="w-16 h-16 rounded-lg border border-input cursor-pointer hover:opacity-80 transition-opacity bg-muted text-muted-foreground flex flex-col items-center justify-center p-2"
74
+ @click=${this.handleClick}
75
+ title="${this.attachment.fileName}"
76
+ >
77
+ ${getDocumentIcon()}
78
+ <div class="text-[10px] text-center truncate w-full">
79
+ ${
80
+ this.attachment.fileName.length > 10
81
+ ? `${this.attachment.fileName.substring(0, 8)}...`
82
+ : this.attachment.fileName
83
+ }
84
+ </div>
85
+ </div>
86
+ `
87
+ }
88
+ ${
89
+ this.showDelete
90
+ ? html`
91
+ <button
92
+ @click=${(e: Event) => {
93
+ e.stopPropagation();
94
+ this.onDelete?.();
95
+ }}
96
+ class="absolute -top-1 -right-1 w-5 h-5 bg-background hover:bg-muted text-muted-foreground hover:text-foreground rounded-full flex items-center justify-center opacity-100 hover:opacity-100 [@media(hover:hover)]:opacity-0 [@media(hover:hover)]:group-hover:opacity-100 transition-opacity border border-input shadow-sm"
97
+ title="${i18n("Remove")}"
98
+ >
99
+ ${icon(X, "xs")}
100
+ </button>
101
+ `
102
+ : ""
103
+ }
104
+ </div>
105
+ `;
106
+ }
107
+ }
@@ -0,0 +1,72 @@
1
+ import { icon } from "@mariozechner/mini-lit";
2
+ import { LitElement } from "lit";
3
+ import { property, state } from "lit/decorators.js";
4
+ import { html } from "lit/html.js";
5
+ import { Check, Copy } from "lucide";
6
+ import { i18n } from "../utils/i18n.js";
7
+
8
+ export class ConsoleBlock extends LitElement {
9
+ @property() content: string = "";
10
+ @property() variant: "default" | "error" = "default";
11
+ @state() private copied = false;
12
+
13
+ protected override createRenderRoot(): HTMLElement | DocumentFragment {
14
+ return this;
15
+ }
16
+
17
+ override connectedCallback(): void {
18
+ super.connectedCallback();
19
+ this.style.display = "block";
20
+ }
21
+
22
+ private async copy() {
23
+ try {
24
+ await navigator.clipboard.writeText(this.content || "");
25
+ this.copied = true;
26
+ setTimeout(() => {
27
+ this.copied = false;
28
+ }, 1500);
29
+ } catch (e) {
30
+ console.error("Copy failed", e);
31
+ }
32
+ }
33
+
34
+ override updated() {
35
+ // Auto-scroll to bottom on content changes
36
+ const container = this.querySelector(".console-scroll") as HTMLElement | null;
37
+ if (container) {
38
+ container.scrollTop = container.scrollHeight;
39
+ }
40
+ }
41
+
42
+ override render() {
43
+ const isError = this.variant === "error";
44
+ const textClass = isError ? "text-destructive" : "text-foreground";
45
+
46
+ return html`
47
+ <div class="border border-border rounded-lg overflow-hidden">
48
+ <div class="flex items-center justify-between px-3 py-1.5 bg-muted border-b border-border">
49
+ <span class="text-xs text-muted-foreground font-mono">${i18n("console")}</span>
50
+ <button
51
+ @click=${() => this.copy()}
52
+ class="flex items-center gap-1 px-2 py-0.5 text-xs rounded hover:bg-accent text-muted-foreground hover:text-accent-foreground transition-colors"
53
+ title="${i18n("Copy output")}"
54
+ >
55
+ ${this.copied ? icon(Check, "sm") : icon(Copy, "sm")}
56
+ ${this.copied ? html`<span>${i18n("Copied!")}</span>` : ""}
57
+ </button>
58
+ </div>
59
+ <div class="console-scroll overflow-auto max-h-64">
60
+ <pre class="!bg-background !border-0 !rounded-none m-0 p-3 text-xs ${textClass} font-mono whitespace-pre-wrap">
61
+ ${this.content || ""}</pre
62
+ >
63
+ </div>
64
+ </div>
65
+ `;
66
+ }
67
+ }
68
+
69
+ // Register custom element
70
+ if (!customElements.get("console-block")) {
71
+ customElements.define("console-block", ConsoleBlock);
72
+ }
@@ -0,0 +1,100 @@
1
+ import { i18n } from "@mariozechner/mini-lit";
2
+ import { Button } from "@mariozechner/mini-lit/dist/Button.js";
3
+ import { html, LitElement, type TemplateResult } from "lit";
4
+ import { customElement, property } from "lit/decorators.js";
5
+ import type { CustomProvider } from "../storage/stores/custom-providers-store.js";
6
+
7
+ @customElement("custom-provider-card")
8
+ export class CustomProviderCard extends LitElement {
9
+ @property({ type: Object }) provider!: CustomProvider;
10
+ @property({ type: Boolean }) isAutoDiscovery = false;
11
+ @property({ type: Object }) status?: { modelCount: number; status: "connected" | "disconnected" | "checking" };
12
+ @property() onRefresh?: (provider: CustomProvider) => void;
13
+ @property() onEdit?: (provider: CustomProvider) => void;
14
+ @property() onDelete?: (provider: CustomProvider) => void;
15
+
16
+ protected createRenderRoot() {
17
+ return this;
18
+ }
19
+
20
+ private renderStatus(): TemplateResult {
21
+ if (!this.isAutoDiscovery) {
22
+ return html`
23
+ <div class="text-xs text-muted-foreground mt-1">
24
+ ${i18n("Models")}: ${this.provider.models?.length || 0}
25
+ </div>
26
+ `;
27
+ }
28
+
29
+ if (!this.status) return html``;
30
+
31
+ const statusIcon =
32
+ this.status.status === "connected"
33
+ ? html`<span class="text-green-500">●</span>`
34
+ : this.status.status === "checking"
35
+ ? html`<span class="text-yellow-500">●</span>`
36
+ : html`<span class="text-red-500">●</span>`;
37
+
38
+ const statusText =
39
+ this.status.status === "connected"
40
+ ? `${this.status.modelCount} ${i18n("models")}`
41
+ : this.status.status === "checking"
42
+ ? i18n("Checking...")
43
+ : i18n("Disconnected");
44
+
45
+ return html`
46
+ <div class="text-xs text-muted-foreground mt-1 flex items-center gap-1">
47
+ ${statusIcon} ${statusText}
48
+ </div>
49
+ `;
50
+ }
51
+
52
+ render(): TemplateResult {
53
+ return html`
54
+ <div class="border border-border rounded-lg p-4 space-y-2">
55
+ <div class="flex items-center justify-between">
56
+ <div class="flex-1">
57
+ <div class="font-medium text-sm text-foreground">${this.provider.name}</div>
58
+ <div class="text-xs text-muted-foreground mt-1">
59
+ <span class="capitalize">${this.provider.type}</span>
60
+ ${this.provider.baseUrl ? html` • ${this.provider.baseUrl}` : ""}
61
+ </div>
62
+ ${this.renderStatus()}
63
+ </div>
64
+ <div class="flex gap-2">
65
+ ${
66
+ this.isAutoDiscovery && this.onRefresh
67
+ ? Button({
68
+ onClick: () => this.onRefresh?.(this.provider),
69
+ variant: "ghost",
70
+ size: "sm",
71
+ children: i18n("Refresh"),
72
+ })
73
+ : ""
74
+ }
75
+ ${
76
+ this.onEdit
77
+ ? Button({
78
+ onClick: () => this.onEdit?.(this.provider),
79
+ variant: "ghost",
80
+ size: "sm",
81
+ children: i18n("Edit"),
82
+ })
83
+ : ""
84
+ }
85
+ ${
86
+ this.onDelete
87
+ ? Button({
88
+ onClick: () => this.onDelete?.(this.provider),
89
+ variant: "ghost",
90
+ size: "sm",
91
+ children: i18n("Delete"),
92
+ })
93
+ : ""
94
+ }
95
+ </div>
96
+ </div>
97
+ </div>
98
+ `;
99
+ }
100
+ }
@@ -0,0 +1,46 @@
1
+ import { icon } from "@mariozechner/mini-lit";
2
+ import { html, LitElement, type TemplateResult } from "lit";
3
+ import { customElement, property, state } from "lit/decorators.js";
4
+ import { ChevronDown, ChevronRight } from "lucide";
5
+
6
+ /**
7
+ * Reusable expandable section component for tool renderers.
8
+ * Captures children in connectedCallback and re-renders them in the details area.
9
+ */
10
+ @customElement("expandable-section")
11
+ export class ExpandableSection extends LitElement {
12
+ @property() summary!: string;
13
+ @property({ type: Boolean }) defaultExpanded = false;
14
+ @state() private expanded = false;
15
+ private capturedChildren: Node[] = [];
16
+
17
+ protected createRenderRoot() {
18
+ return this; // light DOM
19
+ }
20
+
21
+ override connectedCallback() {
22
+ super.connectedCallback();
23
+ // Capture children before first render
24
+ this.capturedChildren = Array.from(this.childNodes);
25
+ // Clear children (we'll re-insert them in render)
26
+ this.innerHTML = "";
27
+ this.expanded = this.defaultExpanded;
28
+ }
29
+
30
+ override render(): TemplateResult {
31
+ return html`
32
+ <div>
33
+ <button
34
+ @click=${() => {
35
+ this.expanded = !this.expanded;
36
+ }}
37
+ class="flex items-center gap-2 text-sm text-muted-foreground hover:text-foreground transition-colors w-full text-left"
38
+ >
39
+ ${icon(this.expanded ? ChevronDown : ChevronRight, "sm")}
40
+ <span>${this.summary}</span>
41
+ </button>
42
+ ${this.expanded ? html`<div class="mt-2">${this.capturedChildren}</div>` : ""}
43
+ </div>
44
+ `;
45
+ }
46
+ }
@@ -0,0 +1,113 @@
1
+ import { type BaseComponentProps, fc } from "@mariozechner/mini-lit/dist/mini.js";
2
+ import { html } from "lit";
3
+ import { type Ref, ref } from "lit/directives/ref.js";
4
+ import { i18n } from "../utils/i18n.js";
5
+
6
+ export type InputType = "text" | "email" | "password" | "number" | "url" | "tel" | "search";
7
+ export type InputSize = "sm" | "md" | "lg";
8
+
9
+ export interface InputProps extends BaseComponentProps {
10
+ type?: InputType;
11
+ size?: InputSize;
12
+ value?: string;
13
+ placeholder?: string;
14
+ label?: string;
15
+ error?: string;
16
+ disabled?: boolean;
17
+ required?: boolean;
18
+ name?: string;
19
+ autocomplete?: string;
20
+ min?: number;
21
+ max?: number;
22
+ step?: number;
23
+ inputRef?: Ref<HTMLInputElement>;
24
+ onInput?: (e: Event) => void;
25
+ onChange?: (e: Event) => void;
26
+ onKeyDown?: (e: KeyboardEvent) => void;
27
+ onKeyUp?: (e: KeyboardEvent) => void;
28
+ }
29
+
30
+ export const Input = fc<InputProps>(
31
+ ({
32
+ type = "text",
33
+ size = "md",
34
+ value = "",
35
+ placeholder = "",
36
+ label = "",
37
+ error = "",
38
+ disabled = false,
39
+ required = false,
40
+ name = "",
41
+ autocomplete = "",
42
+ min,
43
+ max,
44
+ step,
45
+ inputRef,
46
+ onInput,
47
+ onChange,
48
+ onKeyDown,
49
+ onKeyUp,
50
+ className = "",
51
+ }) => {
52
+ const sizeClasses = {
53
+ sm: "h-8 px-3 py-1 text-sm",
54
+ md: "h-9 px-3 py-1 text-sm md:text-sm",
55
+ lg: "h-10 px-4 py-1 text-base",
56
+ };
57
+
58
+ const baseClasses =
59
+ "flex w-full min-w-0 rounded-md border bg-transparent text-foreground shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium";
60
+ const interactionClasses =
61
+ "placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground";
62
+ const focusClasses = "focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]";
63
+ const darkClasses = "dark:bg-input/30";
64
+ const stateClasses = error
65
+ ? "border-destructive aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40"
66
+ : "border-input";
67
+ const disabledClasses = "disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50";
68
+
69
+ const handleInput = (e: Event) => {
70
+ onInput?.(e);
71
+ };
72
+
73
+ const handleChange = (e: Event) => {
74
+ onChange?.(e);
75
+ };
76
+
77
+ return html`
78
+ <div class="flex flex-col gap-1.5 ${className}">
79
+ ${
80
+ label
81
+ ? html`
82
+ <label class="text-sm font-medium text-foreground">
83
+ ${label} ${required ? html`<span class="text-destructive">${i18n("*")}</span>` : ""}
84
+ </label>
85
+ `
86
+ : ""
87
+ }
88
+ <input
89
+ type="${type}"
90
+ class="${baseClasses} ${
91
+ sizeClasses[size]
92
+ } ${interactionClasses} ${focusClasses} ${darkClasses} ${stateClasses} ${disabledClasses}"
93
+ .value=${value}
94
+ placeholder="${placeholder}"
95
+ ?disabled=${disabled}
96
+ ?required=${required}
97
+ ?aria-invalid=${!!error}
98
+ name="${name}"
99
+ autocomplete="${autocomplete}"
100
+ min="${min ?? ""}"
101
+ max="${max ?? ""}"
102
+ step="${step ?? ""}"
103
+ @input=${handleInput}
104
+ @change=${handleChange}
105
+ @keydown=${onKeyDown}
106
+ @keyup=${onKeyUp}
107
+ ${inputRef ? ref(inputRef) : ""}
108
+ />
109
+ ${error ? html`<span class="text-sm text-destructive">${error}</span>` : ""}
110
+ </div>
111
+ `;
112
+ },
113
+ );