CopilotChatMessageView
Vue 3 component for rendering a list of chat messages
Overview
CopilotChatMessageView renders a list of chat messages and, optionally, a typing cursor while the agent is running. It dispatches each message to a default child component based on its role (assistant, user, or reasoning) and exposes named slots so you can replace or wrap that rendering. A pulsing cursor is shown after the last message while isRunning is true.
Unlike the React reference component, customization in Vue is driven entirely through named slots rather than render props or a slot-prop system. The component also surfaces slots for interrupts, activity messages, tool calls, and custom message renderers registered on the CopilotKit instance.
Import
<script setup lang="ts">
import { CopilotChatMessageView } from "@copilotkit/vue/v2";
import "@copilotkit/vue/styles.css";
</script>Example
<script setup lang="ts">
import { CopilotChatMessageView } from "@copilotkit/vue/v2";
import { useAgent } from "@copilotkit/vue/v2";
const { agent } = useAgent();
</script>
<template>
<copilot-chat-message-view
:messages="agent?.messages ?? []"
:is-running="agent?.isRunning ?? false"
/>
</template>Props
Prop
Type
Prop
Type
Attributes that are not declared props (such as class, style, or
data-*) are forwarded to the component's root <div> via v-bind="$attrs".
Slots
Each slot below is named. Use a <template #slot-name="slotProps"> block to override or wrap the default rendering. Where a slot has a default, omitting it falls back to the built-in child component.
Prop
Type
Prop
Type
Prop
Type
Prop
Type
Prop
Type
Prop
Type
Prop
Type
Prop
Type
Prop
Type
Usage
Basic message list
<script setup lang="ts">
import { CopilotChatMessageView } from "@copilotkit/vue/v2";
import { useAgent } from "@copilotkit/vue/v2";
const { agent } = useAgent();
</script>
<template>
<copilot-chat-message-view
:messages="agent?.messages ?? []"
:is-running="agent?.isRunning ?? false"
/>
</template>Customizing assistant and user messages
<script setup lang="ts">
import { CopilotChatMessageView } from "@copilotkit/vue/v2";
import { useAgent } from "@copilotkit/vue/v2";
const { agent } = useAgent();
</script>
<template>
<copilot-chat-message-view
:messages="agent?.messages ?? []"
:is-running="agent?.isRunning ?? false"
>
<template #assistant-message="{ message }">
<div class="bg-blue-50 p-4 rounded-xl">{{ message.content }}</div>
</template>
<template #user-message="{ message }">
<div class="bg-gray-100 p-4 rounded-xl">{{ message.content }}</div>
</template>
</copilot-chat-message-view>
</template>Custom typing indicator
<script setup lang="ts">
import { CopilotChatMessageView } from "@copilotkit/vue/v2";
import { useAgent } from "@copilotkit/vue/v2";
const { agent } = useAgent();
</script>
<template>
<copilot-chat-message-view
:messages="agent?.messages ?? []"
:is-running="agent?.isRunning ?? false"
>
<template #cursor>
<div class="animate-pulse text-gray-400">Thinking...</div>
</template>
</copilot-chat-message-view>
</template>Rendering a specific tool call
<script setup lang="ts">
import { CopilotChatMessageView } from "@copilotkit/vue/v2";
import { useAgent } from "@copilotkit/vue/v2";
const { agent } = useAgent();
</script>
<template>
<copilot-chat-message-view
:messages="agent?.messages ?? []"
:is-running="agent?.isRunning ?? false"
>
<template #tool-call-get_weather="{ args, status, result }">
<div class="rounded-lg border p-3">
<p>Status: {{ status }}</p>
<p v-if="result">Result: {{ result }}</p>
</div>
</template>
</copilot-chat-message-view>
</template>Behavior
- Message rendering: Each message is dispatched to the matching default child component based on its
role(assistant, user, reasoning, or activity), unless the corresponding named slot is provided. - Deduplication: Messages sharing an
idare deduplicated; assistant fragments with the same id are merged (content and tool calls combined). In development, a console warning is logged when duplicates are dropped. - Cursor display: The
cursorslot is rendered only whenisRunningistrueand the last message is not a reasoning message. It appears after the last message. - Slot forwarding: Slots passed to
CopilotChatMessageView(includingtool-callandtool-call-<name>) are forwarded to the default assistant and user message children, so tool rendering works without re-implementing those components. - Custom and activity renderers: When
message-before,message-after, oractivity-messageslots are omitted, the component falls back to renderers registered on the CopilotKit instance, scoped to the activeagentIdwhen applicable.
Related
CopilotChatAssistantMessage- Default assistant message child componentCopilotChatUserMessage- Default user message child componentCopilotChatView- Higher-level chat view that composes this componentuseAgent- Composable for accessing the agent'smessagesandisRunningstate