@mariozechner/pi-web-ui 0.5.44
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 +252 -0
- package/dist/ChatPanel.d.ts +23 -0
- package/dist/ChatPanel.d.ts.map +1 -0
- package/dist/ChatPanel.js +224 -0
- package/dist/ChatPanel.js.map +1 -0
- package/dist/app.css +2 -0
- package/dist/components/AgentInterface.d.ts +35 -0
- package/dist/components/AgentInterface.d.ts.map +1 -0
- package/dist/components/AgentInterface.js +308 -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 +114 -0
- package/dist/components/AttachmentTile.js.map +1 -0
- package/dist/components/ConsoleBlock.d.ts +11 -0
- package/dist/components/ConsoleBlock.d.ts.map +1 -0
- package/dist/components/ConsoleBlock.js +77 -0
- package/dist/components/ConsoleBlock.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 +56 -0
- package/dist/components/Input.js.map +1 -0
- package/dist/components/MessageEditor.d.ts +38 -0
- package/dist/components/MessageEditor.d.ts.map +1 -0
- package/dist/components/MessageEditor.js +296 -0
- package/dist/components/MessageEditor.js.map +1 -0
- package/dist/components/MessageList.d.ts +13 -0
- package/dist/components/MessageList.d.ts.map +1 -0
- package/dist/components/MessageList.js +88 -0
- package/dist/components/MessageList.js.map +1 -0
- package/dist/components/Messages.d.ts +53 -0
- package/dist/components/Messages.d.ts.map +1 -0
- package/dist/components/Messages.js +323 -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 +183 -0
- package/dist/components/ProviderKeyInput.js.map +1 -0
- package/dist/components/SandboxedIframe.d.ts +63 -0
- package/dist/components/SandboxedIframe.d.ts.map +1 -0
- package/dist/components/SandboxedIframe.js +435 -0
- package/dist/components/SandboxedIframe.js.map +1 -0
- package/dist/components/StreamingMessageContainer.d.ts +17 -0
- package/dist/components/StreamingMessageContainer.d.ts.map +1 -0
- package/dist/components/StreamingMessageContainer.js +114 -0
- package/dist/components/StreamingMessageContainer.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 +80 -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 +575 -0
- package/dist/dialogs/AttachmentOverlay.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 +334 -0
- package/dist/dialogs/ModelSelector.js.map +1 -0
- package/dist/dialogs/SettingsDialog.d.ts +31 -0
- package/dist/dialogs/SettingsDialog.d.ts.map +1 -0
- package/dist/dialogs/SettingsDialog.js +228 -0
- package/dist/dialogs/SettingsDialog.js.map +1 -0
- package/dist/index.d.ts +46 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +51 -0
- package/dist/index.js.map +1 -0
- package/dist/state/agent-session.d.ts +58 -0
- package/dist/state/agent-session.d.ts.map +1 -0
- package/dist/state/agent-session.js +252 -0
- package/dist/state/agent-session.js.map +1 -0
- package/dist/state/transports/AppTransport.d.ts +13 -0
- package/dist/state/transports/AppTransport.d.ts.map +1 -0
- package/dist/state/transports/AppTransport.js +316 -0
- package/dist/state/transports/AppTransport.js.map +1 -0
- package/dist/state/transports/ProviderTransport.d.ts +12 -0
- package/dist/state/transports/ProviderTransport.d.ts.map +1 -0
- package/dist/state/transports/ProviderTransport.js +44 -0
- package/dist/state/transports/ProviderTransport.js.map +1 -0
- package/dist/state/transports/index.d.ts +4 -0
- package/dist/state/transports/index.d.ts.map +1 -0
- package/dist/state/transports/index.js +4 -0
- package/dist/state/transports/index.js.map +1 -0
- package/dist/state/transports/proxy-types.d.ts +48 -0
- package/dist/state/transports/proxy-types.d.ts.map +1 -0
- package/dist/state/transports/proxy-types.js +2 -0
- package/dist/state/transports/proxy-types.js.map +1 -0
- package/dist/state/transports/types.d.ts +11 -0
- package/dist/state/transports/types.d.ts.map +1 -0
- package/dist/state/transports/types.js +2 -0
- package/dist/state/transports/types.js.map +1 -0
- package/dist/state/types.d.ts +15 -0
- package/dist/state/types.d.ts.map +1 -0
- package/dist/state/types.js +2 -0
- package/dist/state/types.js.map +1 -0
- package/dist/storage/app-storage.d.ts +26 -0
- package/dist/storage/app-storage.d.ts.map +1 -0
- package/dist/storage/app-storage.js +44 -0
- package/dist/storage/app-storage.js.map +1 -0
- package/dist/storage/backends/chrome-storage-backend.d.ts +18 -0
- package/dist/storage/backends/chrome-storage-backend.d.ts.map +1 -0
- package/dist/storage/backends/chrome-storage-backend.js +67 -0
- package/dist/storage/backends/chrome-storage-backend.js.map +1 -0
- package/dist/storage/backends/indexeddb-backend.d.ts +20 -0
- package/dist/storage/backends/indexeddb-backend.d.ts.map +1 -0
- package/dist/storage/backends/indexeddb-backend.js +89 -0
- package/dist/storage/backends/indexeddb-backend.js.map +1 -0
- package/dist/storage/backends/local-storage-backend.d.ts +18 -0
- package/dist/storage/backends/local-storage-backend.d.ts.map +1 -0
- package/dist/storage/backends/local-storage-backend.js +69 -0
- package/dist/storage/backends/local-storage-backend.js.map +1 -0
- package/dist/storage/repositories/provider-keys-repository.d.ts +34 -0
- package/dist/storage/repositories/provider-keys-repository.d.ts.map +1 -0
- package/dist/storage/repositories/provider-keys-repository.js +50 -0
- package/dist/storage/repositories/provider-keys-repository.js.map +1 -0
- package/dist/storage/repositories/settings-repository.d.ts +34 -0
- package/dist/storage/repositories/settings-repository.d.ts.map +1 -0
- package/dist/storage/repositories/settings-repository.js +46 -0
- package/dist/storage/repositories/settings-repository.js.map +1 -0
- package/dist/storage/types.d.ts +43 -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 +10 -0
- package/dist/tools/artifacts/ArtifactElement.d.ts.map +1 -0
- package/dist/tools/artifacts/ArtifactElement.js +12 -0
- package/dist/tools/artifacts/ArtifactElement.js.map +1 -0
- package/dist/tools/artifacts/HtmlArtifact.d.ts +30 -0
- package/dist/tools/artifacts/HtmlArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/HtmlArtifact.js +217 -0
- package/dist/tools/artifacts/HtmlArtifact.js.map +1 -0
- package/dist/tools/artifacts/MarkdownArtifact.d.ts +20 -0
- package/dist/tools/artifacts/MarkdownArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/MarkdownArtifact.js +84 -0
- package/dist/tools/artifacts/MarkdownArtifact.js.map +1 -0
- package/dist/tools/artifacts/SvgArtifact.d.ts +19 -0
- package/dist/tools/artifacts/SvgArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/SvgArtifact.js +80 -0
- package/dist/tools/artifacts/SvgArtifact.js.map +1 -0
- package/dist/tools/artifacts/TextArtifact.d.ts +20 -0
- package/dist/tools/artifacts/TextArtifact.d.ts.map +1 -0
- package/dist/tools/artifacts/TextArtifact.js +147 -0
- package/dist/tools/artifacts/TextArtifact.js.map +1 -0
- package/dist/tools/artifacts/artifacts.d.ts +67 -0
- package/dist/tools/artifacts/artifacts.d.ts.map +1 -0
- package/dist/tools/artifacts/artifacts.js +836 -0
- package/dist/tools/artifacts/artifacts.js.map +1 -0
- package/dist/tools/artifacts/index.d.ts +7 -0
- package/dist/tools/artifacts/index.d.ts.map +1 -0
- package/dist/tools/artifacts/index.js +7 -0
- package/dist/tools/artifacts/index.js.map +1 -0
- package/dist/tools/index.d.ts +14 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +29 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/javascript-repl.d.ts +43 -0
- package/dist/tools/javascript-repl.d.ts.map +1 -0
- package/dist/tools/javascript-repl.js +252 -0
- package/dist/tools/javascript-repl.js.map +1 -0
- package/dist/tools/renderer-registry.d.ts +11 -0
- package/dist/tools/renderer-registry.d.ts.map +1 -0
- package/dist/tools/renderer-registry.js +15 -0
- package/dist/tools/renderer-registry.js.map +1 -0
- package/dist/tools/renderers/BashRenderer.d.ts +12 -0
- package/dist/tools/renderers/BashRenderer.d.ts.map +1 -0
- package/dist/tools/renderers/BashRenderer.js +35 -0
- package/dist/tools/renderers/BashRenderer.js.map +1 -0
- package/dist/tools/renderers/CalculateRenderer.d.ts +12 -0
- package/dist/tools/renderers/CalculateRenderer.d.ts.map +1 -0
- package/dist/tools/renderers/CalculateRenderer.js +38 -0
- package/dist/tools/renderers/CalculateRenderer.js.map +1 -0
- package/dist/tools/renderers/DefaultRenderer.d.ts +8 -0
- package/dist/tools/renderers/DefaultRenderer.d.ts.map +1 -0
- package/dist/tools/renderers/DefaultRenderer.js +31 -0
- package/dist/tools/renderers/DefaultRenderer.js.map +1 -0
- package/dist/tools/renderers/GetCurrentTimeRenderer.d.ts +12 -0
- package/dist/tools/renderers/GetCurrentTimeRenderer.d.ts.map +1 -0
- package/dist/tools/renderers/GetCurrentTimeRenderer.js +30 -0
- package/dist/tools/renderers/GetCurrentTimeRenderer.js.map +1 -0
- package/dist/tools/types.d.ts +7 -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 +111 -0
- package/dist/utils/i18n.d.ts.map +1 -0
- package/dist/utils/i18n.js +224 -0
- package/dist/utils/i18n.js.map +1 -0
- package/dist/utils/test-sessions.d.ts +347 -0
- package/dist/utils/test-sessions.d.ts.map +1 -0
- package/dist/utils/test-sessions.js +2215 -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-lock.json +1965 -0
- package/example/package.json +22 -0
- package/example/src/app.css +1 -0
- package/example/src/main.ts +57 -0
- package/example/src/test-sessions.ts +104 -0
- package/example/tsconfig.json +15 -0
- package/example/vite.config.ts +6 -0
- package/package.json +45 -0
- package/src/ChatPanel.ts +214 -0
- package/src/app.css +44 -0
- package/src/components/AgentInterface.ts +316 -0
- package/src/components/AttachmentTile.ts +112 -0
- package/src/components/ConsoleBlock.ts +67 -0
- package/src/components/Input.ts +112 -0
- package/src/components/MessageEditor.ts +272 -0
- package/src/components/MessageList.ts +82 -0
- package/src/components/Messages.ts +310 -0
- package/src/components/ProviderKeyInput.ts +170 -0
- package/src/components/SandboxedIframe.ts +525 -0
- package/src/components/StreamingMessageContainer.ts +101 -0
- package/src/dialogs/ApiKeyPromptDialog.ts +76 -0
- package/src/dialogs/AttachmentOverlay.ts +635 -0
- package/src/dialogs/ModelSelector.ts +324 -0
- package/src/dialogs/SettingsDialog.ts +223 -0
- package/src/index.ts +63 -0
- package/src/state/agent-session.ts +311 -0
- package/src/state/transports/AppTransport.ts +363 -0
- package/src/state/transports/ProviderTransport.ts +49 -0
- package/src/state/transports/index.ts +3 -0
- package/src/state/transports/proxy-types.ts +15 -0
- package/src/state/transports/types.ts +16 -0
- package/src/state/types.ts +11 -0
- package/src/storage/app-storage.ts +53 -0
- package/src/storage/backends/chrome-storage-backend.ts +82 -0
- package/src/storage/backends/indexeddb-backend.ts +107 -0
- package/src/storage/backends/local-storage-backend.ts +74 -0
- package/src/storage/repositories/provider-keys-repository.ts +55 -0
- package/src/storage/repositories/settings-repository.ts +51 -0
- package/src/storage/types.ts +48 -0
- package/src/tools/artifacts/ArtifactElement.ts +15 -0
- package/src/tools/artifacts/HtmlArtifact.ts +221 -0
- package/src/tools/artifacts/MarkdownArtifact.ts +81 -0
- package/src/tools/artifacts/SvgArtifact.ts +77 -0
- package/src/tools/artifacts/TextArtifact.ts +148 -0
- package/src/tools/artifacts/artifacts.ts +888 -0
- package/src/tools/artifacts/index.ts +6 -0
- package/src/tools/index.ts +35 -0
- package/src/tools/javascript-repl.ts +309 -0
- package/src/tools/renderer-registry.ts +18 -0
- package/src/tools/renderers/BashRenderer.ts +45 -0
- package/src/tools/renderers/CalculateRenderer.ts +49 -0
- package/src/tools/renderers/DefaultRenderer.ts +36 -0
- package/src/tools/renderers/GetCurrentTimeRenderer.ts +39 -0
- package/src/tools/types.ts +7 -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 +343 -0
- package/src/utils/test-sessions.ts +2247 -0
- package/tsconfig.build.json +20 -0
- package/tsconfig.json +7 -0
|
@@ -0,0 +1,217 @@
|
|
|
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 { CopyButton, DownloadButton, PreviewCodeToggle } from "@mariozechner/mini-lit";
|
|
8
|
+
import hljs from "highlight.js";
|
|
9
|
+
import { html } from "lit";
|
|
10
|
+
import { customElement, property, state } from "lit/decorators.js";
|
|
11
|
+
import { createRef, ref } from "lit/directives/ref.js";
|
|
12
|
+
import { unsafeHTML } from "lit/directives/unsafe-html.js";
|
|
13
|
+
import { i18n } from "../../utils/i18n.js";
|
|
14
|
+
import "../../components/SandboxedIframe.js";
|
|
15
|
+
import { ArtifactElement } from "./ArtifactElement.js";
|
|
16
|
+
let HtmlArtifact = class HtmlArtifact extends ArtifactElement {
|
|
17
|
+
constructor() {
|
|
18
|
+
super(...arguments);
|
|
19
|
+
this.filename = "";
|
|
20
|
+
this.displayTitle = "";
|
|
21
|
+
this.attachments = [];
|
|
22
|
+
this._content = "";
|
|
23
|
+
this.logs = [];
|
|
24
|
+
// Refs for DOM elements
|
|
25
|
+
this.sandboxIframeRef = createRef();
|
|
26
|
+
this.consoleLogsRef = createRef();
|
|
27
|
+
this.consoleButtonRef = createRef();
|
|
28
|
+
this.viewMode = "preview";
|
|
29
|
+
this.consoleOpen = false;
|
|
30
|
+
}
|
|
31
|
+
setViewMode(mode) {
|
|
32
|
+
this.viewMode = mode;
|
|
33
|
+
}
|
|
34
|
+
getHeaderButtons() {
|
|
35
|
+
const toggle = new PreviewCodeToggle();
|
|
36
|
+
toggle.mode = this.viewMode;
|
|
37
|
+
toggle.addEventListener("mode-change", (e) => {
|
|
38
|
+
this.setViewMode(e.detail);
|
|
39
|
+
});
|
|
40
|
+
const copyButton = new CopyButton();
|
|
41
|
+
copyButton.text = this._content;
|
|
42
|
+
copyButton.title = i18n("Copy HTML");
|
|
43
|
+
copyButton.showText = false;
|
|
44
|
+
return html `
|
|
45
|
+
<div class="flex items-center gap-2">
|
|
46
|
+
${toggle}
|
|
47
|
+
${copyButton}
|
|
48
|
+
${DownloadButton({ content: this._content, filename: this.filename, mimeType: "text/html", title: i18n("Download HTML") })}
|
|
49
|
+
</div>
|
|
50
|
+
`;
|
|
51
|
+
}
|
|
52
|
+
set content(value) {
|
|
53
|
+
const oldValue = this._content;
|
|
54
|
+
this._content = value;
|
|
55
|
+
if (oldValue !== value) {
|
|
56
|
+
// Reset logs when content changes
|
|
57
|
+
this.logs = [];
|
|
58
|
+
if (this.consoleLogsRef.value) {
|
|
59
|
+
this.consoleLogsRef.value.innerHTML = "";
|
|
60
|
+
}
|
|
61
|
+
this.requestUpdate();
|
|
62
|
+
// Execute content in sandbox if it exists
|
|
63
|
+
if (this.sandboxIframeRef.value && value) {
|
|
64
|
+
this.updateConsoleButton();
|
|
65
|
+
this.executeContent(value);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
executeContent(html) {
|
|
70
|
+
const sandbox = this.sandboxIframeRef.value;
|
|
71
|
+
if (!sandbox)
|
|
72
|
+
return;
|
|
73
|
+
// Configure sandbox URL provider if provided (for browser extensions)
|
|
74
|
+
if (this.sandboxUrlProvider) {
|
|
75
|
+
sandbox.sandboxUrlProvider = this.sandboxUrlProvider;
|
|
76
|
+
}
|
|
77
|
+
// Remove previous message handler if it exists
|
|
78
|
+
if (this.messageHandler) {
|
|
79
|
+
window.removeEventListener("message", this.messageHandler);
|
|
80
|
+
}
|
|
81
|
+
const sandboxId = `artifact-${this.filename}`;
|
|
82
|
+
// Set up message listener to collect logs
|
|
83
|
+
this.messageHandler = (e) => {
|
|
84
|
+
if (e.data.sandboxId !== sandboxId)
|
|
85
|
+
return;
|
|
86
|
+
if (e.data.type === "console") {
|
|
87
|
+
this.logs.push({
|
|
88
|
+
type: e.data.method === "error" ? "error" : "log",
|
|
89
|
+
text: e.data.text,
|
|
90
|
+
});
|
|
91
|
+
this.updateConsoleButton();
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
window.addEventListener("message", this.messageHandler);
|
|
95
|
+
// Load content (iframe persists, doesn't get removed)
|
|
96
|
+
sandbox.loadContent(sandboxId, html, this.attachments);
|
|
97
|
+
}
|
|
98
|
+
get content() {
|
|
99
|
+
return this._content;
|
|
100
|
+
}
|
|
101
|
+
disconnectedCallback() {
|
|
102
|
+
super.disconnectedCallback();
|
|
103
|
+
// Clean up message handler when element is removed from DOM
|
|
104
|
+
if (this.messageHandler) {
|
|
105
|
+
window.removeEventListener("message", this.messageHandler);
|
|
106
|
+
this.messageHandler = undefined;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
firstUpdated() {
|
|
110
|
+
// Execute initial content
|
|
111
|
+
if (this._content && this.sandboxIframeRef.value) {
|
|
112
|
+
this.executeContent(this._content);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
updated(changedProperties) {
|
|
116
|
+
super.updated(changedProperties);
|
|
117
|
+
// If we have content but haven't executed yet (e.g., during reconstruction),
|
|
118
|
+
// execute when the iframe ref becomes available
|
|
119
|
+
if (this._content && this.sandboxIframeRef.value && this.logs.length === 0) {
|
|
120
|
+
this.executeContent(this._content);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
updateConsoleButton() {
|
|
124
|
+
const button = this.consoleButtonRef.value;
|
|
125
|
+
if (!button)
|
|
126
|
+
return;
|
|
127
|
+
const errorCount = this.logs.filter((l) => l.type === "error").length;
|
|
128
|
+
const text = errorCount > 0
|
|
129
|
+
? `${i18n("console")} <span class="text-destructive">${errorCount} errors</span>`
|
|
130
|
+
: `${i18n("console")} (${this.logs.length})`;
|
|
131
|
+
button.innerHTML = `<span>${text}</span><span>${this.consoleOpen ? "▼" : "▶"}</span>`;
|
|
132
|
+
}
|
|
133
|
+
toggleConsole() {
|
|
134
|
+
this.consoleOpen = !this.consoleOpen;
|
|
135
|
+
this.requestUpdate();
|
|
136
|
+
// Populate console logs if opening
|
|
137
|
+
if (this.consoleOpen) {
|
|
138
|
+
requestAnimationFrame(() => {
|
|
139
|
+
if (this.consoleLogsRef.value) {
|
|
140
|
+
// Populate with existing logs
|
|
141
|
+
this.consoleLogsRef.value.innerHTML = "";
|
|
142
|
+
this.logs.forEach((log) => {
|
|
143
|
+
const logEl = document.createElement("div");
|
|
144
|
+
logEl.className = `text-xs font-mono ${log.type === "error" ? "text-destructive" : "text-muted-foreground"}`;
|
|
145
|
+
logEl.textContent = `[${log.type}] ${log.text}`;
|
|
146
|
+
this.consoleLogsRef.value.appendChild(logEl);
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
getLogs() {
|
|
153
|
+
if (this.logs.length === 0)
|
|
154
|
+
return i18n("No logs for {filename}").replace("{filename}", this.filename);
|
|
155
|
+
return this.logs.map((l) => `[${l.type}] ${l.text}`).join("\n");
|
|
156
|
+
}
|
|
157
|
+
render() {
|
|
158
|
+
return html `
|
|
159
|
+
<div class="h-full flex flex-col">
|
|
160
|
+
<div class="flex-1 overflow-hidden relative">
|
|
161
|
+
<!-- Preview container - always in DOM, just hidden when not active -->
|
|
162
|
+
<div class="absolute inset-0 flex flex-col" style="display: ${this.viewMode === "preview" ? "flex" : "none"}">
|
|
163
|
+
<sandbox-iframe class="flex-1" ${ref(this.sandboxIframeRef)}></sandbox-iframe>
|
|
164
|
+
${this.logs.length > 0
|
|
165
|
+
? html `
|
|
166
|
+
<div class="border-t border-border">
|
|
167
|
+
<button
|
|
168
|
+
@click=${() => this.toggleConsole()}
|
|
169
|
+
class="w-full px-3 py-1 text-xs text-left hover:bg-muted flex items-center justify-between"
|
|
170
|
+
${ref(this.consoleButtonRef)}
|
|
171
|
+
>
|
|
172
|
+
<span
|
|
173
|
+
>${i18n("console")}
|
|
174
|
+
${this.logs.filter((l) => l.type === "error").length > 0
|
|
175
|
+
? html `<span class="text-destructive">${this.logs.filter((l) => l.type === "error").length} errors</span>`
|
|
176
|
+
: `(${this.logs.length})`}</span
|
|
177
|
+
>
|
|
178
|
+
<span>${this.consoleOpen ? "▼" : "▶"}</span>
|
|
179
|
+
</button>
|
|
180
|
+
${this.consoleOpen ? html ` <div class="max-h-48 overflow-y-auto bg-muted/50 p-2" ${ref(this.consoleLogsRef)}></div> ` : ""}
|
|
181
|
+
</div>
|
|
182
|
+
`
|
|
183
|
+
: ""}
|
|
184
|
+
</div>
|
|
185
|
+
|
|
186
|
+
<!-- Code view - always in DOM, just hidden when not active -->
|
|
187
|
+
<div class="absolute inset-0 overflow-auto bg-background" style="display: ${this.viewMode === "code" ? "block" : "none"}">
|
|
188
|
+
<pre class="m-0 p-4 text-xs"><code class="hljs language-html">${unsafeHTML(hljs.highlight(this._content, { language: "html" }).value)}</code></pre>
|
|
189
|
+
</div>
|
|
190
|
+
</div>
|
|
191
|
+
</div>
|
|
192
|
+
`;
|
|
193
|
+
}
|
|
194
|
+
};
|
|
195
|
+
__decorate([
|
|
196
|
+
property()
|
|
197
|
+
], HtmlArtifact.prototype, "filename", void 0);
|
|
198
|
+
__decorate([
|
|
199
|
+
property({ attribute: false })
|
|
200
|
+
], HtmlArtifact.prototype, "displayTitle", void 0);
|
|
201
|
+
__decorate([
|
|
202
|
+
property({ attribute: false })
|
|
203
|
+
], HtmlArtifact.prototype, "attachments", void 0);
|
|
204
|
+
__decorate([
|
|
205
|
+
property({ attribute: false })
|
|
206
|
+
], HtmlArtifact.prototype, "sandboxUrlProvider", void 0);
|
|
207
|
+
__decorate([
|
|
208
|
+
state()
|
|
209
|
+
], HtmlArtifact.prototype, "viewMode", void 0);
|
|
210
|
+
__decorate([
|
|
211
|
+
state()
|
|
212
|
+
], HtmlArtifact.prototype, "consoleOpen", void 0);
|
|
213
|
+
HtmlArtifact = __decorate([
|
|
214
|
+
customElement("html-artifact")
|
|
215
|
+
], HtmlArtifact);
|
|
216
|
+
export { HtmlArtifact };
|
|
217
|
+
//# sourceMappingURL=HtmlArtifact.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HtmlArtifact.js","sourceRoot":"","sources":["../../../src/tools/artifacts/HtmlArtifact.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AACvF,OAAO,IAAI,MAAM,cAAc,CAAC;AAChC,OAAO,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,SAAS,EAAY,GAAG,EAAE,MAAM,uBAAuB,CAAC;AACjE,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAG3D,OAAO,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAC3C,OAAO,qCAAqC,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAGhD,IAAM,YAAY,GAAlB,MAAM,YAAa,SAAQ,eAAe;IAA1C;;QACe,aAAQ,GAAG,EAAE,CAAC;QACM,iBAAY,GAAG,EAAE,CAAC;QAC3B,gBAAW,GAAiB,EAAE,CAAC;QAGvD,aAAQ,GAAG,EAAE,CAAC;QACd,SAAI,GAAmD,EAAE,CAAC;QAElE,wBAAwB;QAChB,qBAAgB,GAAuB,SAAS,EAAE,CAAC;QACnD,mBAAc,GAAwB,SAAS,EAAE,CAAC;QAClD,qBAAgB,GAA2B,SAAS,EAAE,CAAC;QAK9C,aAAQ,GAAuB,SAAS,CAAC;QACzC,gBAAW,GAAG,KAAK,CAAC;IA6LtC,CAAC;IA3LQ,WAAW,CAAC,IAAwB;QAC3C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACtB,CAAC;IAEM,gBAAgB;QACtB,MAAM,MAAM,GAAG,IAAI,iBAAiB,EAAE,CAAC;QACvC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC5B,MAAM,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC,CAAQ,EAAE,EAAE;YACnD,IAAI,CAAC,WAAW,CAAE,CAAiB,CAAC,MAAM,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,MAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;QACpC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;QAChC,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC;QACrC,UAAU,CAAC,QAAQ,GAAG,KAAK,CAAC;QAE5B,OAAO,IAAI,CAAA;;MAEP,MAAM;MACN,UAAU;MACV,cAAc,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC;;GAE3H,CAAC;IACH,CAAC;IAED,IAAa,OAAO,CAAC,KAAa;QACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,QAAQ,KAAK,KAAK,EAAE,CAAC;YACxB,kCAAkC;YAClC,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACf,IAAI,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;gBAC/B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,EAAE,CAAC;YAC1C,CAAC;YACD,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,0CAA0C;YAC1C,IAAI,IAAI,CAAC,gBAAgB,CAAC,KAAK,IAAI,KAAK,EAAE,CAAC;gBAC1C,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAC5B,CAAC;QACF,CAAC;IACF,CAAC;IAEO,cAAc,CAAC,IAAY;QAClC,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC;QAC5C,IAAI,CAAC,OAAO;YAAE,OAAO;QAErB,sEAAsE;QACtE,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC7B,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC;QACtD,CAAC;QAED,+CAA+C;QAC/C,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAC5D,CAAC;QAED,MAAM,SAAS,GAAG,YAAY,IAAI,CAAC,QAAQ,EAAE,CAAC;QAE9C,0CAA0C;QAC1C,IAAI,CAAC,cAAc,GAAG,CAAC,CAAe,EAAE,EAAE;YACzC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,KAAK,SAAS;gBAAE,OAAO;YAE3C,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;gBAC/B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;oBACd,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK;oBACjD,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI;iBACjB,CAAC,CAAC;gBACH,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC5B,CAAC;QACF,CAAC,CAAC;QACF,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAExD,sDAAsD;QACtD,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IACxD,CAAC;IAED,IAAa,OAAO;QACnB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACtB,CAAC;IAEQ,oBAAoB;QAC5B,KAAK,CAAC,oBAAoB,EAAE,CAAC;QAC7B,4DAA4D;QAC5D,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;YAC3D,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;QACjC,CAAC;IACF,CAAC;IAEQ,YAAY;QACpB,0BAA0B;QAC1B,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;YAClD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACpC,CAAC;IACF,CAAC;IAEQ,OAAO,CAAC,iBAAyD;QACzE,KAAK,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;QACjC,6EAA6E;QAC7E,gDAAgD;QAChD,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,gBAAgB,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC5E,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACpC,CAAC;IACF,CAAC;IAEO,mBAAmB;QAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC;QAC3C,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,MAAM,CAAC;QACtE,MAAM,IAAI,GACT,UAAU,GAAG,CAAC;YACb,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,mCAAmC,UAAU,gBAAgB;YACjF,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;QAC/C,MAAM,CAAC,SAAS,GAAG,SAAS,IAAI,gBAAgB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC;IACvF,CAAC;IAEO,aAAa;QACpB,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,mCAAmC;QACnC,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,qBAAqB,CAAC,GAAG,EAAE;gBAC1B,IAAI,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;oBAC/B,8BAA8B;oBAC9B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,EAAE,CAAC;oBACzC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;wBACzB,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;wBAC5C,KAAK,CAAC,SAAS,GAAG,qBAAqB,GAAG,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,uBAAuB,EAAE,CAAC;wBAC7G,KAAK,CAAC,WAAW,GAAG,IAAI,GAAG,CAAC,IAAI,KAAK,GAAG,CAAC,IAAI,EAAE,CAAC;wBAChD,IAAI,CAAC,cAAc,CAAC,KAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;oBAC/C,CAAC,CAAC,CAAC;gBACJ,CAAC;YACF,CAAC,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;IAEM,OAAO;QACb,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,IAAI,CAAC,wBAAwB,CAAC,CAAC,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACvG,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjE,CAAC;IAEQ,MAAM;QACd,OAAO,IAAI,CAAA;;;;mEAIsD,IAAI,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;uCACzE,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC;QAE1D,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;YACnB,CAAC,CAAC,IAAI,CAAA;;;oBAGM,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE;;aAEjC,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC;;;eAGxB,IAAI,CAAC,SAAS,CAAC;cAEjB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC;gBACrD,CAAC,CAAC,IAAI,CAAA,kCAAkC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,MAAM,gBAAgB;gBAC1G,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GACxB;;mBAEO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG;;YAEnC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAA,0DAA0D,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE;;SAE3H;YACD,CAAC,CAAC,EACJ;;;;iFAI2E,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;sEACtD,UAAU,CACzE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC,KAAK,CACzD;;;;GAIJ,CAAC;IACH,CAAC;CACD,CAAA;AA9MqB;IAApB,QAAQ,EAAE;8CAAwB;AACM;IAAxC,QAAQ,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;kDAA4B;AAC3B;IAA/B,QAAQ,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;iDAAgC;AAC/B;IAA/B,QAAQ,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;wDAAmC;AAajD;IAAhB,KAAK,EAAE;8CAAkD;AACzC;IAAhB,KAAK,EAAE;iDAA6B;AAlBzB,YAAY;IADxB,aAAa,CAAC,eAAe,CAAC;GAClB,YAAY,CA+MxB"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import "@mariozechner/mini-lit/dist/MarkdownBlock.js";
|
|
2
|
+
import { ArtifactElement } from "./ArtifactElement.js";
|
|
3
|
+
export declare class MarkdownArtifact extends ArtifactElement {
|
|
4
|
+
filename: string;
|
|
5
|
+
displayTitle: string;
|
|
6
|
+
private _content;
|
|
7
|
+
get content(): string;
|
|
8
|
+
set content(value: string);
|
|
9
|
+
private viewMode;
|
|
10
|
+
protected createRenderRoot(): HTMLElement | DocumentFragment;
|
|
11
|
+
private setViewMode;
|
|
12
|
+
getHeaderButtons(): import("lit-html").TemplateResult<1>;
|
|
13
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
14
|
+
}
|
|
15
|
+
declare global {
|
|
16
|
+
interface HTMLElementTagNameMap {
|
|
17
|
+
"markdown-artifact": MarkdownArtifact;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=MarkdownArtifact.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarkdownArtifact.d.ts","sourceRoot":"","sources":["../../../src/tools/artifacts/MarkdownArtifact.ts"],"names":[],"mappings":"AAMA,OAAO,8CAA8C,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEvD,qBACa,gBAAiB,SAAQ,eAAe;IAC/B,QAAQ,SAAM;IACM,YAAY,SAAM;IAE3D,OAAO,CAAC,QAAQ,CAAM;IACtB,IAAa,OAAO,IAAI,MAAM,CAE7B;IACD,IAAa,OAAO,CAAC,KAAK,EAAE,MAAM,EAGjC;IAEQ,OAAO,CAAC,QAAQ,CAAiC;cAEvC,gBAAgB,IAAI,WAAW,GAAG,gBAAgB;IAIrE,OAAO,CAAC,WAAW;IAIZ,gBAAgB;IA0Bd,MAAM;CAef;AAED,OAAO,CAAC,MAAM,CAAC;IACd,UAAU,qBAAqB;QAC9B,mBAAmB,EAAE,gBAAgB,CAAC;KACtC;CACD"}
|
|
@@ -0,0 +1,84 @@
|
|
|
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 { CopyButton, DownloadButton, PreviewCodeToggle } from "@mariozechner/mini-lit";
|
|
8
|
+
import hljs from "highlight.js";
|
|
9
|
+
import { html } from "lit";
|
|
10
|
+
import { customElement, property, state } from "lit/decorators.js";
|
|
11
|
+
import { unsafeHTML } from "lit/directives/unsafe-html.js";
|
|
12
|
+
import { i18n } from "../../utils/i18n.js";
|
|
13
|
+
import "@mariozechner/mini-lit/dist/MarkdownBlock.js";
|
|
14
|
+
import { ArtifactElement } from "./ArtifactElement.js";
|
|
15
|
+
let MarkdownArtifact = class MarkdownArtifact extends ArtifactElement {
|
|
16
|
+
constructor() {
|
|
17
|
+
super(...arguments);
|
|
18
|
+
this.filename = "";
|
|
19
|
+
this.displayTitle = "";
|
|
20
|
+
this._content = "";
|
|
21
|
+
this.viewMode = "preview";
|
|
22
|
+
}
|
|
23
|
+
get content() {
|
|
24
|
+
return this._content;
|
|
25
|
+
}
|
|
26
|
+
set content(value) {
|
|
27
|
+
this._content = value;
|
|
28
|
+
this.requestUpdate();
|
|
29
|
+
}
|
|
30
|
+
createRenderRoot() {
|
|
31
|
+
return this; // light DOM
|
|
32
|
+
}
|
|
33
|
+
setViewMode(mode) {
|
|
34
|
+
this.viewMode = mode;
|
|
35
|
+
}
|
|
36
|
+
getHeaderButtons() {
|
|
37
|
+
const toggle = new PreviewCodeToggle();
|
|
38
|
+
toggle.mode = this.viewMode;
|
|
39
|
+
toggle.addEventListener("mode-change", (e) => {
|
|
40
|
+
this.setViewMode(e.detail);
|
|
41
|
+
});
|
|
42
|
+
const copyButton = new CopyButton();
|
|
43
|
+
copyButton.text = this._content;
|
|
44
|
+
copyButton.title = i18n("Copy Markdown");
|
|
45
|
+
copyButton.showText = false;
|
|
46
|
+
return html `
|
|
47
|
+
<div class="flex items-center gap-2">
|
|
48
|
+
${toggle}
|
|
49
|
+
${copyButton}
|
|
50
|
+
${DownloadButton({
|
|
51
|
+
content: this._content,
|
|
52
|
+
filename: this.filename,
|
|
53
|
+
mimeType: "text/markdown",
|
|
54
|
+
title: i18n("Download Markdown"),
|
|
55
|
+
})}
|
|
56
|
+
</div>
|
|
57
|
+
`;
|
|
58
|
+
}
|
|
59
|
+
render() {
|
|
60
|
+
return html `
|
|
61
|
+
<div class="h-full flex flex-col">
|
|
62
|
+
<div class="flex-1 overflow-auto">
|
|
63
|
+
${this.viewMode === "preview"
|
|
64
|
+
? html `<div class="p-4"><markdown-block .content=${this.content}></markdown-block></div>`
|
|
65
|
+
: html `<pre class="m-0 p-4 text-xs whitespace-pre-wrap break-words"><code class="hljs language-markdown">${unsafeHTML(hljs.highlight(this.content, { language: "markdown", ignoreIllegals: true }).value)}</code></pre>`}
|
|
66
|
+
</div>
|
|
67
|
+
</div>
|
|
68
|
+
`;
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
__decorate([
|
|
72
|
+
property()
|
|
73
|
+
], MarkdownArtifact.prototype, "filename", void 0);
|
|
74
|
+
__decorate([
|
|
75
|
+
property({ attribute: false })
|
|
76
|
+
], MarkdownArtifact.prototype, "displayTitle", void 0);
|
|
77
|
+
__decorate([
|
|
78
|
+
state()
|
|
79
|
+
], MarkdownArtifact.prototype, "viewMode", void 0);
|
|
80
|
+
MarkdownArtifact = __decorate([
|
|
81
|
+
customElement("markdown-artifact")
|
|
82
|
+
], MarkdownArtifact);
|
|
83
|
+
export { MarkdownArtifact };
|
|
84
|
+
//# sourceMappingURL=MarkdownArtifact.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MarkdownArtifact.js","sourceRoot":"","sources":["../../../src/tools/artifacts/MarkdownArtifact.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AACvF,OAAO,IAAI,MAAM,cAAc,CAAC;AAChC,OAAO,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAC3C,OAAO,8CAA8C,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAGhD,IAAM,gBAAgB,GAAtB,MAAM,gBAAiB,SAAQ,eAAe;IAA9C;;QACe,aAAQ,GAAG,EAAE,CAAC;QACM,iBAAY,GAAG,EAAE,CAAC;QAEnD,aAAQ,GAAG,EAAE,CAAC;QASL,aAAQ,GAAuB,SAAS,CAAC;IAmD3D,CAAC;IA3DA,IAAa,OAAO;QACnB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACtB,CAAC;IACD,IAAa,OAAO,CAAC,KAAa;QACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,aAAa,EAAE,CAAC;IACtB,CAAC;IAIkB,gBAAgB;QAClC,OAAO,IAAI,CAAC,CAAC,YAAY;IAC1B,CAAC;IAEO,WAAW,CAAC,IAAwB;QAC3C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACtB,CAAC;IAEM,gBAAgB;QACtB,MAAM,MAAM,GAAG,IAAI,iBAAiB,EAAE,CAAC;QACvC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC5B,MAAM,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC,CAAQ,EAAE,EAAE;YACnD,IAAI,CAAC,WAAW,CAAE,CAAiB,CAAC,MAAM,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,MAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;QACpC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;QAChC,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC;QACzC,UAAU,CAAC,QAAQ,GAAG,KAAK,CAAC;QAE5B,OAAO,IAAI,CAAA;;MAEP,MAAM;MACN,UAAU;MACV,cAAc,CAAC;YAChB,OAAO,EAAE,IAAI,CAAC,QAAQ;YACtB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,QAAQ,EAAE,eAAe;YACzB,KAAK,EAAE,IAAI,CAAC,mBAAmB,CAAC;SAChC,CAAC;;GAEH,CAAC;IACH,CAAC;IAEQ,MAAM;QACd,OAAO,IAAI,CAAA;;;OAIP,IAAI,CAAC,QAAQ,KAAK,SAAS;YAC1B,CAAC,CAAC,IAAI,CAAA,6CAA6C,IAAI,CAAC,OAAO,0BAA0B;YACzF,CAAC,CAAC,IAAI,CAAA,qGAAqG,UAAU,CACnH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,cAAc,EAAE,IAAI,EAAE,CAAC,CAAC,KAAK,CAClF,eACJ;;;GAGF,CAAC;IACH,CAAC;CACD,CAAA;AA/DqB;IAApB,QAAQ,EAAE;kDAAwB;AACM;IAAxC,QAAQ,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;sDAA4B;AAW1C;IAAhB,KAAK,EAAE;kDAAkD;AAb9C,gBAAgB;IAD5B,aAAa,CAAC,mBAAmB,CAAC;GACtB,gBAAgB,CAgE5B"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ArtifactElement } from "./ArtifactElement.js";
|
|
2
|
+
export declare class SvgArtifact extends ArtifactElement {
|
|
3
|
+
filename: string;
|
|
4
|
+
displayTitle: string;
|
|
5
|
+
private _content;
|
|
6
|
+
get content(): string;
|
|
7
|
+
set content(value: string);
|
|
8
|
+
private viewMode;
|
|
9
|
+
protected createRenderRoot(): HTMLElement | DocumentFragment;
|
|
10
|
+
private setViewMode;
|
|
11
|
+
getHeaderButtons(): import("lit-html").TemplateResult<1>;
|
|
12
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
13
|
+
}
|
|
14
|
+
declare global {
|
|
15
|
+
interface HTMLElementTagNameMap {
|
|
16
|
+
"svg-artifact": SvgArtifact;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=SvgArtifact.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SvgArtifact.d.ts","sourceRoot":"","sources":["../../../src/tools/artifacts/SvgArtifact.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEvD,qBACa,WAAY,SAAQ,eAAe;IAC1B,QAAQ,SAAM;IACM,YAAY,SAAM;IAE3D,OAAO,CAAC,QAAQ,CAAM;IACtB,IAAa,OAAO,IAAI,MAAM,CAE7B;IACD,IAAa,OAAO,CAAC,KAAK,EAAE,MAAM,EAGjC;IAEQ,OAAO,CAAC,QAAQ,CAAiC;cAEvC,gBAAgB,IAAI,WAAW,GAAG,gBAAgB;IAIrE,OAAO,CAAC,WAAW;IAIZ,gBAAgB;IAqBd,MAAM;CAiBf;AAED,OAAO,CAAC,MAAM,CAAC;IACd,UAAU,qBAAqB;QAC9B,cAAc,EAAE,WAAW,CAAC;KAC5B;CACD"}
|
|
@@ -0,0 +1,80 @@
|
|
|
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 { CopyButton, DownloadButton, PreviewCodeToggle } from "@mariozechner/mini-lit";
|
|
8
|
+
import hljs from "highlight.js";
|
|
9
|
+
import { html } from "lit";
|
|
10
|
+
import { customElement, property, state } from "lit/decorators.js";
|
|
11
|
+
import { unsafeHTML } from "lit/directives/unsafe-html.js";
|
|
12
|
+
import { i18n } from "../../utils/i18n.js";
|
|
13
|
+
import { ArtifactElement } from "./ArtifactElement.js";
|
|
14
|
+
let SvgArtifact = class SvgArtifact extends ArtifactElement {
|
|
15
|
+
constructor() {
|
|
16
|
+
super(...arguments);
|
|
17
|
+
this.filename = "";
|
|
18
|
+
this.displayTitle = "";
|
|
19
|
+
this._content = "";
|
|
20
|
+
this.viewMode = "preview";
|
|
21
|
+
}
|
|
22
|
+
get content() {
|
|
23
|
+
return this._content;
|
|
24
|
+
}
|
|
25
|
+
set content(value) {
|
|
26
|
+
this._content = value;
|
|
27
|
+
this.requestUpdate();
|
|
28
|
+
}
|
|
29
|
+
createRenderRoot() {
|
|
30
|
+
return this; // light DOM
|
|
31
|
+
}
|
|
32
|
+
setViewMode(mode) {
|
|
33
|
+
this.viewMode = mode;
|
|
34
|
+
}
|
|
35
|
+
getHeaderButtons() {
|
|
36
|
+
const toggle = new PreviewCodeToggle();
|
|
37
|
+
toggle.mode = this.viewMode;
|
|
38
|
+
toggle.addEventListener("mode-change", (e) => {
|
|
39
|
+
this.setViewMode(e.detail);
|
|
40
|
+
});
|
|
41
|
+
const copyButton = new CopyButton();
|
|
42
|
+
copyButton.text = this._content;
|
|
43
|
+
copyButton.title = i18n("Copy SVG");
|
|
44
|
+
copyButton.showText = false;
|
|
45
|
+
return html `
|
|
46
|
+
<div class="flex items-center gap-2">
|
|
47
|
+
${toggle}
|
|
48
|
+
${copyButton}
|
|
49
|
+
${DownloadButton({ content: this._content, filename: this.filename, mimeType: "image/svg+xml", title: i18n("Download SVG") })}
|
|
50
|
+
</div>
|
|
51
|
+
`;
|
|
52
|
+
}
|
|
53
|
+
render() {
|
|
54
|
+
return html `
|
|
55
|
+
<div class="h-full flex flex-col">
|
|
56
|
+
<div class="flex-1 overflow-auto">
|
|
57
|
+
${this.viewMode === "preview"
|
|
58
|
+
? html `<div class="h-full flex items-center justify-center">
|
|
59
|
+
${unsafeHTML(this.content.replace(/<svg(\s|>)/i, (_m, p1) => `<svg class="w-full h-full"${p1}`))}
|
|
60
|
+
</div>`
|
|
61
|
+
: html `<pre class="m-0 p-4 text-xs"><code class="hljs language-xml">${unsafeHTML(hljs.highlight(this.content, { language: "xml", ignoreIllegals: true }).value)}</code></pre>`}
|
|
62
|
+
</div>
|
|
63
|
+
</div>
|
|
64
|
+
`;
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
__decorate([
|
|
68
|
+
property()
|
|
69
|
+
], SvgArtifact.prototype, "filename", void 0);
|
|
70
|
+
__decorate([
|
|
71
|
+
property({ attribute: false })
|
|
72
|
+
], SvgArtifact.prototype, "displayTitle", void 0);
|
|
73
|
+
__decorate([
|
|
74
|
+
state()
|
|
75
|
+
], SvgArtifact.prototype, "viewMode", void 0);
|
|
76
|
+
SvgArtifact = __decorate([
|
|
77
|
+
customElement("svg-artifact")
|
|
78
|
+
], SvgArtifact);
|
|
79
|
+
export { SvgArtifact };
|
|
80
|
+
//# sourceMappingURL=SvgArtifact.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SvgArtifact.js","sourceRoot":"","sources":["../../../src/tools/artifacts/SvgArtifact.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AACvF,OAAO,IAAI,MAAM,cAAc,CAAC;AAChC,OAAO,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC3D,OAAO,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAGhD,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,eAAe;IAAzC;;QACe,aAAQ,GAAG,EAAE,CAAC;QACM,iBAAY,GAAG,EAAE,CAAC;QAEnD,aAAQ,GAAG,EAAE,CAAC;QASL,aAAQ,GAAuB,SAAS,CAAC;IAgD3D,CAAC;IAxDA,IAAa,OAAO;QACnB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACtB,CAAC;IACD,IAAa,OAAO,CAAC,KAAa;QACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,aAAa,EAAE,CAAC;IACtB,CAAC;IAIkB,gBAAgB;QAClC,OAAO,IAAI,CAAC,CAAC,YAAY;IAC1B,CAAC;IAEO,WAAW,CAAC,IAAwB;QAC3C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACtB,CAAC;IAEM,gBAAgB;QACtB,MAAM,MAAM,GAAG,IAAI,iBAAiB,EAAE,CAAC;QACvC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC5B,MAAM,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC,CAAQ,EAAE,EAAE;YACnD,IAAI,CAAC,WAAW,CAAE,CAAiB,CAAC,MAAM,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,MAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;QACpC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;QAChC,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC;QACpC,UAAU,CAAC,QAAQ,GAAG,KAAK,CAAC;QAE5B,OAAO,IAAI,CAAA;;MAEP,MAAM;MACN,UAAU;MACV,cAAc,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,eAAe,EAAE,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC;;GAE9H,CAAC;IACH,CAAC;IAEQ,MAAM;QACd,OAAO,IAAI,CAAA;;;OAIP,IAAI,CAAC,QAAQ,KAAK,SAAS;YAC1B,CAAC,CAAC,IAAI,CAAA;UACH,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,6BAA6B,EAAE,EAAE,CAAC,CAAC;cAC1F;YACP,CAAC,CAAC,IAAI,CAAA,gEAAgE,UAAU,CAC9E,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,cAAc,EAAE,IAAI,EAAE,CAAC,CAAC,KAAK,CAC7E,eACJ;;;GAGF,CAAC;IACH,CAAC;CACD,CAAA;AA5DqB;IAApB,QAAQ,EAAE;6CAAwB;AACM;IAAxC,QAAQ,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;iDAA4B;AAW1C;IAAhB,KAAK,EAAE;6CAAkD;AAb9C,WAAW;IADvB,aAAa,CAAC,cAAc,CAAC;GACjB,WAAW,CA6DvB"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ArtifactElement } from "./ArtifactElement.js";
|
|
2
|
+
export declare class TextArtifact extends ArtifactElement {
|
|
3
|
+
filename: string;
|
|
4
|
+
displayTitle: string;
|
|
5
|
+
private _content;
|
|
6
|
+
get content(): string;
|
|
7
|
+
set content(value: string);
|
|
8
|
+
protected createRenderRoot(): HTMLElement | DocumentFragment;
|
|
9
|
+
private isCode;
|
|
10
|
+
private getLanguageFromExtension;
|
|
11
|
+
private getMimeType;
|
|
12
|
+
getHeaderButtons(): import("lit-html").TemplateResult<1>;
|
|
13
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
14
|
+
}
|
|
15
|
+
declare global {
|
|
16
|
+
interface HTMLElementTagNameMap {
|
|
17
|
+
"text-artifact": TextArtifact;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=TextArtifact.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TextArtifact.d.ts","sourceRoot":"","sources":["../../../src/tools/artifacts/TextArtifact.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAiDvD,qBACa,YAAa,SAAQ,eAAe;IAC3B,QAAQ,SAAM;IACM,YAAY,SAAM;IAE3D,OAAO,CAAC,QAAQ,CAAM;IACtB,IAAa,OAAO,IAAI,MAAM,CAE7B;IACD,IAAa,OAAO,CAAC,KAAK,EAAE,MAAM,EAGjC;cAEkB,gBAAgB,IAAI,WAAW,GAAG,gBAAgB;IAIrE,OAAO,CAAC,MAAM;IAKd,OAAO,CAAC,wBAAwB;IAahC,OAAO,CAAC,WAAW;IAOZ,gBAAgB;IAmBd,MAAM;CAwBf;AAED,OAAO,CAAC,MAAM,CAAC;IACd,UAAU,qBAAqB;QAC9B,eAAe,EAAE,YAAY,CAAC;KAC9B;CACD"}
|
|
@@ -0,0 +1,147 @@
|
|
|
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 { CopyButton, DownloadButton } from "@mariozechner/mini-lit";
|
|
8
|
+
import hljs from "highlight.js";
|
|
9
|
+
import { html } from "lit";
|
|
10
|
+
import { customElement, property } from "lit/decorators.js";
|
|
11
|
+
import { unsafeHTML } from "lit/directives/unsafe-html.js";
|
|
12
|
+
import { i18n } from "../../utils/i18n.js";
|
|
13
|
+
import { ArtifactElement } from "./ArtifactElement.js";
|
|
14
|
+
// Known code file extensions for highlighting
|
|
15
|
+
const CODE_EXTENSIONS = [
|
|
16
|
+
"js",
|
|
17
|
+
"javascript",
|
|
18
|
+
"ts",
|
|
19
|
+
"typescript",
|
|
20
|
+
"jsx",
|
|
21
|
+
"tsx",
|
|
22
|
+
"py",
|
|
23
|
+
"python",
|
|
24
|
+
"java",
|
|
25
|
+
"c",
|
|
26
|
+
"cpp",
|
|
27
|
+
"cs",
|
|
28
|
+
"php",
|
|
29
|
+
"rb",
|
|
30
|
+
"ruby",
|
|
31
|
+
"go",
|
|
32
|
+
"rust",
|
|
33
|
+
"swift",
|
|
34
|
+
"kotlin",
|
|
35
|
+
"scala",
|
|
36
|
+
"dart",
|
|
37
|
+
"html",
|
|
38
|
+
"css",
|
|
39
|
+
"scss",
|
|
40
|
+
"sass",
|
|
41
|
+
"less",
|
|
42
|
+
"json",
|
|
43
|
+
"xml",
|
|
44
|
+
"yaml",
|
|
45
|
+
"yml",
|
|
46
|
+
"toml",
|
|
47
|
+
"sql",
|
|
48
|
+
"sh",
|
|
49
|
+
"bash",
|
|
50
|
+
"ps1",
|
|
51
|
+
"bat",
|
|
52
|
+
"r",
|
|
53
|
+
"matlab",
|
|
54
|
+
"julia",
|
|
55
|
+
"lua",
|
|
56
|
+
"perl",
|
|
57
|
+
"vue",
|
|
58
|
+
"svelte",
|
|
59
|
+
];
|
|
60
|
+
let TextArtifact = class TextArtifact extends ArtifactElement {
|
|
61
|
+
constructor() {
|
|
62
|
+
super(...arguments);
|
|
63
|
+
this.filename = "";
|
|
64
|
+
this.displayTitle = "";
|
|
65
|
+
this._content = "";
|
|
66
|
+
}
|
|
67
|
+
get content() {
|
|
68
|
+
return this._content;
|
|
69
|
+
}
|
|
70
|
+
set content(value) {
|
|
71
|
+
this._content = value;
|
|
72
|
+
this.requestUpdate();
|
|
73
|
+
}
|
|
74
|
+
createRenderRoot() {
|
|
75
|
+
return this; // light DOM
|
|
76
|
+
}
|
|
77
|
+
isCode() {
|
|
78
|
+
const ext = this.filename.split(".").pop()?.toLowerCase() || "";
|
|
79
|
+
return CODE_EXTENSIONS.includes(ext);
|
|
80
|
+
}
|
|
81
|
+
getLanguageFromExtension(ext) {
|
|
82
|
+
const languageMap = {
|
|
83
|
+
js: "javascript",
|
|
84
|
+
ts: "typescript",
|
|
85
|
+
py: "python",
|
|
86
|
+
rb: "ruby",
|
|
87
|
+
yml: "yaml",
|
|
88
|
+
ps1: "powershell",
|
|
89
|
+
bat: "batch",
|
|
90
|
+
};
|
|
91
|
+
return languageMap[ext] || ext;
|
|
92
|
+
}
|
|
93
|
+
getMimeType() {
|
|
94
|
+
const ext = this.filename.split(".").pop()?.toLowerCase() || "";
|
|
95
|
+
if (ext === "svg")
|
|
96
|
+
return "image/svg+xml";
|
|
97
|
+
if (ext === "md" || ext === "markdown")
|
|
98
|
+
return "text/markdown";
|
|
99
|
+
return "text/plain";
|
|
100
|
+
}
|
|
101
|
+
getHeaderButtons() {
|
|
102
|
+
const copyButton = new CopyButton();
|
|
103
|
+
copyButton.text = this.content;
|
|
104
|
+
copyButton.title = i18n("Copy");
|
|
105
|
+
copyButton.showText = false;
|
|
106
|
+
return html `
|
|
107
|
+
<div class="flex items-center gap-1">
|
|
108
|
+
${copyButton}
|
|
109
|
+
${DownloadButton({
|
|
110
|
+
content: this.content,
|
|
111
|
+
filename: this.filename,
|
|
112
|
+
mimeType: this.getMimeType(),
|
|
113
|
+
title: i18n("Download"),
|
|
114
|
+
})}
|
|
115
|
+
</div>
|
|
116
|
+
`;
|
|
117
|
+
}
|
|
118
|
+
render() {
|
|
119
|
+
const isCode = this.isCode();
|
|
120
|
+
const ext = this.filename.split(".").pop() || "";
|
|
121
|
+
return html `
|
|
122
|
+
<div class="h-full flex flex-col">
|
|
123
|
+
<div class="flex-1 overflow-auto">
|
|
124
|
+
${isCode
|
|
125
|
+
? html `
|
|
126
|
+
<pre class="m-0 p-4 text-xs"><code class="hljs language-${this.getLanguageFromExtension(ext.toLowerCase())}">${unsafeHTML(hljs.highlight(this.content, {
|
|
127
|
+
language: this.getLanguageFromExtension(ext.toLowerCase()),
|
|
128
|
+
ignoreIllegals: true,
|
|
129
|
+
}).value)}</code></pre>
|
|
130
|
+
`
|
|
131
|
+
: html ` <pre class="m-0 p-4 text-xs font-mono">${this.content}</pre> `}
|
|
132
|
+
</div>
|
|
133
|
+
</div>
|
|
134
|
+
`;
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
__decorate([
|
|
138
|
+
property()
|
|
139
|
+
], TextArtifact.prototype, "filename", void 0);
|
|
140
|
+
__decorate([
|
|
141
|
+
property({ attribute: false })
|
|
142
|
+
], TextArtifact.prototype, "displayTitle", void 0);
|
|
143
|
+
TextArtifact = __decorate([
|
|
144
|
+
customElement("text-artifact")
|
|
145
|
+
], TextArtifact);
|
|
146
|
+
export { TextArtifact };
|
|
147
|
+
//# sourceMappingURL=TextArtifact.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TextArtifact.js","sourceRoot":"","sources":["../../../src/tools/artifacts/TextArtifact.ts"],"names":[],"mappings":"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"}
|