# Response
URL: /components/response
---
title: Response
description: A component that renders a Markdown response from a large language model.
path: elements/components/response
---
The `Response` component renders a Markdown response from a large language model. It uses [Streamdown](https://streamdown.ai/) under the hood to render the markdown.
## Installation
**Important:** After adding the component, you'll need to add the following to your `globals.css` file:
```css
@source "../node_modules/streamdown/dist/index.js";
```
This is **required** for the Response component to work properly. Without this import, the Streamdown styles will not be applied to your project. See [Streamdown's documentation](https://streamdown.ai/) for more details.
## Usage
```tsx
import { Response } from "@/components/ai-elements/response";
```
```tsx
**Hi there.** I am an AI model designed to help you.
```
## Usage with AI SDK
Populate a markdown response with messages from [`useChat`](/docs/reference/ai-sdk-ui/use-chat).
Add the following component to your frontend:
```tsx title="app/page.tsx"
"use client";
import { Conversation, ConversationContent, ConversationScrollButton } from "@/components/ai-elements/conversation";
import { Message, MessageContent } from "@/components/ai-elements/message";
import { useChat } from "@ai-sdk/react";
import { Response } from "@/components/ai-elements/response";
const ResponseDemo = () => {
const { messages } = useChat();
return (
{messages.map((message) => (
{message.parts.map((part, i) => {
switch (part.type) {
case "text": // we don't use any reasoning or tool calls in this example
return {part.text};
default:
return null;
}
})}
))}
);
};
export default ResponseDemo;
```
## Features
- Renders markdown content with support for paragraphs, links, and code blocks
- Supports GFM features like tables, task lists, and strikethrough text via remark-gfm
- Supports rendering Math Equations via rehype-katex
- **Smart streaming support** - automatically completes incomplete formatting during real-time text streaming
- Code blocks are rendered with syntax highlighting for various programming languages
- Code blocks include a button to easily copy code to clipboard
- Adapts to different screen sizes while maintaining readability
- Seamlessly integrates with both light and dark themes
- Customizable appearance through className props and Tailwind CSS utilities
- Built with accessibility in mind for all users
## Props
### ``
',
},
}}
/>