Ai Elements
/install ai-elements
AI Elements
AI Elements is a comprehensive React component library for building AI-powered user interfaces. The library provides 30+ components specifically designed for chat interfaces, tool execution visualization, reasoning displays, and workflow management.
Installation
Install via shadcn registry:
npx shadcn@latest add https://ai-elements.vercel.app/r/[component-name]
Import Pattern: Components are imported from individual files, not a barrel export:
// Correct - import from specific files
import { Conversation } from "@/components/ai-elements/conversation";
import { Message } from "@/components/ai-elements/message";
import { PromptInput } from "@/components/ai-elements/prompt-input";
// Incorrect - no barrel export
import { Conversation, Message } from "@/components/ai-elements";
Gates (before relying on examples)
Use this sequence when adding or wiring AI Elements so setup is checkable, not assumed.
-
Install each component — Run
npx shadcn@latest add https://ai-elements.vercel.app/r/[component-name]for every component you need.- Pass: The command completes successfully and a file for that component exists under your project’s
components/ai-elements/(or the directorycomponents.jsonuses for those additions).
- Pass: The command completes successfully and a file for that component exists under your project’s
-
Align import paths — Every
import … from "@/components/ai-elements/..."must match your repo’s actual alias and folder layout.- Pass: Each import resolves to a file on disk (IDE navigation or build/
tscshows no “cannot find module” for those paths).
- Pass: Each import resolves to a file on disk (IDE navigation or build/
-
Match
Tool/Confirmationstates to your AI SDK — State strings (including approval-related states) depend on the installedaipackage major/version.- Pass: The states you pass to
ToolHeader,Tool, orConfirmationare listed in the AI SDK version you have installed (docs or exported types), not copied from memory alone.
- Pass: The states you pass to
Component Categories
Conversation Components
Components for displaying chat-style interfaces with messages, attachments, and auto-scrolling behavior.
- Conversation: Container with auto-scroll capabilities
- Message: Individual message display with role-based styling
- MessageAttachment: File and image attachments
- MessageBranch: Alternative response navigation
See references/conversation.md for details.
Prompt Input Components
Advanced text input with file attachments, drag-and-drop, speech input, and state management.
- PromptInput: Form container with file handling
- PromptInputTextarea: Auto-expanding textarea
- PromptInputSubmit: Status-aware submit button
- PromptInputAttachments: File attachment display
- PromptInputProvider: Global state management
See references/prompt-input.md for details.
Workflow Components
Components for displaying job queues, tool execution, and approval workflows.
- Queue: Job queue container
- QueueItem: Individual queue items with status
- Tool: Tool execution display with collapsible states
- Confirmation: Approval workflow component
- Reasoning: Collapsible thinking/reasoning display
See references/workflow.md for details.
Visualization Components
ReactFlow-based components for workflow visualization and custom node types.
- Canvas: ReactFlow wrapper with aviation-specific defaults
- Node: Custom node component with handles
- Edge: Temporary and Animated edge types
- Controls, Panel, Toolbar: Navigation and control elements
See references/visualization.md for details.
Integration with shadcn/ui
AI Elements is built on top of shadcn/ui and integrates seamlessly with its theming system:
- Uses shadcn/ui's design tokens (colors, spacing, typography)
- Respects light/dark mode via CSS variables
- Compatible with shadcn/ui components (Button, Card, Collapsible, etc.)
- Follows shadcn/ui's component composition patterns
Key Design Patterns
Component Composition
AI Elements follows a composition-first approach where larger components are built from smaller primitives:
\x3CTool>
\x3CToolHeader title="search" type="tool-call-search" state="output-available" />
\x3CToolContent>
\x3CToolInput input={{ query: "AI tools" }} />
\x3CToolOutput output={results} errorText={undefined} />
\x3C/ToolContent>
\x3C/Tool>
Context-Based State
Many components use React Context for state management:
PromptInputProviderfor global input stateMessageBranchfor alternative response navigationConfirmationfor approval workflow stateReasoningfor collapsible thinking state
Controlled vs Uncontrolled
Components support both controlled and uncontrolled patterns:
// Uncontrolled (self-managed state)
\x3CPromptInput onSubmit={handleSubmit} />
// Controlled (external state)
\x3CPromptInputProvider initialInput="">
\x3CPromptInput onSubmit={handleSubmit} />
\x3C/PromptInputProvider>
Tool State Machine
The Tool component follows the Vercel AI SDK's state machine:
input-streaming: Parameters being receivedinput-available: Ready to executeapproval-requested: Awaiting user approval (SDK v6)approval-responded: User responded (SDK v6)output-available: Execution completedoutput-error: Execution failedoutput-denied: Approval denied
Queue Patterns
Queue components support hierarchical organization:
\x3CQueue>
\x3CQueueSection defaultOpen={true}>
\x3CQueueSectionTrigger>
\x3CQueueSectionLabel count={3} label="tasks" icon={\x3CIcon />} />
\x3C/QueueSectionTrigger>
\x3CQueueSectionContent>
\x3CQueueList>
\x3CQueueItem>
\x3CQueueItemIndicator completed={false} />
\x3CQueueItemContent>Task description\x3C/QueueItemContent>
\x3C/QueueItem>
\x3C/QueueList>
\x3C/QueueSectionContent>
\x3C/QueueSection>
\x3C/Queue>
Auto-Scroll Behavior
The Conversation component uses the use-stick-to-bottom hook for intelligent auto-scrolling:
- Automatically scrolls to bottom when new messages arrive
- Pauses auto-scroll when user scrolls up
- Provides scroll-to-bottom button when not at bottom
- Supports smooth and instant scroll modes
File Attachment Handling
PromptInput provides comprehensive file handling:
- Drag-and-drop support (local or global)
- Paste image/file support
- File type validation (accept prop)
- File size limits (maxFileSize prop)
- Maximum file count (maxFiles prop)
- Preview for images, icons for files
- Automatic blob URL to data URL conversion on submit
Speech Input
The PromptInputSpeechButton uses the Web Speech API for voice input:
- Browser-based speech recognition
- Continuous recognition mode
- Interim results support
- Automatic text insertion into textarea
- Visual feedback during recording
Reasoning Auto-Collapse
The Reasoning component provides auto-collapse behavior:
- Opens automatically when streaming starts
- Closes 1 second after streaming ends
- Tracks thinking duration in seconds
- Displays "Thinking..." with shimmer effect during streaming
- Shows "Thought for N seconds" when complete
TypeScript Types
All components are fully typed with TypeScript:
import type { ToolUIPart, FileUIPart, UIMessage } from "ai";
type ToolProps = ComponentProps\x3Ctypeof Collapsible>;
type QueueItemProps = ComponentProps\x3C"li">;
type MessageAttachmentProps = HTMLAttributes\x3CHTMLDivElement> & {
data: FileUIPart;
onRemove?: () => void;
};
Common Use Cases
Chat Interface
Combine Conversation, Message, and PromptInput for a complete chat UI:
import { Conversation, ConversationContent, ConversationScrollButton } from "@/components/ai-elements/conversation";
import { Message, MessageContent, MessageResponse } from "@/components/ai-elements/message";
import {
PromptInput,
PromptInputTextarea,
PromptInputFooter,
PromptInputTools,
PromptInputButton,
PromptInputSubmit
} from "@/components/ai-elements/prompt-input";
\x3Cdiv className="flex flex-col h-screen">
\x3CConversation>
\x3CConversationContent>
{messages.map(msg => (
\x3CMessage key={msg.id} from={msg.role}>
\x3CMessageContent>
\x3CMessageResponse>{msg.content}\x3C/MessageResponse>
\x3C/MessageContent>
\x3C/Message>
))}
\x3C/ConversationContent>
\x3CConversationScrollButton />
\x3C/Conversation>
\x3CPromptInput onSubmit={handleSubmit}>
\x3CPromptInputTextarea />
\x3CPromptInputFooter>
\x3CPromptInputTools>
\x3CPromptInputButton onClick={() => attachments.openFileDialog()}>
\x3CPaperclipIcon />
\x3C/PromptInputButton>
\x3C/PromptInputTools>
\x3CPromptInputSubmit status={chatStatus} />
\x3C/PromptInputFooter>
\x3C/PromptInput>
\x3C/div>
Tool Execution Display
Show tool execution with expandable details:
import { Tool, ToolHeader, ToolContent, ToolInput, ToolOutput } from "@/components/ai-elements/tool";
{toolInvocations.map(tool => (
\x3CTool key={tool.id}>
\x3CToolHeader
title={tool.toolName}
type={`tool-call-${tool.toolName}`}
state={tool.state}
/>
\x3CToolContent>
\x3CToolInput input={tool.args} />
{tool.result && (
\x3CToolOutput output={tool.result} errorText={tool.error} />
)}
\x3C/ToolContent>
\x3C/Tool>
))}
Approval Workflow
Request user confirmation before executing actions:
import {
Confirmation,
ConfirmationTitle,
ConfirmationRequest,
ConfirmationActions,
ConfirmationAction,
ConfirmationAccepted,
ConfirmationRejected
} from "@/components/ai-elements/confirmation";
\x3CConfirmation approval={tool.approval} state={tool.state}>
\x3CConfirmationTitle>
Approve deletion of {resource}?
\x3C/ConfirmationTitle>
\x3CConfirmationRequest>
\x3CConfirmationActions>
\x3CConfirmationAction onClick={approve} variant="default">
Approve
\x3C/ConfirmationAction>
\x3CConfirmationAction onClick={reject} variant="outline">
Reject
\x3C/ConfirmationAction>
\x3C/ConfirmationActions>
\x3C/ConfirmationRequest>
\x3CConfirmationAccepted>
Action approved and executed.
\x3C/ConfirmationAccepted>
\x3CConfirmationRejected>
Action rejected.
\x3C/ConfirmationRejected>
\x3C/Confirmation>
Job Queue Management
Display task lists with completion status:
import {
Queue,
QueueSection,
QueueSectionTrigger,
QueueSectionLabel,
QueueSectionContent,
QueueList,
QueueItem,
QueueItemIndicator,
QueueItemContent,
QueueItemDescription
} from "@/components/ai-elements/queue";
\x3CQueue>
\x3CQueueSection>
\x3CQueueSectionTrigger>
\x3CQueueSectionLabel count={todos.length} label="todos" />
\x3C/QueueSectionTrigger>
\x3CQueueSectionContent>
\x3CQueueList>
{todos.map(todo => (
\x3CQueueItem key={todo.id}>
\x3CQueueItemIndicator completed={todo.status === 'completed'} />
\x3CQueueItemContent completed={todo.status === 'completed'}>
{todo.title}
\x3C/QueueItemContent>
{todo.description && (
\x3CQueueItemDescription completed={todo.status === 'completed'}>
{todo.description}
\x3C/QueueItemDescription>
)}
\x3C/QueueItem>
))}
\x3C/QueueList>
\x3C/QueueSectionContent>
\x3C/QueueSection>
\x3C/Queue>
Accessibility
Components include accessibility features:
- ARIA labels and roles
- Keyboard navigation support
- Screen reader announcements
- Focus management
- Semantic HTML elements
Animation
Many components use Framer Motion for smooth animations:
- Shimmer effect for loading states
- Collapsible content transitions
- Edge animations in Canvas
- Loader spinner rotation
References
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install ai-elements - After installation, invoke the skill by name or use
/ai-elements - Provide required inputs per the skill's parameter spec and get structured output
What is Ai Elements?
Vercel AI Elements for workflow UI components. Use when building chat interfaces, displaying tool execution, showing reasoning/thinking, or creating job queu... It is an AI Agent Skill for Claude Code / OpenClaw, with 158 downloads so far.
How do I install Ai Elements?
Run "/install ai-elements" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is Ai Elements free?
Yes, Ai Elements is completely free, licensed under MIT-0. You can download, install and use it at no cost.
Which platforms does Ai Elements support?
Ai Elements is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created Ai Elements?
It is built and maintained by Kevin Anderson (@anderskev); the current version is v1.1.1.