mirror of
https://github.com/getcompanion-ai/co-mono.git
synced 2026-04-16 00:03:00 +00:00
- Add ArtifactMessage type as core part of AppMessage union (not CustomMessages) - ArtifactsRuntimeProvider appends artifact messages on create/update/delete - MessageList filters out artifact messages (UI display only) - artifacts.ts reconstructFromMessages handles artifact messages - Export ARTIFACTS_RUNTIME_PROVIDER_DESCRIPTION from main index - Fix artifact creation bug: pass filename as title instead of mimeType Changes: - web-ui/src/components/Messages.ts: Add ArtifactMessage to BaseMessage union - web-ui/src/components/MessageList.ts: Skip artifact messages in render - web-ui/src/components/sandbox/ArtifactsRuntimeProvider.ts: Append messages, fix title parameter - web-ui/src/ChatPanel.ts: Pass agent.appendMessage callback - web-ui/src/tools/artifacts/artifacts.ts: Handle artifact messages in reconstructFromMessages - web-ui/src/index.ts: Export ARTIFACTS_RUNTIME_PROVIDER_DESCRIPTION - web-ui/example/src/custom-messages.ts: Update message transformer to filter artifacts
112 lines
3.5 KiB
TypeScript
112 lines
3.5 KiB
TypeScript
import { Alert } from "@mariozechner/mini-lit";
|
|
import type { Message } from "@mariozechner/pi-ai";
|
|
import { html } from "lit";
|
|
import { registerMessageRenderer } from "@mariozechner/pi-web-ui";
|
|
import type { AppMessage, MessageRenderer } from "@mariozechner/pi-web-ui";
|
|
|
|
// ============================================================================
|
|
// 1. EXTEND AppMessage TYPE VIA DECLARATION MERGING
|
|
// ============================================================================
|
|
|
|
// Define custom message types
|
|
export interface SystemNotificationMessage {
|
|
role: "system-notification";
|
|
message: string;
|
|
variant: "default" | "destructive";
|
|
timestamp: string;
|
|
}
|
|
|
|
// Extend CustomMessages interface via declaration merging
|
|
declare module "@mariozechner/pi-web-ui" {
|
|
interface CustomMessages {
|
|
"system-notification": SystemNotificationMessage;
|
|
}
|
|
}
|
|
|
|
// ============================================================================
|
|
// 2. CREATE CUSTOM RENDERER (TYPED TO SystemNotificationMessage)
|
|
// ============================================================================
|
|
|
|
const systemNotificationRenderer: MessageRenderer<SystemNotificationMessage> = {
|
|
render: (notification) => {
|
|
// notification is fully typed as SystemNotificationMessage!
|
|
return html`
|
|
<div class="px-4">
|
|
${Alert({
|
|
variant: notification.variant,
|
|
children: html`
|
|
<div class="flex flex-col gap-1">
|
|
<div>${notification.message}</div>
|
|
<div class="text-xs opacity-70">${new Date(notification.timestamp).toLocaleTimeString()}</div>
|
|
</div>
|
|
`,
|
|
})}
|
|
</div>
|
|
`;
|
|
},
|
|
};
|
|
|
|
// ============================================================================
|
|
// 3. REGISTER RENDERER
|
|
// ============================================================================
|
|
|
|
export function registerCustomMessageRenderers() {
|
|
registerMessageRenderer("system-notification", systemNotificationRenderer);
|
|
}
|
|
|
|
// ============================================================================
|
|
// 4. HELPER TO CREATE CUSTOM MESSAGES
|
|
// ============================================================================
|
|
|
|
export function createSystemNotification(
|
|
message: string,
|
|
variant: "default" | "destructive" = "default",
|
|
): SystemNotificationMessage {
|
|
return {
|
|
role: "system-notification",
|
|
message,
|
|
variant,
|
|
timestamp: new Date().toISOString(),
|
|
};
|
|
}
|
|
|
|
// ============================================================================
|
|
// 5. CUSTOM MESSAGE TRANSFORMER
|
|
// ============================================================================
|
|
|
|
// Transform custom messages to user messages with <system> tags so LLM can see them
|
|
export function customMessageTransformer(messages: AppMessage[]): Message[] {
|
|
return messages
|
|
.filter((m) => {
|
|
// Filter out artifact messages - they're for session reconstruction only
|
|
if (m.role === "artifact") {
|
|
return false;
|
|
}
|
|
|
|
// Keep LLM-compatible messages + custom messages
|
|
return (
|
|
m.role === "user" ||
|
|
m.role === "assistant" ||
|
|
m.role === "toolResult" ||
|
|
m.role === "system-notification"
|
|
);
|
|
})
|
|
.map((m) => {
|
|
// Transform system notifications to user messages
|
|
if (m.role === "system-notification") {
|
|
const notification = m as SystemNotificationMessage;
|
|
return {
|
|
role: "user",
|
|
content: `<system>${notification.message}</system>`,
|
|
} as Message;
|
|
}
|
|
|
|
// Strip attachments from user messages
|
|
if (m.role === "user") {
|
|
const { attachments, ...rest } = m as any;
|
|
return rest as Message;
|
|
}
|
|
|
|
return m as Message;
|
|
});
|
|
}
|