Expandable Chat

ExpandableChat

The ExpandableChat expandable-chat.tsx component gives an easily installable component for quickly creating a chat support ui feature.

There's an example repository here (opens in a new tab) that gives you a ready-to-use chatbot with Vercel AI's SDK.

Check it out in the bottom right corner of your screen!

Installation

npx shadcn-chat-cli@latest add expandable-chat

Example usage

Create a chat-support.tsx file:

chat-support.tsx
import { Send } from "lucide-react";
import {
  ChatBubble,
  ChatBubbleAvatar,
  ChatBubbleMessage,
} from "@/components/ui/chat/chat-bubble";
import { ChatInput } from "@/components/ui/chat/chat-input";
import {
  ExpandableChat,
  ExpandableChatHeader,
  ExpandableChatBody,
  ExpandableChatFooter,
} from "@/components/ui/chat/expandable-chat";
import { ChatMessageList } from "@/components/ui/chat/chat-message-list";
 
export default function ChatSupport() {
  return (
    <ExpandableChat size="lg" position="bottom-right">
      <ExpandableChatHeader className="flex-col text-center justify-center">
        <h1 className="text-xl font-semibold">Chat with our AI ✨</h1>
        <p>Ask any question for our AI to answer</p>
        <div className="flex gap-2 items-center pt-2">
          <Button variant="secondary">New Chat</Button>
          <Button variant="secondary">See FAQ</Button>
        </div>
      </ExpandableChatHeader>
      <ExpandableChatBody>
        <ChatMessageList>
          <ChatBubble>
            <ChatBubbleAvatar />
            <ChatBubbleMessage>{message.content}</ChatBubbleMessage>
          </ChatBubble>
        </ChatMessageList>
      </ExpandableChatBody>
      <ExpandableChatFooter>
        <ChatInput />
        <Button type="submit" size="icon">
          <Send className="size-4" />
        </Button>
      </ExpandableChatFooter>
    </ExpandableChat>
  );
}

And then use that component on all your sites by placing it in your layout.tsx file (Next.js):

layou.tsx
<html lang="en">
  <body>
    </main>
      {children}
      <ChatSupport />
    </main>
  </body>
</html>

Want to create a chatbot fast? Use the following command to install a ready-to-use Next.js app with Vercel AI SDK integrated:

npx create-next-app --example https://github.com/jakobhoeg/shadcn-chat/tree/master/examples/shadcn-chat-example-vercel-ai nextjs-shadcn-chat-vercel-ai

Check out the docs for that here (opens in a new tab).

API Reference

ExpandableChat

PropTypeDefaultDescription
position"bottom-right" | "bottom-left""bottom-right"Position of the chat widget on the screen
size"sm" | "md" | "lg" | "xl" | "full""md"Size of the chat window
iconReact.ReactNode-Custom icon for the chat toggle button
classNamestring-Additional CSS classes for the main container
childrenReact.ReactNode-Content of the chat window

ExpandableChatHeader

PropTypeDefaultDescription
classNamestring-Additional CSS classes for the header section

ExpandableChatBody

PropTypeDefaultDescription
classNamestring-Additional CSS classes for the body section

ExpandableChatFooter

PropTypeDefaultDescription
classNamestring-Additional CSS classes for the footer section

ExpandableChatToggle (internal component)

PropTypeDefaultDescription
iconReact.ReactNode-Custom icon for the toggle button
isOpenboolean-Current open/closed state of the chat window
toggleChat() => void-Function to toggle the chat window open/closed
classNamestring-Additional CSS classes for the toggle button