@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,363 @@
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 { customElement, property } from "lit/decorators.js";
9
+ import { renderTool } from "../tools/index.js";
10
+ import { formatUsage } from "../utils/format.js";
11
+ import { i18n } from "../utils/i18n.js";
12
+ import "./ThinkingBlock.js";
13
+ let UserMessage = class UserMessage extends LitElement {
14
+ message;
15
+ createRenderRoot() {
16
+ return this;
17
+ }
18
+ connectedCallback() {
19
+ super.connectedCallback();
20
+ this.style.display = "block";
21
+ }
22
+ render() {
23
+ const content = typeof this.message.content === "string"
24
+ ? this.message.content
25
+ : this.message.content.find((c) => c.type === "text")?.text || "";
26
+ return html `
27
+ <div class="flex justify-start mx-4">
28
+ <div class="user-message-container py-2 px-4 rounded-xl">
29
+ <markdown-block .content=${content}></markdown-block>
30
+ ${this.message.role === "user-with-attachments" &&
31
+ this.message.attachments &&
32
+ this.message.attachments.length > 0
33
+ ? html `
34
+ <div class="mt-3 flex flex-wrap gap-2">
35
+ ${this.message.attachments.map((attachment) => html ` <attachment-tile .attachment=${attachment}></attachment-tile> `)}
36
+ </div>
37
+ `
38
+ : ""}
39
+ </div>
40
+ </div>
41
+ `;
42
+ }
43
+ };
44
+ __decorate([
45
+ property({ type: Object })
46
+ ], UserMessage.prototype, "message", void 0);
47
+ UserMessage = __decorate([
48
+ customElement("user-message")
49
+ ], UserMessage);
50
+ export { UserMessage };
51
+ let AssistantMessage = class AssistantMessage extends LitElement {
52
+ message;
53
+ tools;
54
+ pendingToolCalls;
55
+ hideToolCalls = false;
56
+ toolResultsById;
57
+ isStreaming = false;
58
+ hidePendingToolCalls = false;
59
+ onCostClick;
60
+ createRenderRoot() {
61
+ return this;
62
+ }
63
+ connectedCallback() {
64
+ super.connectedCallback();
65
+ this.style.display = "block";
66
+ }
67
+ render() {
68
+ // Render content in the order it appears
69
+ const orderedParts = [];
70
+ for (const chunk of this.message.content) {
71
+ if (chunk.type === "text" && chunk.text.trim() !== "") {
72
+ orderedParts.push(html `<markdown-block .content=${chunk.text}></markdown-block>`);
73
+ }
74
+ else if (chunk.type === "thinking" && chunk.thinking.trim() !== "") {
75
+ orderedParts.push(html `<thinking-block .content=${chunk.thinking} .isStreaming=${this.isStreaming}></thinking-block>`);
76
+ }
77
+ else if (chunk.type === "toolCall") {
78
+ if (!this.hideToolCalls) {
79
+ const tool = this.tools?.find((t) => t.name === chunk.name);
80
+ const pending = this.pendingToolCalls?.has(chunk.id) ?? false;
81
+ const result = this.toolResultsById?.get(chunk.id);
82
+ // Skip rendering pending tool calls when hidePendingToolCalls is true
83
+ // (used to prevent duplication when StreamingMessageContainer is showing them)
84
+ if (this.hidePendingToolCalls && pending && !result) {
85
+ continue;
86
+ }
87
+ // A tool call is aborted if the message was aborted and there's no result for this tool call
88
+ const aborted = this.message.stopReason === "aborted" && !result;
89
+ orderedParts.push(html `<tool-message
90
+ .tool=${tool}
91
+ .toolCall=${chunk}
92
+ .result=${result}
93
+ .pending=${pending}
94
+ .aborted=${aborted}
95
+ .isStreaming=${this.isStreaming}
96
+ ></tool-message>`);
97
+ }
98
+ }
99
+ }
100
+ return html `
101
+ <div>
102
+ ${orderedParts.length ? html ` <div class="px-4 flex flex-col gap-3">${orderedParts}</div> ` : ""}
103
+ ${this.message.usage && !this.isStreaming
104
+ ? this.onCostClick
105
+ ? html ` <div class="px-4 mt-2 text-xs text-muted-foreground cursor-pointer hover:text-foreground transition-colors" @click=${this.onCostClick}>${formatUsage(this.message.usage)}</div> `
106
+ : html ` <div class="px-4 mt-2 text-xs text-muted-foreground">${formatUsage(this.message.usage)}</div> `
107
+ : ""}
108
+ ${this.message.stopReason === "error" && this.message.errorMessage
109
+ ? html `
110
+ <div class="mx-4 mt-3 p-3 bg-destructive/10 text-destructive rounded-lg text-sm overflow-hidden">
111
+ <strong>${i18n("Error:")}</strong> ${this.message.errorMessage}
112
+ </div>
113
+ `
114
+ : ""}
115
+ ${this.message.stopReason === "aborted"
116
+ ? html `<span class="text-sm text-destructive italic">${i18n("Request aborted")}</span>`
117
+ : ""}
118
+ </div>
119
+ `;
120
+ }
121
+ };
122
+ __decorate([
123
+ property({ type: Object })
124
+ ], AssistantMessage.prototype, "message", void 0);
125
+ __decorate([
126
+ property({ type: Array })
127
+ ], AssistantMessage.prototype, "tools", void 0);
128
+ __decorate([
129
+ property({ type: Object })
130
+ ], AssistantMessage.prototype, "pendingToolCalls", void 0);
131
+ __decorate([
132
+ property({ type: Boolean })
133
+ ], AssistantMessage.prototype, "hideToolCalls", void 0);
134
+ __decorate([
135
+ property({ type: Object })
136
+ ], AssistantMessage.prototype, "toolResultsById", void 0);
137
+ __decorate([
138
+ property({ type: Boolean })
139
+ ], AssistantMessage.prototype, "isStreaming", void 0);
140
+ __decorate([
141
+ property({ type: Boolean })
142
+ ], AssistantMessage.prototype, "hidePendingToolCalls", void 0);
143
+ __decorate([
144
+ property({ attribute: false })
145
+ ], AssistantMessage.prototype, "onCostClick", void 0);
146
+ AssistantMessage = __decorate([
147
+ customElement("assistant-message")
148
+ ], AssistantMessage);
149
+ export { AssistantMessage };
150
+ let ToolMessageDebugView = class ToolMessageDebugView extends LitElement {
151
+ callArgs;
152
+ result;
153
+ hasResult = false;
154
+ createRenderRoot() {
155
+ return this; // light DOM for shared styles
156
+ }
157
+ connectedCallback() {
158
+ super.connectedCallback();
159
+ this.style.display = "block";
160
+ }
161
+ pretty(value) {
162
+ try {
163
+ if (typeof value === "string") {
164
+ const maybeJson = JSON.parse(value);
165
+ return { content: JSON.stringify(maybeJson, null, 2), isJson: true };
166
+ }
167
+ return { content: JSON.stringify(value, null, 2), isJson: true };
168
+ }
169
+ catch {
170
+ return { content: typeof value === "string" ? value : String(value), isJson: false };
171
+ }
172
+ }
173
+ render() {
174
+ const textOutput = this.result?.content
175
+ ?.filter((c) => c.type === "text")
176
+ .map((c) => c.text)
177
+ .join("\n") || "";
178
+ const output = this.pretty(textOutput);
179
+ const details = this.pretty(this.result?.details);
180
+ return html `
181
+ <div class="mt-3 flex flex-col gap-2">
182
+ <div>
183
+ <div class="text-xs font-medium mb-1 text-muted-foreground">${i18n("Call")}</div>
184
+ <code-block .code=${this.pretty(this.callArgs).content} language="json"></code-block>
185
+ </div>
186
+ <div>
187
+ <div class="text-xs font-medium mb-1 text-muted-foreground">${i18n("Result")}</div>
188
+ ${this.hasResult
189
+ ? html `<code-block .code=${output.content} language="${output.isJson ? "json" : "text"}"></code-block>
190
+ <code-block .code=${details.content} language="${details.isJson ? "json" : "text"}"></code-block>`
191
+ : html `<div class="text-xs text-muted-foreground">${i18n("(no result)")}</div>`}
192
+ </div>
193
+ </div>
194
+ `;
195
+ }
196
+ };
197
+ __decorate([
198
+ property({ type: Object })
199
+ ], ToolMessageDebugView.prototype, "callArgs", void 0);
200
+ __decorate([
201
+ property({ type: Object })
202
+ ], ToolMessageDebugView.prototype, "result", void 0);
203
+ __decorate([
204
+ property({ type: Boolean })
205
+ ], ToolMessageDebugView.prototype, "hasResult", void 0);
206
+ ToolMessageDebugView = __decorate([
207
+ customElement("tool-message-debug")
208
+ ], ToolMessageDebugView);
209
+ export { ToolMessageDebugView };
210
+ let ToolMessage = class ToolMessage extends LitElement {
211
+ toolCall;
212
+ tool;
213
+ result;
214
+ pending = false;
215
+ aborted = false;
216
+ isStreaming = false;
217
+ createRenderRoot() {
218
+ return this;
219
+ }
220
+ connectedCallback() {
221
+ super.connectedCallback();
222
+ this.style.display = "block";
223
+ }
224
+ render() {
225
+ const toolName = this.tool?.name || this.toolCall.name;
226
+ // Render tool content (renderer handles errors and styling)
227
+ const result = this.aborted
228
+ ? {
229
+ role: "toolResult",
230
+ isError: true,
231
+ content: [],
232
+ toolCallId: this.toolCall.id,
233
+ toolName: this.toolCall.name,
234
+ timestamp: Date.now(),
235
+ }
236
+ : this.result;
237
+ const renderResult = renderTool(toolName, this.toolCall.arguments, result, !this.aborted && (this.isStreaming || this.pending));
238
+ // Handle custom rendering (no card wrapper)
239
+ if (renderResult.isCustom) {
240
+ return renderResult.content;
241
+ }
242
+ // Default: wrap in card
243
+ return html `
244
+ <div class="p-2.5 border border-border rounded-md bg-card text-card-foreground shadow-xs">
245
+ ${renderResult.content}
246
+ </div>
247
+ `;
248
+ }
249
+ };
250
+ __decorate([
251
+ property({ type: Object })
252
+ ], ToolMessage.prototype, "toolCall", void 0);
253
+ __decorate([
254
+ property({ type: Object })
255
+ ], ToolMessage.prototype, "tool", void 0);
256
+ __decorate([
257
+ property({ type: Object })
258
+ ], ToolMessage.prototype, "result", void 0);
259
+ __decorate([
260
+ property({ type: Boolean })
261
+ ], ToolMessage.prototype, "pending", void 0);
262
+ __decorate([
263
+ property({ type: Boolean })
264
+ ], ToolMessage.prototype, "aborted", void 0);
265
+ __decorate([
266
+ property({ type: Boolean })
267
+ ], ToolMessage.prototype, "isStreaming", void 0);
268
+ ToolMessage = __decorate([
269
+ customElement("tool-message")
270
+ ], ToolMessage);
271
+ export { ToolMessage };
272
+ let AbortedMessage = class AbortedMessage extends LitElement {
273
+ createRenderRoot() {
274
+ return this;
275
+ }
276
+ connectedCallback() {
277
+ super.connectedCallback();
278
+ this.style.display = "block";
279
+ }
280
+ render() {
281
+ return html `<span class="text-sm text-destructive italic">${i18n("Request aborted")}</span>`;
282
+ }
283
+ };
284
+ AbortedMessage = __decorate([
285
+ customElement("aborted-message")
286
+ ], AbortedMessage);
287
+ export { AbortedMessage };
288
+ /**
289
+ * Convert attachments to content blocks for LLM.
290
+ * - Images become ImageContent blocks
291
+ * - Documents with extractedText become TextContent blocks with filename header
292
+ */
293
+ export function convertAttachments(attachments) {
294
+ const content = [];
295
+ for (const attachment of attachments) {
296
+ if (attachment.type === "image") {
297
+ content.push({
298
+ type: "image",
299
+ data: attachment.content,
300
+ mimeType: attachment.mimeType,
301
+ });
302
+ }
303
+ else if (attachment.type === "document" && attachment.extractedText) {
304
+ content.push({
305
+ type: "text",
306
+ text: `\n\n[Document: ${attachment.fileName}]\n${attachment.extractedText}`,
307
+ });
308
+ }
309
+ }
310
+ return content;
311
+ }
312
+ /**
313
+ * Check if a message is a UserMessageWithAttachments.
314
+ */
315
+ export function isUserMessageWithAttachments(msg) {
316
+ return msg.role === "user-with-attachments";
317
+ }
318
+ /**
319
+ * Check if a message is an ArtifactMessage.
320
+ */
321
+ export function isArtifactMessage(msg) {
322
+ return msg.role === "artifact";
323
+ }
324
+ /**
325
+ * Default convertToLlm for web-ui apps.
326
+ *
327
+ * Handles:
328
+ * - UserMessageWithAttachments: converts to user message with content blocks
329
+ * - ArtifactMessage: filtered out (UI-only, for session reconstruction)
330
+ * - Standard LLM messages (user, assistant, toolResult): passed through
331
+ */
332
+ export function defaultConvertToLlm(messages) {
333
+ return messages
334
+ .filter((m) => {
335
+ // Filter out artifact messages - they're for session reconstruction only
336
+ if (isArtifactMessage(m)) {
337
+ return false;
338
+ }
339
+ return true;
340
+ })
341
+ .map((m) => {
342
+ // Convert user-with-attachments to user message with content blocks
343
+ if (isUserMessageWithAttachments(m)) {
344
+ const textContent = typeof m.content === "string" ? [{ type: "text", text: m.content }] : [...m.content];
345
+ if (m.attachments) {
346
+ textContent.push(...convertAttachments(m.attachments));
347
+ }
348
+ return {
349
+ role: "user",
350
+ content: textContent,
351
+ timestamp: m.timestamp,
352
+ };
353
+ }
354
+ // Pass through standard LLM roles
355
+ if (m.role === "user" || m.role === "assistant" || m.role === "toolResult") {
356
+ return m;
357
+ }
358
+ // Filter out unknown message types
359
+ return null;
360
+ })
361
+ .filter((m) => m !== null);
362
+ }
363
+ //# sourceMappingURL=Messages.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Messages.js","sourceRoot":"","sources":["../../src/components/Messages.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { LitElement } from "lit";
2
+ export declare class ProviderKeyInput extends LitElement {
3
+ provider: string;
4
+ private keyInput;
5
+ private testing;
6
+ private failed;
7
+ private hasKey;
8
+ private inputChanged;
9
+ protected createRenderRoot(): this;
10
+ connectedCallback(): Promise<void>;
11
+ private checkKeyStatus;
12
+ private testApiKey;
13
+ private saveKey;
14
+ render(): import("lit").TemplateResult<1>;
15
+ }
16
+ //# sourceMappingURL=ProviderKeyInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProviderKeyInput.d.ts","sourceRoot":"","sources":["../../src/components/ProviderKeyInput.ts"],"names":[],"mappings":"AAIA,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAmBvC,qBACa,gBAAiB,SAAQ,UAAU;IACnC,QAAQ,SAAM;IACjB,OAAO,CAAC,QAAQ,CAAM;IACtB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,YAAY,CAAS;IAEtC,SAAS,CAAC,gBAAgB,SAEzB;IAEc,iBAAiB,kBAG/B;YAEa,cAAc;YASd,UAAU;YAgCV,OAAO;IAiCrB,MAAM,oCAoCL;CACD"}
@@ -0,0 +1,168 @@
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 { complete, getModel } from "@draht/ai";
8
+ import { i18n } from "@mariozechner/mini-lit";
9
+ import { Badge } from "@mariozechner/mini-lit/dist/Badge.js";
10
+ import { Button } from "@mariozechner/mini-lit/dist/Button.js";
11
+ import { html, LitElement } from "lit";
12
+ import { customElement, property, state } from "lit/decorators.js";
13
+ import { getAppStorage } from "../storage/app-storage.js";
14
+ import { applyProxyIfNeeded } from "../utils/proxy-utils.js";
15
+ import { Input } from "./Input.js";
16
+ // Test models for each provider
17
+ const TEST_MODELS = {
18
+ anthropic: "claude-3-5-haiku-20241022",
19
+ openai: "gpt-4o-mini",
20
+ google: "gemini-2.5-flash",
21
+ groq: "openai/gpt-oss-20b",
22
+ openrouter: "z-ai/glm-4.6",
23
+ "vercel-ai-gateway": "anthropic/claude-opus-4.5",
24
+ cerebras: "gpt-oss-120b",
25
+ xai: "grok-4-fast-non-reasoning",
26
+ zai: "glm-4.5-air",
27
+ };
28
+ let ProviderKeyInput = class ProviderKeyInput extends LitElement {
29
+ provider = "";
30
+ keyInput = "";
31
+ testing = false;
32
+ failed = false;
33
+ hasKey = false;
34
+ inputChanged = false;
35
+ createRenderRoot() {
36
+ return this;
37
+ }
38
+ async connectedCallback() {
39
+ super.connectedCallback();
40
+ await this.checkKeyStatus();
41
+ }
42
+ async checkKeyStatus() {
43
+ try {
44
+ const key = await getAppStorage().providerKeys.get(this.provider);
45
+ this.hasKey = !!key;
46
+ }
47
+ catch (error) {
48
+ console.error("Failed to check key status:", error);
49
+ }
50
+ }
51
+ async testApiKey(provider, apiKey) {
52
+ try {
53
+ const modelId = TEST_MODELS[provider];
54
+ // Returning true here for Ollama and friends. Can' know which model to use for testing
55
+ if (!modelId)
56
+ return true;
57
+ let model = getModel(provider, modelId);
58
+ if (!model)
59
+ return false;
60
+ // Get proxy URL from settings (if available)
61
+ const proxyEnabled = await getAppStorage().settings.get("proxy.enabled");
62
+ const proxyUrl = await getAppStorage().settings.get("proxy.url");
63
+ // Apply proxy only if this provider/key combination requires it
64
+ model = applyProxyIfNeeded(model, apiKey, proxyEnabled ? proxyUrl || undefined : undefined);
65
+ const context = {
66
+ messages: [{ role: "user", content: "Reply with: ok", timestamp: Date.now() }],
67
+ };
68
+ const result = await complete(model, context, {
69
+ apiKey,
70
+ maxTokens: 200,
71
+ });
72
+ return result.stopReason === "stop";
73
+ }
74
+ catch (error) {
75
+ console.error(`API key test failed for ${provider}:`, error);
76
+ return false;
77
+ }
78
+ }
79
+ async saveKey() {
80
+ if (!this.keyInput)
81
+ return;
82
+ this.testing = true;
83
+ this.failed = false;
84
+ const success = await this.testApiKey(this.provider, this.keyInput);
85
+ this.testing = false;
86
+ if (success) {
87
+ try {
88
+ await getAppStorage().providerKeys.set(this.provider, this.keyInput);
89
+ this.hasKey = true;
90
+ this.inputChanged = false;
91
+ this.requestUpdate();
92
+ }
93
+ catch (error) {
94
+ console.error("Failed to save API key:", error);
95
+ this.failed = true;
96
+ setTimeout(() => {
97
+ this.failed = false;
98
+ this.requestUpdate();
99
+ }, 5000);
100
+ }
101
+ }
102
+ else {
103
+ this.failed = true;
104
+ setTimeout(() => {
105
+ this.failed = false;
106
+ this.requestUpdate();
107
+ }, 5000);
108
+ }
109
+ }
110
+ render() {
111
+ return html `
112
+ <div class="space-y-3">
113
+ <div class="flex items-center gap-2">
114
+ <span class="text-sm font-medium capitalize text-foreground">${this.provider}</span>
115
+ ${this.testing
116
+ ? Badge({ children: i18n("Testing..."), variant: "secondary" })
117
+ : this.hasKey
118
+ ? html `<span class="text-green-600 dark:text-green-400">✓</span>`
119
+ : ""}
120
+ ${this.failed ? Badge({ children: i18n("✗ Invalid"), variant: "destructive" }) : ""}
121
+ </div>
122
+ <div class="flex items-center gap-2">
123
+ ${Input({
124
+ type: "password",
125
+ placeholder: this.hasKey ? "••••••••••••" : i18n("Enter API key"),
126
+ value: this.keyInput,
127
+ onInput: (e) => {
128
+ this.keyInput = e.target.value;
129
+ this.inputChanged = true;
130
+ this.requestUpdate();
131
+ },
132
+ className: "flex-1",
133
+ })}
134
+ ${Button({
135
+ onClick: () => this.saveKey(),
136
+ variant: "default",
137
+ size: "sm",
138
+ disabled: !this.keyInput || this.testing || (this.hasKey && !this.inputChanged),
139
+ children: i18n("Save"),
140
+ })}
141
+ </div>
142
+ </div>
143
+ `;
144
+ }
145
+ };
146
+ __decorate([
147
+ property()
148
+ ], ProviderKeyInput.prototype, "provider", void 0);
149
+ __decorate([
150
+ state()
151
+ ], ProviderKeyInput.prototype, "keyInput", void 0);
152
+ __decorate([
153
+ state()
154
+ ], ProviderKeyInput.prototype, "testing", void 0);
155
+ __decorate([
156
+ state()
157
+ ], ProviderKeyInput.prototype, "failed", void 0);
158
+ __decorate([
159
+ state()
160
+ ], ProviderKeyInput.prototype, "hasKey", void 0);
161
+ __decorate([
162
+ state()
163
+ ], ProviderKeyInput.prototype, "inputChanged", void 0);
164
+ ProviderKeyInput = __decorate([
165
+ customElement("provider-key-input")
166
+ ], ProviderKeyInput);
167
+ export { ProviderKeyInput };
168
+ //# sourceMappingURL=ProviderKeyInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProviderKeyInput.js","sourceRoot":"","sources":["../../src/components/ProviderKeyInput.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,85 @@
1
+ import { LitElement } from "lit";
2
+ import { type MessageConsumer } from "./sandbox/RuntimeMessageRouter.js";
3
+ import type { SandboxRuntimeProvider } from "./sandbox/SandboxRuntimeProvider.js";
4
+ export interface SandboxFile {
5
+ fileName: string;
6
+ content: string | Uint8Array;
7
+ mimeType: string;
8
+ }
9
+ export interface SandboxResult {
10
+ success: boolean;
11
+ console: Array<{
12
+ type: string;
13
+ text: string;
14
+ }>;
15
+ files?: SandboxFile[];
16
+ error?: {
17
+ message: string;
18
+ stack: string;
19
+ };
20
+ returnValue?: any;
21
+ }
22
+ /**
23
+ * Function that returns the URL to the sandbox HTML file.
24
+ * Used in browser extensions to load sandbox.html via chrome.runtime.getURL().
25
+ */
26
+ export type SandboxUrlProvider = () => string;
27
+ /**
28
+ * Configuration for prepareHtmlDocument
29
+ */
30
+ export interface PrepareHtmlOptions {
31
+ /** True if this is an HTML artifact (inject into existing HTML), false if REPL (wrap in HTML) */
32
+ isHtmlArtifact: boolean;
33
+ /** True if this is a standalone download (no runtime bridge, no navigation interceptor) */
34
+ isStandalone?: boolean;
35
+ }
36
+ export declare class SandboxIframe extends LitElement {
37
+ private iframe?;
38
+ /**
39
+ * Optional: Provide a function that returns the sandbox HTML URL.
40
+ * If provided, the iframe will use this URL instead of srcdoc.
41
+ * This is required for browser extensions with strict CSP.
42
+ */
43
+ sandboxUrlProvider?: SandboxUrlProvider;
44
+ createRenderRoot(): this;
45
+ connectedCallback(): void;
46
+ disconnectedCallback(): void;
47
+ /**
48
+ * Load HTML content into sandbox and keep it displayed (for HTML artifacts)
49
+ * @param sandboxId Unique ID
50
+ * @param htmlContent Full HTML content
51
+ * @param providers Runtime providers to inject
52
+ * @param consumers Message consumers to register (optional)
53
+ */
54
+ loadContent(sandboxId: string, htmlContent: string, providers?: SandboxRuntimeProvider[], consumers?: MessageConsumer[]): void;
55
+ private loadViaSandboxUrl;
56
+ private loadViaSrcdoc;
57
+ /**
58
+ * Execute code in sandbox
59
+ * @param sandboxId Unique ID for this execution
60
+ * @param code User code (plain JS for REPL, or full HTML for artifacts)
61
+ * @param providers Runtime providers to inject
62
+ * @param consumers Additional message consumers (optional, execute has its own internal consumer)
63
+ * @param signal Abort signal
64
+ * @returns Promise resolving to execution result
65
+ */
66
+ execute(sandboxId: string, code: string, providers?: SandboxRuntimeProvider[], consumers?: MessageConsumer[], signal?: AbortSignal, isHtmlArtifact?: boolean): Promise<SandboxResult>;
67
+ /**
68
+ * Validate HTML using DOMParser - returns error message if invalid, null if valid
69
+ * Note: JavaScript syntax validation is done in sandbox.js to avoid CSP restrictions
70
+ */
71
+ private validateHtml;
72
+ /**
73
+ * Prepare complete HTML document with runtime + user code
74
+ * PUBLIC so HtmlArtifact can use it for download button
75
+ */
76
+ prepareHtmlDocument(sandboxId: string, userCode: string, providers?: SandboxRuntimeProvider[], options?: PrepareHtmlOptions): string;
77
+ /**
78
+ * Generate runtime script from providers
79
+ * @param sandboxId Unique sandbox ID
80
+ * @param providers Runtime providers
81
+ * @param isStandalone If true, skip runtime bridge and navigation interceptor (for standalone downloads)
82
+ */
83
+ private getRuntimeScript;
84
+ }
85
+ //# sourceMappingURL=SandboxedIframe.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SandboxedIframe.d.ts","sourceRoot":"","sources":["../../src/components/SandboxedIframe.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAIjC,OAAO,EAAE,KAAK,eAAe,EAA0B,MAAM,mCAAmC,CAAC;AACjG,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,qCAAqC,CAAC;AAElF,MAAM,WAAW,WAAW;IAC3B,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,GAAG,UAAU,CAAC;IAC7B,QAAQ,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,aAAa;IAC7B,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC/C,KAAK,CAAC,EAAE,WAAW,EAAE,CAAC;IACtB,KAAK,CAAC,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IAC3C,WAAW,CAAC,EAAE,GAAG,CAAC;CAClB;AAED;;;GAGG;AACH,MAAM,MAAM,kBAAkB,GAAG,MAAM,MAAM,CAAC;AAE9C;;GAEG;AACH,MAAM,WAAW,kBAAkB;IAClC,iGAAiG;IACjG,cAAc,EAAE,OAAO,CAAC;IACxB,2FAA2F;IAC3F,YAAY,CAAC,EAAE,OAAO,CAAC;CACvB;AAWD,qBACa,aAAc,SAAQ,UAAU;IAC5C,OAAO,CAAC,MAAM,CAAC,CAAoB;IAEnC;;;;OAIG;IAC6B,kBAAkB,CAAC,EAAE,kBAAkB,CAAC;IAExE,gBAAgB,SAEf;IAEQ,iBAAiB,SAEzB;IAEQ,oBAAoB,SAM5B;IAED;;;;;;OAMG;IACI,WAAW,CACjB,SAAS,EAAE,MAAM,EACjB,WAAW,EAAE,MAAM,EACnB,SAAS,GAAE,sBAAsB,EAAO,EACxC,SAAS,GAAE,eAAe,EAAO,GAC/B,IAAI,CAgDN;IAED,OAAO,CAAC,iBAAiB;IAuEzB,OAAO,CAAC,aAAa;IAyBrB;;;;;;;;OAQG;IACU,OAAO,CACnB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,MAAM,EACZ,SAAS,GAAE,sBAAsB,EAAO,EACxC,SAAS,GAAE,eAAe,EAAO,EACjC,MAAM,CAAC,EAAE,WAAW,EACpB,cAAc,GAAE,OAAe,GAC7B,OAAO,CAAC,aAAa,CAAC,CAiKxB;IAED;;;OAGG;IACH,OAAO,CAAC,YAAY;IAiBpB;;;OAGG;IACI,mBAAmB,CACzB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,MAAM,EAChB,SAAS,GAAE,sBAAsB,EAAO,EACxC,OAAO,CAAC,EAAE,kBAAkB,GAC1B,MAAM,CAiFR;IAED;;;;;OAKG;IACH,OAAO,CAAC,gBAAgB;CAgGxB"}