examples/v2/docs/reference/copilot-popup.mdx
CopilotPopup is a React component that provides a floating popup chat interface. It wraps CopilotChat with additional popup-specific behavior including a toggle button, fade/scale animation, and optional click-outside-to-close functionality.
The CopilotPopup component:
CopilotPopup extends CopilotChat with additional slots:
graph LR
CP[CopilotPopup] --> header
CP --> toggleButton
| Slot | Description |
|---|---|
header | Header bar with title and close button |
toggleButton | Floating button to open/close the popup |
CopilotPopup also inherits all slots from CopilotChat: messageView, scrollView, input, suggestionView, and welcomeScreen.
See Slot Customization for details on how to customize these slots.
import { CopilotPopup, CopilotKitProvider } from "@copilotkit/react-core";
function App() {
return (
<CopilotKitProvider runtimeUrl="/api/copilotkit">
<CopilotPopup />
</CopilotKitProvider>
);
}
These props are unique to CopilotPopup:
| Prop | Type | Default | Description |
|---|---|---|---|
defaultOpen | boolean | true | Whether the popup is open initially |
width | number | string | 420 | Popup width in pixels or CSS unit |
height | number | string | 560 | Popup height in pixels or CSS unit |
clickOutsideToClose | boolean | false | Close the popup when clicking outside |
header | SlotValue | - | Custom header component with title and close button |
toggleButton | SlotValue | - | Custom toggle button to open/close the popup |
CopilotPopup inherits all props from CopilotChat, including:
agentId - The agent to connect tothreadId - The conversation thread IDlabels - Customize text labelsautoScroll - Auto-scroll behaviorclassName - CSS class for the root containerSee CopilotChat Props for the complete list.
The popup includes a header with a title and close button. Customize it through the header prop:
<CopilotPopup
header={{
titleContent: "My Assistant",
closeButton: "hidden",
}}
/>
| Sub-Slot | Description |
|---|---|
titleContent | The title text or component |
closeButton | The close button (can be hidden) |
Replace the entire header with your own component:
function CustomHeader() {
return (
<div className="flex items-center justify-between p-4 border-b">
<div className="flex items-center gap-2">
<BotIcon className="w-5 h-5" />
<span className="font-semibold">My AI Assistant</span>
</div>
<button onClick={() => /* close popup */}>
<XIcon className="w-5 h-5" />
</button>
</div>
);
}
<CopilotPopup header={CustomHeader} />
The popup includes a floating toggle button to open and close it. Customize it through the toggleButton prop:
<CopilotPopup
toggleButton={{
className: "bg-purple-500 hover:bg-purple-600",
openIcon: "text-white",
closeIcon: "text-white",
}}
/>
| Sub-Slot | Description |
|---|---|
openIcon | Icon shown when popup is closed (click to open) |
closeIcon | Icon shown when popup is open (click to close) |
Replace the toggle button entirely:
function CustomToggleButton() {
return (
<button className="fixed bottom-4 right-4 p-3 bg-blue-500 rounded-full">
<ChatIcon className="w-6 h-6 text-white" />
</button>
);
}
<CopilotPopup toggleButton={CustomToggleButton} />;
CopilotPopup uses the same slot system as CopilotChat. Each slot accepts four types of values:
<CopilotPopup width={500} height={700} />
// Or with CSS units
<CopilotPopup width="30vw" height="80vh" />
<CopilotPopup clickOutsideToClose={true} />
<CopilotPopup
header={{
className: "bg-gradient-to-r from-blue-500 to-purple-500 text-white",
titleContent: "AI Assistant",
}}
/>
<CopilotPopup
messageView={{
assistantMessage: {
onThumbsUp: (msg) => console.log("Liked:", msg.id),
onThumbsDown: (msg) => console.log("Disliked:", msg.id),
},
}}
input={{
className: "border-2 border-gray-200",
sendButton: "bg-blue-500 hover:bg-blue-600",
}}
/>