@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.
- package/CHANGELOG.md +276 -0
- package/README.md +601 -0
- package/dist/ChatPanel.d.ts +28 -0
- package/dist/ChatPanel.d.ts.map +1 -0
- package/dist/ChatPanel.js +193 -0
- package/dist/ChatPanel.js.map +1 -0
- package/dist/app.css +2 -0
- package/dist/components/AgentInterface.d.ts +39 -0
- package/dist/components/AgentInterface.d.ts.map +1 -0
- package/dist/components/AgentInterface.js +384 -0
- package/dist/components/AgentInterface.js.map +1 -0
- package/dist/components/AttachmentTile.d.ts +12 -0
- package/dist/components/AttachmentTile.d.ts.map +1 -0
- package/dist/components/AttachmentTile.js +110 -0
- package/dist/components/AttachmentTile.js.map +1 -0
- package/dist/components/ConsoleBlock.d.ts +12 -0
- package/dist/components/ConsoleBlock.d.ts.map +1 -0
- package/dist/components/ConsoleBlock.js +81 -0
- package/dist/components/ConsoleBlock.js.map +1 -0
- package/dist/components/CustomProviderCard.d.ts +17 -0
- package/dist/components/CustomProviderCard.d.ts.map +1 -0
- package/dist/components/CustomProviderCard.js +112 -0
- package/dist/components/CustomProviderCard.js.map +1 -0
- package/dist/components/ExpandableSection.d.ts +15 -0
- package/dist/components/ExpandableSection.d.ts.map +1 -0
- package/dist/components/ExpandableSection.js +61 -0
- package/dist/components/ExpandableSection.js.map +1 -0
- package/dist/components/Input.d.ts +26 -0
- package/dist/components/Input.d.ts.map +1 -0
- package/dist/components/Input.js +57 -0
- package/dist/components/Input.js.map +1 -0
- package/dist/components/MessageEditor.d.ts +44 -0
- package/dist/components/MessageEditor.d.ts.map +1 -0
- package/dist/components/MessageEditor.js +418 -0
- package/dist/components/MessageEditor.js.map +1 -0
- package/dist/components/MessageList.d.ts +14 -0
- package/dist/components/MessageList.d.ts.map +1 -0
- package/dist/components/MessageList.js +104 -0
- package/dist/components/MessageList.js.map +1 -0
- package/dist/components/Messages.d.ts +95 -0
- package/dist/components/Messages.d.ts.map +1 -0
- package/dist/components/Messages.js +363 -0
- package/dist/components/Messages.js.map +1 -0
- package/dist/components/ProviderKeyInput.d.ts +16 -0
- package/dist/components/ProviderKeyInput.d.ts.map +1 -0
- package/dist/components/ProviderKeyInput.js +168 -0
- package/dist/components/ProviderKeyInput.js.map +1 -0
- package/dist/components/SandboxedIframe.d.ts +85 -0
- package/dist/components/SandboxedIframe.d.ts.map +1 -0
- package/dist/components/SandboxedIframe.js +518 -0
- package/dist/components/SandboxedIframe.js.map +1 -0
- package/dist/components/StreamingMessageContainer.d.ts +19 -0
- package/dist/components/StreamingMessageContainer.d.ts.map +1 -0
- package/dist/components/StreamingMessageContainer.js +117 -0
- package/dist/components/StreamingMessageContainer.js.map +1 -0
- package/dist/components/ThinkingBlock.d.ts +11 -0
- package/dist/components/ThinkingBlock.d.ts.map +1 -0
- package/dist/components/ThinkingBlock.js +56 -0
- package/dist/components/ThinkingBlock.js.map +1 -0
- package/dist/components/message-renderer-registry.d.ts +12 -0
- package/dist/components/message-renderer-registry.d.ts.map +1 -0
- package/dist/components/message-renderer-registry.js +12 -0
- package/dist/components/message-renderer-registry.js.map +1 -0
- package/dist/components/sandbox/ArtifactsRuntimeProvider.d.ts +35 -0
- package/dist/components/sandbox/ArtifactsRuntimeProvider.d.ts.map +1 -0
- package/dist/components/sandbox/ArtifactsRuntimeProvider.js +192 -0
- package/dist/components/sandbox/ArtifactsRuntimeProvider.js.map +1 -0
- package/dist/components/sandbox/AttachmentsRuntimeProvider.d.ts +17 -0
- package/dist/components/sandbox/AttachmentsRuntimeProvider.d.ts.map +1 -0
- package/dist/components/sandbox/AttachmentsRuntimeProvider.js +65 -0
- package/dist/components/sandbox/AttachmentsRuntimeProvider.js.map +1 -0
- package/dist/components/sandbox/ConsoleRuntimeProvider.d.ts +42 -0
- package/dist/components/sandbox/ConsoleRuntimeProvider.d.ts.map +1 -0
- package/dist/components/sandbox/ConsoleRuntimeProvider.js +159 -0
- package/dist/components/sandbox/ConsoleRuntimeProvider.js.map +1 -0
- package/dist/components/sandbox/FileDownloadRuntimeProvider.d.ts +30 -0
- package/dist/components/sandbox/FileDownloadRuntimeProvider.d.ts.map +1 -0
- package/dist/components/sandbox/FileDownloadRuntimeProvider.js +95 -0
- package/dist/components/sandbox/FileDownloadRuntimeProvider.js.map +1 -0
- package/dist/components/sandbox/RuntimeMessageBridge.d.ts +19 -0
- package/dist/components/sandbox/RuntimeMessageBridge.d.ts.map +1 -0
- package/dist/components/sandbox/RuntimeMessageBridge.js +74 -0
- package/dist/components/sandbox/RuntimeMessageBridge.js.map +1 -0
- package/dist/components/sandbox/RuntimeMessageRouter.d.ts +65 -0
- package/dist/components/sandbox/RuntimeMessageRouter.d.ts.map +1 -0
- package/dist/components/sandbox/RuntimeMessageRouter.js +166 -0
- package/dist/components/sandbox/RuntimeMessageRouter.js.map +1 -0
- package/dist/components/sandbox/SandboxRuntimeProvider.d.ts +48 -0
- package/dist/components/sandbox/SandboxRuntimeProvider.d.ts.map +1 -0
- package/dist/components/sandbox/SandboxRuntimeProvider.js +2 -0
- package/dist/components/sandbox/SandboxRuntimeProvider.js.map +1 -0
- package/dist/dialogs/ApiKeyPromptDialog.d.ts +15 -0
- package/dist/dialogs/ApiKeyPromptDialog.d.ts.map +1 -0
- package/dist/dialogs/ApiKeyPromptDialog.js +77 -0
- package/dist/dialogs/ApiKeyPromptDialog.js.map +1 -0
- package/dist/dialogs/AttachmentOverlay.d.ts +32 -0
- package/dist/dialogs/AttachmentOverlay.d.ts.map +1 -0
- package/dist/dialogs/AttachmentOverlay.js +576 -0
- package/dist/dialogs/AttachmentOverlay.js.map +1 -0
- package/dist/dialogs/CustomProviderDialog.d.ts +25 -0
- package/dist/dialogs/CustomProviderDialog.d.ts.map +1 -0
- package/dist/dialogs/CustomProviderDialog.js +270 -0
- package/dist/dialogs/CustomProviderDialog.js.map +1 -0
- package/dist/dialogs/ModelSelector.d.ts +27 -0
- package/dist/dialogs/ModelSelector.d.ts.map +1 -0
- package/dist/dialogs/ModelSelector.js +320 -0
- package/dist/dialogs/ModelSelector.js.map +1 -0
- package/dist/dialogs/PersistentStorageDialog.d.ts +17 -0
- package/dist/dialogs/PersistentStorageDialog.d.ts.map +1 -0
- package/dist/dialogs/PersistentStorageDialog.js +144 -0
- package/dist/dialogs/PersistentStorageDialog.js.map +1 -0
- package/dist/dialogs/ProvidersModelsTab.d.ts +20 -0
- package/dist/dialogs/ProvidersModelsTab.d.ts.map +1 -0
- package/dist/dialogs/ProvidersModelsTab.js +188 -0
- package/dist/dialogs/ProvidersModelsTab.js.map +1 -0
- package/dist/dialogs/SessionListDialog.d.ts +19 -0
- package/dist/dialogs/SessionListDialog.d.ts.map +1 -0
- package/dist/dialogs/SessionListDialog.js +152 -0
- package/dist/dialogs/SessionListDialog.js.map +1 -0
- package/dist/dialogs/SettingsDialog.d.ts +30 -0
- package/dist/dialogs/SettingsDialog.d.ts.map +1 -0
- package/dist/dialogs/SettingsDialog.js +222 -0
- package/dist/dialogs/SettingsDialog.js.map +1 -0
- package/dist/index.d.ts +67 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +70 -0
- package/dist/index.js.map +1 -0
- package/dist/prompts/prompts.d.ts +11 -0
- package/dist/prompts/prompts.d.ts.map +1 -0
- package/dist/prompts/prompts.js +272 -0
- package/dist/prompts/prompts.js.map +1 -0
- package/dist/storage/app-storage.d.ts +33 -0
- package/dist/storage/app-storage.d.ts.map +1 -0
- package/dist/storage/app-storage.js +43 -0
- package/dist/storage/app-storage.js.map +1 -0
- package/dist/storage/backends/indexeddb-storage-backend.d.ts +27 -0
- package/dist/storage/backends/indexeddb-storage-backend.d.ts.map +1 -0
- package/dist/storage/backends/indexeddb-storage-backend.js +167 -0
- package/dist/storage/backends/indexeddb-storage-backend.js.map +1 -0
- package/dist/storage/store.d.ts +23 -0
- package/dist/storage/store.d.ts.map +1 -0
- package/dist/storage/store.js +24 -0
- package/dist/storage/store.js.map +1 -0
- package/dist/storage/stores/custom-providers-store.d.ts +25 -0
- package/dist/storage/stores/custom-providers-store.d.ts.map +1 -0
- package/dist/storage/stores/custom-providers-store.js +35 -0
- package/dist/storage/stores/custom-providers-store.js.map +1 -0
- package/dist/storage/stores/provider-keys-store.d.ts +14 -0
- package/dist/storage/stores/provider-keys-store.d.ts.map +1 -0
- package/dist/storage/stores/provider-keys-store.js +27 -0
- package/dist/storage/stores/provider-keys-store.js.map +1 -0
- package/dist/storage/stores/sessions-store.d.ts +32 -0
- package/dist/storage/stores/sessions-store.d.ts.map +1 -0
- package/dist/storage/stores/sessions-store.js +113 -0
- package/dist/storage/stores/sessions-store.js.map +1 -0
- package/dist/storage/stores/settings-store.d.ts +14 -0
- package/dist/storage/stores/settings-store.d.ts.map +1 -0
- package/dist/storage/stores/settings-store.js +28 -0
- package/dist/storage/stores/settings-store.js.map +1 -0
- package/dist/storage/types.d.ts +176 -0
- package/dist/storage/types.d.ts.map +1 -0
- package/dist/storage/types.js +2 -0
- package/dist/storage/types.js.map +1 -0
- package/dist/tools/artifacts/ArtifactElement.d.ts +9 -0
- package/dist/tools/artifacts/ArtifactElement.d.ts.map +1 -0
- package/dist/tools/artifacts/ArtifactElement.js +8 -0
- package/dist/tools/artifacts/ArtifactElement.js.map +1 -0
- package/dist/tools/artifacts/ArtifactPill.d.ts +4 -0
- package/dist/tools/artifacts/ArtifactPill.d.ts.map +1 -0
- package/dist/tools/artifacts/ArtifactPill.js +23 -0
- package/dist/tools/artifacts/ArtifactPill.js.map +1 -0
- package/dist/tools/artifacts/Console.d.ts +18 -0
- package/dist/tools/artifacts/Console.d.ts.map +1 -0
- package/dist/tools/artifacts/Console.js +92 -0
- package/dist/tools/artifacts/Console.js.map +1 -0
- package/dist/tools/artifacts/DocxArtifact.d.ts +22 -0
- package/dist/tools/artifacts/DocxArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/DocxArtifact.js +205 -0
- package/dist/tools/artifacts/DocxArtifact.js.map +1 -0
- package/dist/tools/artifacts/ExcelArtifact.d.ts +24 -0
- package/dist/tools/artifacts/ExcelArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/ExcelArtifact.js +213 -0
- package/dist/tools/artifacts/ExcelArtifact.js.map +1 -0
- package/dist/tools/artifacts/GenericArtifact.d.ts +19 -0
- package/dist/tools/artifacts/GenericArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/GenericArtifact.js +114 -0
- package/dist/tools/artifacts/GenericArtifact.js.map +1 -0
- package/dist/tools/artifacts/HtmlArtifact.d.ts +27 -0
- package/dist/tools/artifacts/HtmlArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/HtmlArtifact.js +187 -0
- package/dist/tools/artifacts/HtmlArtifact.js.map +1 -0
- package/dist/tools/artifacts/ImageArtifact.d.ts +20 -0
- package/dist/tools/artifacts/ImageArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/ImageArtifact.js +117 -0
- package/dist/tools/artifacts/ImageArtifact.js.map +1 -0
- package/dist/tools/artifacts/MarkdownArtifact.d.ts +19 -0
- package/dist/tools/artifacts/MarkdownArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/MarkdownArtifact.js +79 -0
- package/dist/tools/artifacts/MarkdownArtifact.js.map +1 -0
- package/dist/tools/artifacts/PdfArtifact.d.ts +25 -0
- package/dist/tools/artifacts/PdfArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/PdfArtifact.js +181 -0
- package/dist/tools/artifacts/PdfArtifact.js.map +1 -0
- package/dist/tools/artifacts/SvgArtifact.d.ts +18 -0
- package/dist/tools/artifacts/SvgArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/SvgArtifact.js +75 -0
- package/dist/tools/artifacts/SvgArtifact.js.map +1 -0
- package/dist/tools/artifacts/TextArtifact.d.ts +19 -0
- package/dist/tools/artifacts/TextArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/TextArtifact.js +141 -0
- package/dist/tools/artifacts/TextArtifact.js.map +1 -0
- package/dist/tools/artifacts/artifacts-tool-renderer.d.ts +11 -0
- package/dist/tools/artifacts/artifacts-tool-renderer.d.ts.map +1 -0
- package/dist/tools/artifacts/artifacts-tool-renderer.js +273 -0
- package/dist/tools/artifacts/artifacts-tool-renderer.js.map +1 -0
- package/dist/tools/artifacts/artifacts.d.ts +63 -0
- package/dist/tools/artifacts/artifacts.d.ts.map +1 -0
- package/dist/tools/artifacts/artifacts.js +664 -0
- package/dist/tools/artifacts/artifacts.js.map +1 -0
- package/dist/tools/artifacts/index.d.ts +8 -0
- package/dist/tools/artifacts/index.d.ts.map +1 -0
- package/dist/tools/artifacts/index.js +8 -0
- package/dist/tools/artifacts/index.js.map +1 -0
- package/dist/tools/extract-document.d.ts +24 -0
- package/dist/tools/extract-document.d.ts.map +1 -0
- package/dist/tools/extract-document.js +216 -0
- package/dist/tools/extract-document.js.map +1 -0
- package/dist/tools/index.d.ts +16 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +33 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/javascript-repl.d.ts +44 -0
- package/dist/tools/javascript-repl.d.ts.map +1 -0
- package/dist/tools/javascript-repl.js +224 -0
- package/dist/tools/javascript-repl.js.map +1 -0
- package/dist/tools/renderer-registry.d.ts +23 -0
- package/dist/tools/renderer-registry.d.ts.map +1 -0
- package/dist/tools/renderer-registry.js +107 -0
- package/dist/tools/renderer-registry.js.map +1 -0
- package/dist/tools/renderers/BashRenderer.d.ts +10 -0
- package/dist/tools/renderers/BashRenderer.d.ts.map +1 -0
- package/dist/tools/renderers/BashRenderer.js +42 -0
- package/dist/tools/renderers/BashRenderer.js.map +1 -0
- package/dist/tools/renderers/CalculateRenderer.d.ts +10 -0
- package/dist/tools/renderers/CalculateRenderer.d.ts.map +1 -0
- package/dist/tools/renderers/CalculateRenderer.js +45 -0
- package/dist/tools/renderers/CalculateRenderer.js.map +1 -0
- package/dist/tools/renderers/DefaultRenderer.d.ts +6 -0
- package/dist/tools/renderers/DefaultRenderer.d.ts.map +1 -0
- package/dist/tools/renderers/DefaultRenderer.js +94 -0
- package/dist/tools/renderers/DefaultRenderer.js.map +1 -0
- package/dist/tools/renderers/GetCurrentTimeRenderer.d.ts +10 -0
- package/dist/tools/renderers/GetCurrentTimeRenderer.d.ts.map +1 -0
- package/dist/tools/renderers/GetCurrentTimeRenderer.js +72 -0
- package/dist/tools/renderers/GetCurrentTimeRenderer.js.map +1 -0
- package/dist/tools/types.d.ts +10 -0
- package/dist/tools/types.d.ts.map +1 -0
- package/dist/tools/types.js +2 -0
- package/dist/tools/types.js.map +1 -0
- package/dist/utils/attachment-utils.d.ts +19 -0
- package/dist/utils/attachment-utils.d.ts.map +1 -0
- package/dist/utils/attachment-utils.js +415 -0
- package/dist/utils/attachment-utils.js.map +1 -0
- package/dist/utils/auth-token.d.ts +3 -0
- package/dist/utils/auth-token.d.ts.map +1 -0
- package/dist/utils/auth-token.js +19 -0
- package/dist/utils/auth-token.js.map +1 -0
- package/dist/utils/format.d.ts +6 -0
- package/dist/utils/format.d.ts.map +1 -0
- package/dist/utils/format.js +47 -0
- package/dist/utils/format.js.map +1 -0
- package/dist/utils/i18n.d.ts +636 -0
- package/dist/utils/i18n.d.ts.map +1 -0
- package/dist/utils/i18n.js +418 -0
- package/dist/utils/i18n.js.map +1 -0
- package/dist/utils/model-discovery.d.ts +38 -0
- package/dist/utils/model-discovery.d.ts.map +1 -0
- package/dist/utils/model-discovery.js +243 -0
- package/dist/utils/model-discovery.js.map +1 -0
- package/dist/utils/proxy-utils.d.ts +45 -0
- package/dist/utils/proxy-utils.d.ts.map +1 -0
- package/dist/utils/proxy-utils.js +116 -0
- package/dist/utils/proxy-utils.js.map +1 -0
- package/dist/utils/test-sessions.d.ts +359 -0
- package/dist/utils/test-sessions.d.ts.map +1 -0
- package/dist/utils/test-sessions.js +2325 -0
- package/dist/utils/test-sessions.js.map +1 -0
- package/example/README.md +61 -0
- package/example/index.html +13 -0
- package/example/package.json +25 -0
- package/example/src/app.css +1 -0
- package/example/src/custom-messages.ts +99 -0
- package/example/src/env.d.ts +1 -0
- package/example/src/main.ts +421 -0
- package/example/tsconfig.json +23 -0
- package/example/vite.config.ts +6 -0
- package/package.json +53 -0
- package/scripts/count-prompt-tokens.ts +88 -0
- package/src/ChatPanel.ts +207 -0
- package/src/app.css +68 -0
- package/src/components/AgentInterface.ts +388 -0
- package/src/components/AttachmentTile.ts +107 -0
- package/src/components/ConsoleBlock.ts +72 -0
- package/src/components/CustomProviderCard.ts +100 -0
- package/src/components/ExpandableSection.ts +46 -0
- package/src/components/Input.ts +113 -0
- package/src/components/MessageEditor.ts +400 -0
- package/src/components/MessageList.ts +95 -0
- package/src/components/Messages.ts +383 -0
- package/src/components/ProviderKeyInput.ts +153 -0
- package/src/components/SandboxedIframe.ts +626 -0
- package/src/components/StreamingMessageContainer.ts +103 -0
- package/src/components/ThinkingBlock.ts +43 -0
- package/src/components/message-renderer-registry.ts +28 -0
- package/src/components/sandbox/ArtifactsRuntimeProvider.ts +219 -0
- package/src/components/sandbox/AttachmentsRuntimeProvider.ts +66 -0
- package/src/components/sandbox/ConsoleRuntimeProvider.ts +186 -0
- package/src/components/sandbox/FileDownloadRuntimeProvider.ts +110 -0
- package/src/components/sandbox/RuntimeMessageBridge.ts +82 -0
- package/src/components/sandbox/RuntimeMessageRouter.ts +216 -0
- package/src/components/sandbox/SandboxRuntimeProvider.ts +52 -0
- package/src/dialogs/ApiKeyPromptDialog.ts +75 -0
- package/src/dialogs/AttachmentOverlay.ts +636 -0
- package/src/dialogs/CustomProviderDialog.ts +274 -0
- package/src/dialogs/ModelSelector.ts +313 -0
- package/src/dialogs/PersistentStorageDialog.ts +144 -0
- package/src/dialogs/ProvidersModelsTab.ts +212 -0
- package/src/dialogs/SessionListDialog.ts +150 -0
- package/src/dialogs/SettingsDialog.ts +214 -0
- package/src/index.ts +119 -0
- package/src/prompts/prompts.ts +282 -0
- package/src/storage/app-storage.ts +60 -0
- package/src/storage/backends/indexeddb-storage-backend.ts +193 -0
- package/src/storage/store.ts +33 -0
- package/src/storage/stores/custom-providers-store.ts +62 -0
- package/src/storage/stores/provider-keys-store.ts +33 -0
- package/src/storage/stores/sessions-store.ts +136 -0
- package/src/storage/stores/settings-store.ts +34 -0
- package/src/storage/types.ts +206 -0
- package/src/tools/artifacts/ArtifactElement.ts +14 -0
- package/src/tools/artifacts/ArtifactPill.ts +26 -0
- package/src/tools/artifacts/Console.ts +93 -0
- package/src/tools/artifacts/DocxArtifact.ts +213 -0
- package/src/tools/artifacts/ExcelArtifact.ts +231 -0
- package/src/tools/artifacts/GenericArtifact.ts +117 -0
- package/src/tools/artifacts/HtmlArtifact.ts +195 -0
- package/src/tools/artifacts/ImageArtifact.ts +116 -0
- package/src/tools/artifacts/MarkdownArtifact.ts +82 -0
- package/src/tools/artifacts/PdfArtifact.ts +201 -0
- package/src/tools/artifacts/SvgArtifact.ts +78 -0
- package/src/tools/artifacts/TextArtifact.ts +148 -0
- package/src/tools/artifacts/artifacts-tool-renderer.ts +310 -0
- package/src/tools/artifacts/artifacts.ts +713 -0
- package/src/tools/artifacts/index.ts +7 -0
- package/src/tools/extract-document.ts +275 -0
- package/src/tools/index.ts +46 -0
- package/src/tools/javascript-repl.ts +293 -0
- package/src/tools/renderer-registry.ts +130 -0
- package/src/tools/renderers/BashRenderer.ts +52 -0
- package/src/tools/renderers/CalculateRenderer.ts +58 -0
- package/src/tools/renderers/DefaultRenderer.ts +103 -0
- package/src/tools/renderers/GetCurrentTimeRenderer.ts +92 -0
- package/src/tools/types.ts +15 -0
- package/src/utils/attachment-utils.ts +472 -0
- package/src/utils/auth-token.ts +22 -0
- package/src/utils/format.ts +42 -0
- package/src/utils/i18n.ts +653 -0
- package/src/utils/model-discovery.ts +277 -0
- package/src/utils/proxy-utils.ts +134 -0
- package/src/utils/test-sessions.ts +2357 -0
- package/tsconfig.build.json +20 -0
- 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
|
+
}
|