@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,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"}
|