@mariozechner/pi-web-ui 0.5.44 → 0.5.46
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/README.md +178 -99
- package/dist/ChatPanel.d.ts +15 -10
- package/dist/ChatPanel.d.ts.map +1 -1
- package/dist/ChatPanel.js +68 -100
- package/dist/ChatPanel.js.map +1 -1
- package/dist/{state/agent-session.d.ts → agent/agent.d.ts} +23 -19
- package/dist/agent/agent.d.ts.map +1 -0
- package/dist/{state/agent-session.js → agent/agent.js} +50 -32
- package/dist/agent/agent.js.map +1 -0
- package/dist/{state → agent}/transports/AppTransport.d.ts +1 -3
- package/dist/agent/transports/AppTransport.d.ts.map +1 -0
- package/dist/{state → agent}/transports/AppTransport.js +5 -4
- package/dist/{state → agent}/transports/AppTransport.js.map +1 -1
- package/dist/{state → agent}/transports/ProviderTransport.d.ts +1 -3
- package/dist/agent/transports/ProviderTransport.d.ts.map +1 -0
- package/dist/{state → agent}/transports/ProviderTransport.js +6 -7
- package/dist/agent/transports/ProviderTransport.js.map +1 -0
- package/dist/{state → agent}/transports/index.d.ts.map +1 -1
- package/dist/agent/transports/index.js.map +1 -0
- package/dist/{state → agent}/transports/proxy-types.d.ts.map +1 -1
- package/dist/agent/transports/proxy-types.js.map +1 -0
- package/dist/agent/transports/types.d.ts +12 -0
- package/dist/agent/transports/types.d.ts.map +1 -0
- package/dist/{state → agent}/transports/types.js.map +1 -1
- package/dist/{state → agent}/types.d.ts.map +1 -1
- package/dist/{state → agent}/types.js.map +1 -1
- package/dist/app.css +1 -1
- package/dist/components/AgentInterface.d.ts +7 -4
- package/dist/components/AgentInterface.d.ts.map +1 -1
- package/dist/components/AgentInterface.js +29 -17
- package/dist/components/AgentInterface.js.map +1 -1
- package/dist/components/ConsoleBlock.d.ts +1 -0
- package/dist/components/ConsoleBlock.d.ts.map +1 -1
- package/dist/components/ConsoleBlock.js +7 -1
- package/dist/components/ConsoleBlock.js.map +1 -1
- package/dist/components/ExpandableSection.d.ts +15 -0
- package/dist/components/ExpandableSection.d.ts.map +1 -0
- package/dist/components/ExpandableSection.js +63 -0
- package/dist/components/ExpandableSection.js.map +1 -0
- package/dist/components/MessageEditor.d.ts +8 -1
- package/dist/components/MessageEditor.d.ts.map +1 -1
- package/dist/components/MessageEditor.js +149 -6
- package/dist/components/MessageEditor.js.map +1 -1
- package/dist/components/MessageList.d.ts +3 -2
- package/dist/components/MessageList.d.ts.map +1 -1
- package/dist/components/MessageList.js +14 -1
- package/dist/components/MessageList.js.map +1 -1
- package/dist/components/Messages.d.ts +15 -6
- package/dist/components/Messages.d.ts.map +1 -1
- package/dist/components/Messages.js +17 -83
- package/dist/components/Messages.js.map +1 -1
- package/dist/components/ProviderKeyInput.d.ts.map +1 -1
- package/dist/components/ProviderKeyInput.js +6 -5
- package/dist/components/ProviderKeyInput.js.map +1 -1
- package/dist/components/SandboxedIframe.d.ts +29 -7
- package/dist/components/SandboxedIframe.d.ts.map +1 -1
- package/dist/components/SandboxedIframe.js +350 -282
- package/dist/components/SandboxedIframe.js.map +1 -1
- 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 +189 -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 +64 -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 +161 -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 +97 -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 +168 -0
- package/dist/components/sandbox/RuntimeMessageRouter.js.map +1 -0
- package/dist/components/sandbox/SandboxRuntimeProvider.d.ts +33 -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.map +1 -1
- package/dist/dialogs/ApiKeyPromptDialog.js +2 -5
- package/dist/dialogs/ApiKeyPromptDialog.js.map +1 -1
- package/dist/dialogs/ModelSelector.js.map +1 -1
- 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/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.map +1 -1
- package/dist/dialogs/SettingsDialog.js +1 -0
- package/dist/dialogs/SettingsDialog.js.map +1 -1
- package/dist/index.d.ts +34 -16
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +32 -14
- package/dist/index.js.map +1 -1
- 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 +17 -12
- package/dist/storage/app-storage.d.ts.map +1 -1
- package/dist/storage/app-storage.js +13 -20
- package/dist/storage/app-storage.js.map +1 -1
- 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 +166 -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 +26 -0
- package/dist/storage/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 +31 -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 +156 -22
- package/dist/storage/types.d.ts.map +1 -1
- package/dist/tools/artifacts/ArtifactElement.d.ts +0 -1
- package/dist/tools/artifacts/ArtifactElement.d.ts.map +1 -1
- package/dist/tools/artifacts/ArtifactElement.js +0 -1
- package/dist/tools/artifacts/ArtifactElement.js.map +1 -1
- 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 +22 -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 +95 -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 +208 -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 +216 -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 +117 -0
- package/dist/tools/artifacts/GenericArtifact.js.map +1 -0
- package/dist/tools/artifacts/HtmlArtifact.d.ts +8 -11
- package/dist/tools/artifacts/HtmlArtifact.d.ts.map +1 -1
- package/dist/tools/artifacts/HtmlArtifact.js +56 -88
- package/dist/tools/artifacts/HtmlArtifact.js.map +1 -1
- 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 +120 -0
- package/dist/tools/artifacts/ImageArtifact.js.map +1 -0
- package/dist/tools/artifacts/MarkdownArtifact.d.ts +0 -1
- package/dist/tools/artifacts/MarkdownArtifact.d.ts.map +1 -1
- package/dist/tools/artifacts/MarkdownArtifact.js +0 -4
- package/dist/tools/artifacts/MarkdownArtifact.js.map +1 -1
- 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 +184 -0
- package/dist/tools/artifacts/PdfArtifact.js.map +1 -0
- package/dist/tools/artifacts/SvgArtifact.d.ts +0 -1
- package/dist/tools/artifacts/SvgArtifact.d.ts.map +1 -1
- package/dist/tools/artifacts/SvgArtifact.js +0 -4
- package/dist/tools/artifacts/SvgArtifact.js.map +1 -1
- package/dist/tools/artifacts/TextArtifact.d.ts +0 -1
- package/dist/tools/artifacts/TextArtifact.d.ts.map +1 -1
- package/dist/tools/artifacts/TextArtifact.js +0 -4
- package/dist/tools/artifacts/TextArtifact.js.map +1 -1
- 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 +262 -0
- package/dist/tools/artifacts/artifacts-tool-renderer.js.map +1 -0
- package/dist/tools/artifacts/artifacts.d.ts +10 -13
- package/dist/tools/artifacts/artifacts.d.ts.map +1 -1
- package/dist/tools/artifacts/artifacts.js +166 -344
- package/dist/tools/artifacts/artifacts.js.map +1 -1
- package/dist/tools/artifacts/index.d.ts +1 -0
- package/dist/tools/artifacts/index.d.ts.map +1 -1
- package/dist/tools/artifacts/index.js +1 -0
- package/dist/tools/artifacts/index.js.map +1 -1
- 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 +193 -0
- package/dist/tools/extract-document.js.map +1 -0
- package/dist/tools/index.d.ts +9 -7
- package/dist/tools/index.d.ts.map +1 -1
- package/dist/tools/index.js +17 -13
- package/dist/tools/index.js.map +1 -1
- package/dist/tools/javascript-repl.d.ts +16 -15
- package/dist/tools/javascript-repl.d.ts.map +1 -1
- package/dist/tools/javascript-repl.js +101 -133
- package/dist/tools/javascript-repl.js.map +1 -1
- package/dist/tools/renderer-registry.d.ts +12 -0
- package/dist/tools/renderer-registry.d.ts.map +1 -1
- package/dist/tools/renderer-registry.js +78 -0
- package/dist/tools/renderer-registry.js.map +1 -1
- package/dist/tools/renderers/BashRenderer.d.ts +2 -4
- package/dist/tools/renderers/BashRenderer.d.ts.map +1 -1
- package/dist/tools/renderers/BashRenderer.js +30 -26
- package/dist/tools/renderers/BashRenderer.js.map +1 -1
- package/dist/tools/renderers/CalculateRenderer.d.ts +2 -4
- package/dist/tools/renderers/CalculateRenderer.d.ts.map +1 -1
- package/dist/tools/renderers/CalculateRenderer.js +32 -28
- package/dist/tools/renderers/CalculateRenderer.js.map +1 -1
- package/dist/tools/renderers/DefaultRenderer.d.ts +2 -4
- package/dist/tools/renderers/DefaultRenderer.d.ts.map +1 -1
- package/dist/tools/renderers/DefaultRenderer.js +78 -18
- package/dist/tools/renderers/DefaultRenderer.js.map +1 -1
- package/dist/tools/renderers/GetCurrentTimeRenderer.d.ts +2 -4
- package/dist/tools/renderers/GetCurrentTimeRenderer.d.ts.map +1 -1
- package/dist/tools/renderers/GetCurrentTimeRenderer.js +57 -21
- package/dist/tools/renderers/GetCurrentTimeRenderer.js.map +1 -1
- package/dist/tools/types.d.ts +5 -2
- package/dist/tools/types.d.ts.map +1 -1
- package/dist/utils/i18n.d.ts +424 -1
- package/dist/utils/i18n.d.ts.map +1 -1
- package/dist/utils/i18n.js +131 -7
- package/dist/utils/i18n.js.map +1 -1
- package/example/package.json +2 -1
- package/example/src/custom-messages.ts +112 -0
- package/example/src/main.ts +391 -38
- package/package.json +48 -43
- package/scripts/count-prompt-tokens.ts +88 -0
- package/src/ChatPanel.ts +93 -101
- package/src/{state/agent-session.ts → agent/agent.ts} +80 -55
- package/src/{state → agent}/transports/AppTransport.ts +6 -6
- package/src/{state → agent}/transports/ProviderTransport.ts +13 -7
- package/src/{state → agent}/transports/types.ts +8 -2
- package/src/components/AgentInterface.ts +32 -16
- package/src/components/ConsoleBlock.ts +5 -1
- package/src/components/ExpandableSection.ts +46 -0
- package/src/components/MessageEditor.ts +159 -5
- package/src/components/MessageList.ts +18 -3
- package/src/components/Messages.ts +48 -89
- package/src/components/ProviderKeyInput.ts +6 -5
- package/src/components/SandboxedIframe.ts +412 -321
- 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 +187 -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 +35 -0
- package/src/dialogs/ApiKeyPromptDialog.ts +2 -5
- package/src/dialogs/ModelSelector.ts +2 -2
- package/src/dialogs/PersistentStorageDialog.ts +141 -0
- package/src/dialogs/SessionListDialog.ts +148 -0
- package/src/dialogs/SettingsDialog.ts +1 -0
- package/src/index.ts +61 -20
- package/src/prompts/prompts.ts +282 -0
- package/src/storage/app-storage.ts +27 -24
- package/src/storage/backends/indexeddb-storage-backend.ts +193 -0
- package/src/storage/store.ts +33 -0
- package/src/storage/stores/provider-keys-store.ts +33 -0
- package/src/storage/stores/sessions-store.ts +130 -0
- package/src/storage/stores/settings-store.ts +34 -0
- package/src/storage/types.ts +182 -22
- package/src/tools/artifacts/ArtifactElement.ts +0 -1
- package/src/tools/artifacts/ArtifactPill.ts +25 -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 +64 -94
- package/src/tools/artifacts/ImageArtifact.ts +116 -0
- package/src/tools/artifacts/MarkdownArtifact.ts +0 -1
- package/src/tools/artifacts/PdfArtifact.ts +201 -0
- package/src/tools/artifacts/SvgArtifact.ts +0 -1
- package/src/tools/artifacts/TextArtifact.ts +0 -1
- package/src/tools/artifacts/artifacts-tool-renderer.ts +298 -0
- package/src/tools/artifacts/artifacts.ts +190 -366
- package/src/tools/artifacts/index.ts +1 -0
- package/src/tools/extract-document.ts +250 -0
- package/src/tools/index.ts +25 -14
- package/src/tools/javascript-repl.ts +138 -160
- package/src/tools/renderer-registry.ts +98 -0
- package/src/tools/renderers/BashRenderer.ts +33 -30
- package/src/tools/renderers/CalculateRenderer.ts +36 -31
- package/src/tools/renderers/DefaultRenderer.ts +84 -21
- package/src/tools/renderers/GetCurrentTimeRenderer.ts +68 -23
- package/src/tools/types.ts +10 -2
- package/src/utils/i18n.ts +203 -8
- package/dist/state/agent-session.d.ts.map +0 -1
- package/dist/state/agent-session.js.map +0 -1
- package/dist/state/transports/AppTransport.d.ts.map +0 -1
- package/dist/state/transports/ProviderTransport.d.ts.map +0 -1
- package/dist/state/transports/ProviderTransport.js.map +0 -1
- package/dist/state/transports/index.js.map +0 -1
- package/dist/state/transports/proxy-types.js.map +0 -1
- package/dist/state/transports/types.d.ts +0 -11
- package/dist/state/transports/types.d.ts.map +0 -1
- package/dist/storage/backends/chrome-storage-backend.d.ts +0 -18
- package/dist/storage/backends/chrome-storage-backend.d.ts.map +0 -1
- package/dist/storage/backends/chrome-storage-backend.js +0 -67
- package/dist/storage/backends/chrome-storage-backend.js.map +0 -1
- package/dist/storage/backends/indexeddb-backend.d.ts +0 -20
- package/dist/storage/backends/indexeddb-backend.d.ts.map +0 -1
- package/dist/storage/backends/indexeddb-backend.js +0 -89
- package/dist/storage/backends/indexeddb-backend.js.map +0 -1
- package/dist/storage/backends/local-storage-backend.d.ts +0 -18
- package/dist/storage/backends/local-storage-backend.d.ts.map +0 -1
- package/dist/storage/backends/local-storage-backend.js +0 -69
- package/dist/storage/backends/local-storage-backend.js.map +0 -1
- package/dist/storage/repositories/provider-keys-repository.d.ts +0 -34
- package/dist/storage/repositories/provider-keys-repository.d.ts.map +0 -1
- package/dist/storage/repositories/provider-keys-repository.js +0 -50
- package/dist/storage/repositories/provider-keys-repository.js.map +0 -1
- package/dist/storage/repositories/settings-repository.d.ts +0 -34
- package/dist/storage/repositories/settings-repository.d.ts.map +0 -1
- package/dist/storage/repositories/settings-repository.js +0 -46
- package/dist/storage/repositories/settings-repository.js.map +0 -1
- package/src/storage/backends/chrome-storage-backend.ts +0 -82
- package/src/storage/backends/indexeddb-backend.ts +0 -107
- package/src/storage/backends/local-storage-backend.ts +0 -74
- package/src/storage/repositories/provider-keys-repository.ts +0 -55
- package/src/storage/repositories/settings-repository.ts +0 -51
- /package/dist/{state → agent}/transports/index.d.ts +0 -0
- /package/dist/{state → agent}/transports/index.js +0 -0
- /package/dist/{state → agent}/transports/proxy-types.d.ts +0 -0
- /package/dist/{state → agent}/transports/proxy-types.js +0 -0
- /package/dist/{state → agent}/transports/types.js +0 -0
- /package/dist/{state → agent}/types.d.ts +0 -0
- /package/dist/{state → agent}/types.js +0 -0
- /package/src/{state → agent}/transports/index.ts +0 -0
- /package/src/{state → agent}/transports/proxy-types.ts +0 -0
- /package/src/{state → agent}/types.ts +0 -0
|
@@ -0,0 +1,298 @@
|
|
|
1
|
+
import { Diff, html, type TemplateResult } from "@mariozechner/mini-lit";
|
|
2
|
+
import "@mariozechner/mini-lit/dist/CodeBlock.js";
|
|
3
|
+
import type { ToolResultMessage } from "@mariozechner/pi-ai";
|
|
4
|
+
import { createRef, ref } from "lit/directives/ref.js";
|
|
5
|
+
import { FileCode2 } from "lucide";
|
|
6
|
+
import "../../components/ConsoleBlock.js";
|
|
7
|
+
import { i18n } from "../../utils/i18n.js";
|
|
8
|
+
import { renderCollapsibleHeader, renderHeader } from "../renderer-registry.js";
|
|
9
|
+
import type { ToolRenderer, ToolRenderResult } from "../types.js";
|
|
10
|
+
import { ArtifactPill } from "./ArtifactPill.js";
|
|
11
|
+
import type { ArtifactsPanel, ArtifactsParams } from "./artifacts.js";
|
|
12
|
+
|
|
13
|
+
// Helper to determine language for syntax highlighting
|
|
14
|
+
function getLanguageFromFilename(filename?: string): string {
|
|
15
|
+
if (!filename) return "text";
|
|
16
|
+
const ext = filename.split(".").pop()?.toLowerCase();
|
|
17
|
+
const languageMap: Record<string, string> = {
|
|
18
|
+
js: "javascript",
|
|
19
|
+
jsx: "javascript",
|
|
20
|
+
ts: "typescript",
|
|
21
|
+
tsx: "typescript",
|
|
22
|
+
html: "html",
|
|
23
|
+
css: "css",
|
|
24
|
+
scss: "scss",
|
|
25
|
+
json: "json",
|
|
26
|
+
py: "python",
|
|
27
|
+
md: "markdown",
|
|
28
|
+
svg: "xml",
|
|
29
|
+
xml: "xml",
|
|
30
|
+
yaml: "yaml",
|
|
31
|
+
yml: "yaml",
|
|
32
|
+
sh: "bash",
|
|
33
|
+
bash: "bash",
|
|
34
|
+
sql: "sql",
|
|
35
|
+
java: "java",
|
|
36
|
+
c: "c",
|
|
37
|
+
cpp: "cpp",
|
|
38
|
+
cs: "csharp",
|
|
39
|
+
go: "go",
|
|
40
|
+
rs: "rust",
|
|
41
|
+
php: "php",
|
|
42
|
+
rb: "ruby",
|
|
43
|
+
swift: "swift",
|
|
44
|
+
kt: "kotlin",
|
|
45
|
+
r: "r",
|
|
46
|
+
};
|
|
47
|
+
return languageMap[ext || ""] || "text";
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export class ArtifactsToolRenderer implements ToolRenderer<ArtifactsParams, undefined> {
|
|
51
|
+
constructor(public artifactsPanel?: ArtifactsPanel) {}
|
|
52
|
+
|
|
53
|
+
render(
|
|
54
|
+
params: ArtifactsParams | undefined,
|
|
55
|
+
result: ToolResultMessage<undefined> | undefined,
|
|
56
|
+
isStreaming?: boolean,
|
|
57
|
+
): ToolRenderResult {
|
|
58
|
+
const state = result ? (result.isError ? "error" : "complete") : isStreaming ? "inprogress" : "complete";
|
|
59
|
+
|
|
60
|
+
// Create refs for collapsible sections
|
|
61
|
+
const contentRef = createRef<HTMLDivElement>();
|
|
62
|
+
const chevronRef = createRef<HTMLSpanElement>();
|
|
63
|
+
|
|
64
|
+
// Helper to get command labels
|
|
65
|
+
const getCommandLabels = (command: string): { streaming: string; complete: string } => {
|
|
66
|
+
const labels: Record<string, { streaming: string; complete: string }> = {
|
|
67
|
+
create: { streaming: i18n("Creating artifact"), complete: i18n("Created artifact") },
|
|
68
|
+
update: { streaming: i18n("Updating artifact"), complete: i18n("Updated artifact") },
|
|
69
|
+
rewrite: { streaming: i18n("Rewriting artifact"), complete: i18n("Rewrote artifact") },
|
|
70
|
+
get: { streaming: i18n("Getting artifact"), complete: i18n("Got artifact") },
|
|
71
|
+
delete: { streaming: i18n("Deleting artifact"), complete: i18n("Deleted artifact") },
|
|
72
|
+
logs: { streaming: i18n("Getting logs"), complete: i18n("Got logs") },
|
|
73
|
+
};
|
|
74
|
+
return labels[command] || { streaming: i18n("Processing artifact"), complete: i18n("Processed artifact") };
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
// Helper to render header text with inline artifact pill
|
|
78
|
+
const renderHeaderWithPill = (labelText: string, filename?: string): TemplateResult => {
|
|
79
|
+
if (filename) {
|
|
80
|
+
return html`<span>${labelText} ${ArtifactPill(filename, this.artifactsPanel)}</span>`;
|
|
81
|
+
}
|
|
82
|
+
return html`<span>${labelText}</span>`;
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
// Error handling
|
|
86
|
+
if (result?.isError) {
|
|
87
|
+
const command = params?.command;
|
|
88
|
+
const filename = params?.filename;
|
|
89
|
+
const labels = command
|
|
90
|
+
? getCommandLabels(command)
|
|
91
|
+
: { streaming: i18n("Processing artifact"), complete: i18n("Processed artifact") };
|
|
92
|
+
const headerText = labels.streaming;
|
|
93
|
+
|
|
94
|
+
// For create/update/rewrite errors, show code block + console/error
|
|
95
|
+
if (command === "create" || command === "update" || command === "rewrite") {
|
|
96
|
+
const content = params?.content || "";
|
|
97
|
+
const { old_str, new_str } = params || {};
|
|
98
|
+
const isDiff = command === "update";
|
|
99
|
+
const diffContent =
|
|
100
|
+
old_str !== undefined && new_str !== undefined ? Diff({ oldText: old_str, newText: new_str }) : "";
|
|
101
|
+
|
|
102
|
+
const isHtml = filename?.endsWith(".html");
|
|
103
|
+
|
|
104
|
+
return {
|
|
105
|
+
content: html`
|
|
106
|
+
<div>
|
|
107
|
+
${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
|
|
108
|
+
<div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300 space-y-3">
|
|
109
|
+
${isDiff ? diffContent : content ? html`<code-block .code=${content} language=${getLanguageFromFilename(filename)}></code-block>` : ""}
|
|
110
|
+
${
|
|
111
|
+
isHtml
|
|
112
|
+
? html`<console-block .content=${result.output || i18n("An error occurred")} variant="error"></console-block>`
|
|
113
|
+
: html`<div class="text-sm text-destructive">${result.output || i18n("An error occurred")}</div>`
|
|
114
|
+
}
|
|
115
|
+
</div>
|
|
116
|
+
</div>
|
|
117
|
+
`,
|
|
118
|
+
isCustom: false,
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
// For other errors, just show error message
|
|
123
|
+
return {
|
|
124
|
+
content: html`
|
|
125
|
+
<div class="space-y-3">
|
|
126
|
+
${renderHeader(state, FileCode2, headerText)}
|
|
127
|
+
<div class="text-sm text-destructive">${result.output || i18n("An error occurred")}</div>
|
|
128
|
+
</div>
|
|
129
|
+
`,
|
|
130
|
+
isCustom: false,
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
// Full params + result
|
|
135
|
+
if (result && params) {
|
|
136
|
+
const { command, filename, content } = params;
|
|
137
|
+
const labels = command
|
|
138
|
+
? getCommandLabels(command)
|
|
139
|
+
: { streaming: i18n("Processing artifact"), complete: i18n("Processed artifact") };
|
|
140
|
+
const headerText = labels.complete;
|
|
141
|
+
|
|
142
|
+
// GET command: show code block with file content
|
|
143
|
+
if (command === "get") {
|
|
144
|
+
const fileContent = result.output || i18n("(no output)");
|
|
145
|
+
return {
|
|
146
|
+
content: html`
|
|
147
|
+
<div>
|
|
148
|
+
${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
|
|
149
|
+
<div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300">
|
|
150
|
+
<code-block .code=${fileContent} language=${getLanguageFromFilename(filename)}></code-block>
|
|
151
|
+
</div>
|
|
152
|
+
</div>
|
|
153
|
+
`,
|
|
154
|
+
isCustom: false,
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
// LOGS command: show console block
|
|
159
|
+
if (command === "logs") {
|
|
160
|
+
const logs = result.output || i18n("(no output)");
|
|
161
|
+
return {
|
|
162
|
+
content: html`
|
|
163
|
+
<div>
|
|
164
|
+
${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
|
|
165
|
+
<div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300">
|
|
166
|
+
<console-block .content=${logs}></console-block>
|
|
167
|
+
</div>
|
|
168
|
+
</div>
|
|
169
|
+
`,
|
|
170
|
+
isCustom: false,
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
// CREATE/UPDATE/REWRITE: always show code block, + console block for .html files
|
|
175
|
+
if (command === "create" || command === "rewrite") {
|
|
176
|
+
const codeContent = content || "";
|
|
177
|
+
const isHtml = filename?.endsWith(".html");
|
|
178
|
+
const logs = result.output || "";
|
|
179
|
+
|
|
180
|
+
return {
|
|
181
|
+
content: html`
|
|
182
|
+
<div>
|
|
183
|
+
${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
|
|
184
|
+
<div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300 space-y-3">
|
|
185
|
+
${codeContent ? html`<code-block .code=${codeContent} language=${getLanguageFromFilename(filename)}></code-block>` : ""}
|
|
186
|
+
${isHtml && logs ? html`<console-block .content=${logs}></console-block>` : ""}
|
|
187
|
+
</div>
|
|
188
|
+
</div>
|
|
189
|
+
`,
|
|
190
|
+
isCustom: false,
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
if (command === "update") {
|
|
195
|
+
const isHtml = filename?.endsWith(".html");
|
|
196
|
+
const logs = result.output || "";
|
|
197
|
+
return {
|
|
198
|
+
content: html`
|
|
199
|
+
<div>
|
|
200
|
+
${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
|
|
201
|
+
<div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300 space-y-3">
|
|
202
|
+
${Diff({ oldText: params.old_str || "", newText: params.new_str || "" })}
|
|
203
|
+
${isHtml && logs ? html`<console-block .content=${logs}></console-block>` : ""}
|
|
204
|
+
</div>
|
|
205
|
+
</div>
|
|
206
|
+
`,
|
|
207
|
+
isCustom: false,
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
// For DELETE, just show header
|
|
212
|
+
return {
|
|
213
|
+
content: html`
|
|
214
|
+
<div class="space-y-3">
|
|
215
|
+
${renderHeader(state, FileCode2, renderHeaderWithPill(headerText, filename))}
|
|
216
|
+
</div>
|
|
217
|
+
`,
|
|
218
|
+
isCustom: false,
|
|
219
|
+
};
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
// Params only (streaming or waiting for result)
|
|
223
|
+
if (params) {
|
|
224
|
+
const { command, filename, content, old_str, new_str } = params;
|
|
225
|
+
|
|
226
|
+
// If no command yet
|
|
227
|
+
if (!command) {
|
|
228
|
+
return { content: renderHeader(state, FileCode2, i18n("Preparing artifact...")), isCustom: false };
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
const labels = getCommandLabels(command);
|
|
232
|
+
const headerText = labels.streaming;
|
|
233
|
+
|
|
234
|
+
// Render based on command type
|
|
235
|
+
switch (command) {
|
|
236
|
+
case "create":
|
|
237
|
+
case "rewrite":
|
|
238
|
+
return {
|
|
239
|
+
content: html`
|
|
240
|
+
<div>
|
|
241
|
+
${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
|
|
242
|
+
<div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300">
|
|
243
|
+
${
|
|
244
|
+
content
|
|
245
|
+
? html`<code-block .code=${content} language=${getLanguageFromFilename(filename)}></code-block>`
|
|
246
|
+
: ""
|
|
247
|
+
}
|
|
248
|
+
</div>
|
|
249
|
+
</div>
|
|
250
|
+
`,
|
|
251
|
+
isCustom: false,
|
|
252
|
+
};
|
|
253
|
+
|
|
254
|
+
case "update":
|
|
255
|
+
return {
|
|
256
|
+
content: html`
|
|
257
|
+
<div>
|
|
258
|
+
${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
|
|
259
|
+
<div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300">
|
|
260
|
+
${
|
|
261
|
+
old_str !== undefined && new_str !== undefined
|
|
262
|
+
? Diff({ oldText: old_str, newText: new_str })
|
|
263
|
+
: ""
|
|
264
|
+
}
|
|
265
|
+
</div>
|
|
266
|
+
</div>
|
|
267
|
+
`,
|
|
268
|
+
isCustom: false,
|
|
269
|
+
};
|
|
270
|
+
|
|
271
|
+
case "get":
|
|
272
|
+
case "logs":
|
|
273
|
+
return {
|
|
274
|
+
content: html`
|
|
275
|
+
<div>
|
|
276
|
+
${renderCollapsibleHeader(state, FileCode2, renderHeaderWithPill(headerText, filename), contentRef, chevronRef, false)}
|
|
277
|
+
<div ${ref(contentRef)} class="max-h-0 overflow-hidden transition-all duration-300"></div>
|
|
278
|
+
</div>
|
|
279
|
+
`,
|
|
280
|
+
isCustom: false,
|
|
281
|
+
};
|
|
282
|
+
|
|
283
|
+
default:
|
|
284
|
+
return {
|
|
285
|
+
content: html`
|
|
286
|
+
<div>
|
|
287
|
+
${renderHeader(state, FileCode2, renderHeaderWithPill(headerText, filename))}
|
|
288
|
+
</div>
|
|
289
|
+
`,
|
|
290
|
+
isCustom: false,
|
|
291
|
+
};
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
// No params or result yet
|
|
296
|
+
return { content: renderHeader(state, FileCode2, i18n("Preparing artifact...")), isCustom: false };
|
|
297
|
+
}
|
|
298
|
+
}
|