@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,130 @@
|
|
|
1
|
+
import { icon } from "@mariozechner/mini-lit";
|
|
2
|
+
import { html, type TemplateResult } from "lit";
|
|
3
|
+
import type { Ref } from "lit/directives/ref.js";
|
|
4
|
+
import { ref } from "lit/directives/ref.js";
|
|
5
|
+
import { ChevronsUpDown, ChevronUp, Loader } from "lucide";
|
|
6
|
+
import type { ToolRenderer } from "./types.js";
|
|
7
|
+
|
|
8
|
+
// Registry of tool renderers
|
|
9
|
+
export const toolRenderers = new Map<string, ToolRenderer>();
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Register a custom tool renderer
|
|
13
|
+
*/
|
|
14
|
+
export function registerToolRenderer(toolName: string, renderer: ToolRenderer): void {
|
|
15
|
+
toolRenderers.set(toolName, renderer);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Get a tool renderer by name
|
|
20
|
+
*/
|
|
21
|
+
export function getToolRenderer(toolName: string): ToolRenderer | undefined {
|
|
22
|
+
return toolRenderers.get(toolName);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Helper to render a header for tool renderers
|
|
27
|
+
* Shows icon on left when complete/error, spinner on right when in progress
|
|
28
|
+
*/
|
|
29
|
+
export function renderHeader(
|
|
30
|
+
state: "inprogress" | "complete" | "error",
|
|
31
|
+
toolIcon: any,
|
|
32
|
+
text: string | TemplateResult,
|
|
33
|
+
): TemplateResult {
|
|
34
|
+
const statusIcon = (iconComponent: any, color: string) =>
|
|
35
|
+
html`<span class="inline-block ${color}">${icon(iconComponent, "sm")}</span>`;
|
|
36
|
+
|
|
37
|
+
switch (state) {
|
|
38
|
+
case "inprogress":
|
|
39
|
+
return html`
|
|
40
|
+
<div class="flex items-center justify-between gap-2 text-sm text-muted-foreground">
|
|
41
|
+
<div class="flex items-center gap-2">
|
|
42
|
+
${statusIcon(toolIcon, "text-foreground")}
|
|
43
|
+
${text}
|
|
44
|
+
</div>
|
|
45
|
+
${statusIcon(Loader, "text-foreground animate-spin")}
|
|
46
|
+
</div>
|
|
47
|
+
`;
|
|
48
|
+
case "complete":
|
|
49
|
+
return html`
|
|
50
|
+
<div class="flex items-center gap-2 text-sm text-muted-foreground">
|
|
51
|
+
${statusIcon(toolIcon, "text-green-600 dark:text-green-500")}
|
|
52
|
+
${text}
|
|
53
|
+
</div>
|
|
54
|
+
`;
|
|
55
|
+
case "error":
|
|
56
|
+
return html`
|
|
57
|
+
<div class="flex items-center gap-2 text-sm text-muted-foreground">
|
|
58
|
+
${statusIcon(toolIcon, "text-destructive")}
|
|
59
|
+
${text}
|
|
60
|
+
</div>
|
|
61
|
+
`;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* Helper to render a collapsible header for tool renderers
|
|
67
|
+
* Same as renderHeader but with a chevron button that toggles visibility of content
|
|
68
|
+
*/
|
|
69
|
+
export function renderCollapsibleHeader(
|
|
70
|
+
state: "inprogress" | "complete" | "error",
|
|
71
|
+
toolIcon: any,
|
|
72
|
+
text: string | TemplateResult,
|
|
73
|
+
contentRef: Ref<HTMLElement>,
|
|
74
|
+
chevronRef: Ref<HTMLElement>,
|
|
75
|
+
defaultExpanded = false,
|
|
76
|
+
): TemplateResult {
|
|
77
|
+
const statusIcon = (iconComponent: any, color: string) =>
|
|
78
|
+
html`<span class="inline-block ${color}">${icon(iconComponent, "sm")}</span>`;
|
|
79
|
+
|
|
80
|
+
const toggleContent = (e: Event) => {
|
|
81
|
+
e.preventDefault();
|
|
82
|
+
const content = contentRef.value;
|
|
83
|
+
const chevron = chevronRef.value;
|
|
84
|
+
if (content && chevron) {
|
|
85
|
+
const isCollapsed = content.classList.contains("max-h-0");
|
|
86
|
+
if (isCollapsed) {
|
|
87
|
+
content.classList.remove("max-h-0");
|
|
88
|
+
content.classList.add("max-h-[2000px]", "mt-3");
|
|
89
|
+
// Show ChevronUp, hide ChevronsUpDown
|
|
90
|
+
const upIcon = chevron.querySelector(".chevron-up");
|
|
91
|
+
const downIcon = chevron.querySelector(".chevrons-up-down");
|
|
92
|
+
if (upIcon && downIcon) {
|
|
93
|
+
upIcon.classList.remove("hidden");
|
|
94
|
+
downIcon.classList.add("hidden");
|
|
95
|
+
}
|
|
96
|
+
} else {
|
|
97
|
+
content.classList.remove("max-h-[2000px]", "mt-3");
|
|
98
|
+
content.classList.add("max-h-0");
|
|
99
|
+
// Show ChevronsUpDown, hide ChevronUp
|
|
100
|
+
const upIcon = chevron.querySelector(".chevron-up");
|
|
101
|
+
const downIcon = chevron.querySelector(".chevrons-up-down");
|
|
102
|
+
if (upIcon && downIcon) {
|
|
103
|
+
upIcon.classList.add("hidden");
|
|
104
|
+
downIcon.classList.remove("hidden");
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
|
|
110
|
+
const toolIconColor =
|
|
111
|
+
state === "complete"
|
|
112
|
+
? "text-green-600 dark:text-green-500"
|
|
113
|
+
: state === "error"
|
|
114
|
+
? "text-destructive"
|
|
115
|
+
: "text-foreground";
|
|
116
|
+
|
|
117
|
+
return html`
|
|
118
|
+
<button @click=${toggleContent} class="flex items-center justify-between gap-2 text-sm text-muted-foreground w-full text-left hover:text-foreground transition-colors cursor-pointer">
|
|
119
|
+
<div class="flex items-center gap-2">
|
|
120
|
+
${state === "inprogress" ? statusIcon(Loader, "text-foreground animate-spin") : ""}
|
|
121
|
+
${statusIcon(toolIcon, toolIconColor)}
|
|
122
|
+
${text}
|
|
123
|
+
</div>
|
|
124
|
+
<span class="inline-block text-muted-foreground" ${ref(chevronRef)}>
|
|
125
|
+
<span class="chevron-up ${defaultExpanded ? "" : "hidden"}">${icon(ChevronUp, "sm")}</span>
|
|
126
|
+
<span class="chevrons-up-down ${defaultExpanded ? "hidden" : ""}">${icon(ChevronsUpDown, "sm")}</span>
|
|
127
|
+
</span>
|
|
128
|
+
</button>
|
|
129
|
+
`;
|
|
130
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import type { ToolResultMessage } from "@draht/ai";
|
|
2
|
+
import { html } from "lit";
|
|
3
|
+
import { SquareTerminal } from "lucide";
|
|
4
|
+
import { i18n } from "../../utils/i18n.js";
|
|
5
|
+
import { renderHeader } from "../renderer-registry.js";
|
|
6
|
+
import type { ToolRenderer, ToolRenderResult } from "../types.js";
|
|
7
|
+
|
|
8
|
+
interface BashParams {
|
|
9
|
+
command: string;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
// Bash tool has undefined details (only uses output)
|
|
13
|
+
export class BashRenderer implements ToolRenderer<BashParams, undefined> {
|
|
14
|
+
render(params: BashParams | undefined, result: ToolResultMessage<undefined> | undefined): ToolRenderResult {
|
|
15
|
+
const state = result ? (result.isError ? "error" : "complete") : "inprogress";
|
|
16
|
+
|
|
17
|
+
// With result: show command + output
|
|
18
|
+
if (result && params?.command) {
|
|
19
|
+
const output =
|
|
20
|
+
result.content
|
|
21
|
+
?.filter((c) => c.type === "text")
|
|
22
|
+
.map((c: any) => c.text)
|
|
23
|
+
.join("\n") || "";
|
|
24
|
+
const combined = output ? `> ${params.command}\n\n${output}` : `> ${params.command}`;
|
|
25
|
+
return {
|
|
26
|
+
content: html`
|
|
27
|
+
<div class="space-y-3">
|
|
28
|
+
${renderHeader(state, SquareTerminal, i18n("Running command..."))}
|
|
29
|
+
<console-block .content=${combined} .variant=${result.isError ? "error" : "default"}></console-block>
|
|
30
|
+
</div>
|
|
31
|
+
`,
|
|
32
|
+
isCustom: false,
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// Just params (streaming or waiting)
|
|
37
|
+
if (params?.command) {
|
|
38
|
+
return {
|
|
39
|
+
content: html`
|
|
40
|
+
<div class="space-y-3">
|
|
41
|
+
${renderHeader(state, SquareTerminal, i18n("Running command..."))}
|
|
42
|
+
<console-block .content=${`> ${params.command}`}></console-block>
|
|
43
|
+
</div>
|
|
44
|
+
`,
|
|
45
|
+
isCustom: false,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// No params yet
|
|
50
|
+
return { content: renderHeader(state, SquareTerminal, i18n("Waiting for command...")), isCustom: false };
|
|
51
|
+
}
|
|
52
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import type { ToolResultMessage } from "@draht/ai";
|
|
2
|
+
import { html } from "lit";
|
|
3
|
+
import { Calculator } from "lucide";
|
|
4
|
+
import { i18n } from "../../utils/i18n.js";
|
|
5
|
+
import { renderHeader } from "../renderer-registry.js";
|
|
6
|
+
import type { ToolRenderer, ToolRenderResult } from "../types.js";
|
|
7
|
+
|
|
8
|
+
interface CalculateParams {
|
|
9
|
+
expression: string;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
// Calculate tool has undefined details (only uses output)
|
|
13
|
+
export class CalculateRenderer implements ToolRenderer<CalculateParams, undefined> {
|
|
14
|
+
render(params: CalculateParams | undefined, result: ToolResultMessage<undefined> | undefined): ToolRenderResult {
|
|
15
|
+
const state = result ? (result.isError ? "error" : "complete") : "inprogress";
|
|
16
|
+
|
|
17
|
+
// Full params + full result
|
|
18
|
+
if (result && params?.expression) {
|
|
19
|
+
const output =
|
|
20
|
+
result.content
|
|
21
|
+
?.filter((c) => c.type === "text")
|
|
22
|
+
.map((c: any) => c.text)
|
|
23
|
+
.join("\n") || "";
|
|
24
|
+
|
|
25
|
+
// Error: show expression in header, error below
|
|
26
|
+
if (result.isError) {
|
|
27
|
+
return {
|
|
28
|
+
content: html`
|
|
29
|
+
<div class="space-y-3">
|
|
30
|
+
${renderHeader(state, Calculator, params.expression)}
|
|
31
|
+
<div class="text-sm text-destructive">${output}</div>
|
|
32
|
+
</div>
|
|
33
|
+
`,
|
|
34
|
+
isCustom: false,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
// Success: show expression = result in header
|
|
39
|
+
return { content: renderHeader(state, Calculator, `${params.expression} = ${output}`), isCustom: false };
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// Full params, no result: just show header with expression in it
|
|
43
|
+
if (params?.expression) {
|
|
44
|
+
return {
|
|
45
|
+
content: renderHeader(state, Calculator, `${i18n("Calculating")} ${params.expression}`),
|
|
46
|
+
isCustom: false,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
// Partial params (empty expression), no result
|
|
51
|
+
if (params && !params.expression) {
|
|
52
|
+
return { content: renderHeader(state, Calculator, i18n("Writing expression...")), isCustom: false };
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
// No params, no result
|
|
56
|
+
return { content: renderHeader(state, Calculator, i18n("Waiting for expression...")), isCustom: false };
|
|
57
|
+
}
|
|
58
|
+
}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import type { ToolResultMessage } from "@draht/ai";
|
|
2
|
+
import { html } from "lit";
|
|
3
|
+
import { Code } from "lucide";
|
|
4
|
+
import { i18n } from "../../utils/i18n.js";
|
|
5
|
+
import { renderHeader } from "../renderer-registry.js";
|
|
6
|
+
import type { ToolRenderer, ToolRenderResult } from "../types.js";
|
|
7
|
+
|
|
8
|
+
export class DefaultRenderer implements ToolRenderer {
|
|
9
|
+
render(params: any | undefined, result: ToolResultMessage | undefined, isStreaming?: boolean): ToolRenderResult {
|
|
10
|
+
const state = result ? (result.isError ? "error" : "complete") : isStreaming ? "inprogress" : "complete";
|
|
11
|
+
|
|
12
|
+
// Format params as JSON
|
|
13
|
+
let paramsJson = "";
|
|
14
|
+
if (params) {
|
|
15
|
+
try {
|
|
16
|
+
paramsJson = JSON.stringify(JSON.parse(params), null, 2);
|
|
17
|
+
} catch {
|
|
18
|
+
try {
|
|
19
|
+
paramsJson = JSON.stringify(params, null, 2);
|
|
20
|
+
} catch {
|
|
21
|
+
paramsJson = String(params);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// With result: show header + params + result
|
|
27
|
+
if (result) {
|
|
28
|
+
let outputJson =
|
|
29
|
+
result.content
|
|
30
|
+
?.filter((c) => c.type === "text")
|
|
31
|
+
.map((c: any) => c.text)
|
|
32
|
+
.join("\n") || i18n("(no output)");
|
|
33
|
+
let outputLanguage = "text";
|
|
34
|
+
|
|
35
|
+
// Try to parse and pretty-print if it's valid JSON
|
|
36
|
+
try {
|
|
37
|
+
const parsed = JSON.parse(outputJson);
|
|
38
|
+
outputJson = JSON.stringify(parsed, null, 2);
|
|
39
|
+
outputLanguage = "json";
|
|
40
|
+
} catch {
|
|
41
|
+
// Not valid JSON, leave as-is and use text highlighting
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
return {
|
|
45
|
+
content: html`
|
|
46
|
+
<div class="space-y-3">
|
|
47
|
+
${renderHeader(state, Code, "Tool Call")}
|
|
48
|
+
${
|
|
49
|
+
paramsJson
|
|
50
|
+
? html`<div>
|
|
51
|
+
<div class="text-xs font-medium mb-1 text-muted-foreground">${i18n("Input")}</div>
|
|
52
|
+
<code-block .code=${paramsJson} language="json"></code-block>
|
|
53
|
+
</div>`
|
|
54
|
+
: ""
|
|
55
|
+
}
|
|
56
|
+
<div>
|
|
57
|
+
<div class="text-xs font-medium mb-1 text-muted-foreground">${i18n("Output")}</div>
|
|
58
|
+
<code-block .code=${outputJson} language="${outputLanguage}"></code-block>
|
|
59
|
+
</div>
|
|
60
|
+
</div>
|
|
61
|
+
`,
|
|
62
|
+
isCustom: false,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// Just params (streaming or waiting for result)
|
|
67
|
+
if (params) {
|
|
68
|
+
if (isStreaming && (!paramsJson || paramsJson === "{}" || paramsJson === "null")) {
|
|
69
|
+
return {
|
|
70
|
+
content: html`
|
|
71
|
+
<div>
|
|
72
|
+
${renderHeader(state, Code, "Preparing tool parameters...")}
|
|
73
|
+
</div>
|
|
74
|
+
`,
|
|
75
|
+
isCustom: false,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return {
|
|
80
|
+
content: html`
|
|
81
|
+
<div class="space-y-3">
|
|
82
|
+
${renderHeader(state, Code, "Tool Call")}
|
|
83
|
+
<div>
|
|
84
|
+
<div class="text-xs font-medium mb-1 text-muted-foreground">${i18n("Input")}</div>
|
|
85
|
+
<code-block .code=${paramsJson} language="json"></code-block>
|
|
86
|
+
</div>
|
|
87
|
+
</div>
|
|
88
|
+
`,
|
|
89
|
+
isCustom: false,
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
// No params or result yet
|
|
94
|
+
return {
|
|
95
|
+
content: html`
|
|
96
|
+
<div>
|
|
97
|
+
${renderHeader(state, Code, "Preparing tool...")}
|
|
98
|
+
</div>
|
|
99
|
+
`,
|
|
100
|
+
isCustom: false,
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import type { ToolResultMessage } from "@draht/ai";
|
|
2
|
+
import { html } from "lit";
|
|
3
|
+
import { Clock } from "lucide";
|
|
4
|
+
import { i18n } from "../../utils/i18n.js";
|
|
5
|
+
import { renderHeader } from "../renderer-registry.js";
|
|
6
|
+
import type { ToolRenderer, ToolRenderResult } from "../types.js";
|
|
7
|
+
|
|
8
|
+
interface GetCurrentTimeParams {
|
|
9
|
+
timezone?: string;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
// GetCurrentTime tool has undefined details (only uses output)
|
|
13
|
+
export class GetCurrentTimeRenderer implements ToolRenderer<GetCurrentTimeParams, undefined> {
|
|
14
|
+
render(
|
|
15
|
+
params: GetCurrentTimeParams | undefined,
|
|
16
|
+
result: ToolResultMessage<undefined> | undefined,
|
|
17
|
+
): ToolRenderResult {
|
|
18
|
+
const state = result ? (result.isError ? "error" : "complete") : "inprogress";
|
|
19
|
+
|
|
20
|
+
// Full params + full result
|
|
21
|
+
if (result && params) {
|
|
22
|
+
const output =
|
|
23
|
+
result.content
|
|
24
|
+
?.filter((c) => c.type === "text")
|
|
25
|
+
.map((c: any) => c.text)
|
|
26
|
+
.join("\n") || "";
|
|
27
|
+
const headerText = params.timezone
|
|
28
|
+
? `${i18n("Getting current time in")} ${params.timezone}`
|
|
29
|
+
: i18n("Getting current date and time");
|
|
30
|
+
|
|
31
|
+
// Error: show header, error below
|
|
32
|
+
if (result.isError) {
|
|
33
|
+
return {
|
|
34
|
+
content: html`
|
|
35
|
+
<div class="space-y-3">
|
|
36
|
+
${renderHeader(state, Clock, headerText)}
|
|
37
|
+
<div class="text-sm text-destructive">${output}</div>
|
|
38
|
+
</div>
|
|
39
|
+
`,
|
|
40
|
+
isCustom: false,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
// Success: show time in header
|
|
45
|
+
return { content: renderHeader(state, Clock, `${headerText}: ${output}`), isCustom: false };
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Full result, no params
|
|
49
|
+
if (result) {
|
|
50
|
+
const output =
|
|
51
|
+
result.content
|
|
52
|
+
?.filter((c) => c.type === "text")
|
|
53
|
+
.map((c: any) => c.text)
|
|
54
|
+
.join("\n") || "";
|
|
55
|
+
|
|
56
|
+
// Error: show header, error below
|
|
57
|
+
if (result.isError) {
|
|
58
|
+
return {
|
|
59
|
+
content: html`
|
|
60
|
+
<div class="space-y-3">
|
|
61
|
+
${renderHeader(state, Clock, i18n("Getting current date and time"))}
|
|
62
|
+
<div class="text-sm text-destructive">${output}</div>
|
|
63
|
+
</div>
|
|
64
|
+
`,
|
|
65
|
+
isCustom: false,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
// Success: show time in header
|
|
70
|
+
return {
|
|
71
|
+
content: renderHeader(state, Clock, `${i18n("Getting current date and time")}: ${output}`),
|
|
72
|
+
isCustom: false,
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
// Full params, no result: show timezone info in header
|
|
77
|
+
if (params?.timezone) {
|
|
78
|
+
return {
|
|
79
|
+
content: renderHeader(state, Clock, `${i18n("Getting current time in")} ${params.timezone}`),
|
|
80
|
+
isCustom: false,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
// Partial params (no timezone) or empty params, no result
|
|
85
|
+
if (params) {
|
|
86
|
+
return { content: renderHeader(state, Clock, i18n("Getting current date and time")), isCustom: false };
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
// No params, no result
|
|
90
|
+
return { content: renderHeader(state, Clock, i18n("Getting time...")), isCustom: false };
|
|
91
|
+
}
|
|
92
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { ToolResultMessage } from "@draht/ai";
|
|
2
|
+
import type { TemplateResult } from "lit";
|
|
3
|
+
|
|
4
|
+
export interface ToolRenderResult {
|
|
5
|
+
content: TemplateResult;
|
|
6
|
+
isCustom: boolean; // true = no card wrapper, false = wrap in card
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export interface ToolRenderer<TParams = any, TDetails = any> {
|
|
10
|
+
render(
|
|
11
|
+
params: TParams | undefined,
|
|
12
|
+
result: ToolResultMessage<TDetails> | undefined,
|
|
13
|
+
isStreaming?: boolean,
|
|
14
|
+
): ToolRenderResult;
|
|
15
|
+
}
|