showcase/shell-docs/src/content/reference/components/CopilotPopup.mdx
CopilotPopup renders a floating chat popup with a toggle button. It wraps CopilotChat and provides popup-specific layout, sizing, and open/close behavior. The popup includes a header with a title and close button, and can be dismissed by clicking outside.
See CopilotSidebar for a sidebar variant of this component.
import { CopilotPopup } from "@copilotkit/react-core/v2";
import "@copilotkit/react-core/v2/styles.css";
CopilotPopup accepts all props from CopilotChatProps except chatView, which is set internally to CopilotPopupView. This includes:
<PropertyReference name="inputProps" type="Partial<Omit<CopilotChatInputProps, 'children'>>"
Additional props forwarded to the inner CopilotChatInput component.
</PropertyReference>
<PropertyReference name="welcomeScreen" type="SlotValue<React.FC<WelcomeScreenProps>> | boolean"
Controls the welcome screen shown when no messages exist. </PropertyReference>
All CopilotChatView slot props (messageView, input, scrollView, inputContainer, feather, disclaimer, suggestionView) are also accepted and forwarded through.
All slot props follow the same override pattern used across CopilotKit v2 components. Each slot accepts one of three value types:
| Value | Behavior |
|---|---|
| Component | Replaces the default component entirely. Receives the same props the default would. |
className string | Merged into the default component's class list via twMerge. |
| Partial props object | Spread into the default component as additional or overriding props. |
function App() {
return (
<CopilotPopup
agentId="my-agent"
labels={{ modalHeaderTitle: "Assistant" }}
/>
);
}
function App() {
return (
<CopilotPopup
agentId="my-agent"
defaultOpen={true}
width={450}
height="80vh"
clickOutsideToClose={false}
/>
);
}
function App() {
return <CopilotPopup agentId="my-agent" header="bg-blue-600 text-white" />;
}
CopilotChatToggleButton internally.defaultOpen prop sets the initial state; after that, state changes come from user interaction (toggle button, close button, clicking outside).clickOutsideToClose is true (the default), clicking anywhere outside the popup panel closes it.CopilotPopupView internally, which provides a popup-specific welcome screen layout with the welcome message centered vertically and suggestions just above the input.CopilotChat logic.CopilotChat -- the base chat component used internallyCopilotSidebar -- sidebar variantCopilotChatView -- the layout component used internally