ai-elements-chatbot
ClaudeSkillz: For when you need skills, but lazier
8 stars2 forksUpdated Nov 20, 2025
npx skills add https://github.com/jackspace/claudeskillz --skill ai-elements-chatbotSKILL.md
AI Elements Chatbot Components
Status: Production Ready Last Updated: 2025-11-07 Dependencies: tailwind-v4-shadcn (prerequisite), ai-sdk-ui (companion), nextjs (framework) Latest Versions: ai-elements@1.6.0, ai@5.0+, next@15+, react@19+
Quick Start (15 Minutes)
1. Verify Prerequisites
Before installing AI Elements, ensure these are already set up:
# Check Next.js version (needs 15+)
npx next --version
# Check AI SDK version (needs 5+)
npm list ai
# Check shadcn/ui is initialized
ls components/ui # Should exist with button.tsx etc
Why this matters:
- AI Elements is built ON TOP of shadcn/ui (won't work without it)
- Requires Next.js App Router (Pages Router not supported)
- AI SDK v5 has breaking changes from v4
Missing prerequisites? Use the tailwind-v4-shadcn skill first, then install AI SDK:
pnpm add ai@latest
2. Install AI Elements CLI
# Initialize AI Elements in your project
pnpm dlx ai-elements@latest init
# Add your first components
pnpm dlx ai-elements@latest add message conversation response prompt-input
CRITICAL:
- Components are copied into
components/ui/ai/(NOT installed as npm package) - Full source code ownership (modify as needed)
- Registry URL must be correct in
components.json
3. Create Basic Chat Interface
// app/chat/page.tsx
'use client';
import { useChat } from 'ai/react';
import { Conversation } from '@/components/ui/ai/conversation';
import { Message } from '@/components/ui/ai/message';
import { MessageContent } from '@/components/ui/ai/message-content';
import { Response } from '@/components/ui/ai/response';
import { PromptInput } from '@/components/ui/ai/prompt-input';
export default function ChatPage() {
const { messages, input, handleInputChange, handleSubmit, isLoading } = useChat({
api: '/api/chat'
});
return (
<div className="flex h-screen flex-col">
<Conversation className="flex-1">
{messages.map((msg) => (
<Message key={msg.id} role={msg.role}>
<MessageContent>
<Response markdown={msg.content} />
</MessageContent>
</Message>
))}
</Conversation>
<PromptInput
value={input}
onChange={handleInputChange}
onSubmit={handleSubmit}
disabled={isLoading}
/>
</div>
);
}
Done! You now have a working chat interface with:
- ✅ Streaming markdown rendering
- ✅ Auto-scrolling conversation
- ✅ Auto-resizing input
- ✅ Role-based message styling
The 5-Step Setup Process
Step 1: Install AI Elements CLI
pnpm dlx ai-elements@latest init
This:
- Creates
components/ui/ai/directory - Updates
components.jsonwith AI Elements registry - Adds necessary dependencies to package.json
Key Points:
- Run from project root (where package.json is)
- Requires shadcn/ui already initialized
- Will fail if
components.jsonmissing (runpnpm dlx shadcn@latest initfirst)
Step 2: Add Core Chat Components
# Essential components for basic chat
pnpm dlx ai-elements@latest add message message-content conversation response
# Optional: Input component
pnpm dlx ai-elements@latest add prompt-input actions suggestion
Component Purpose:
message: Container for single message (user/AI)message-content: Wrapper for message partsconversation: Auto-scrolling chat containerresponse: Markdown renderer (streaming-optimized)prompt-input: Auto-resizing textarea with toolbaractions: Copy/regenerate/edit buttonssuggestion: Quick prompt pills
Step 3: Add Advanced Components (Optional)
# For tool calling
pnpm dlx ai-elements@latest add tool
# For reasoning display (Claude/o1 style)
pnpm dlx ai-elements@latest add reasoning
# For source citations (Perplexity style)
pnpm dlx ai-elements@latest add sources inline-citation
# For code highlighting
pnpm dlx ai-elements@latest add code-block
# For conversation branching
pnpm dlx ai-elements@latest add branch
# For task lists
pnpm dlx ai-elements@latest add task
# For AI-generated images
pnpm dlx ai-elements@latest add image
# For web previews (Claude artifacts style)
pnpm dlx ai-elements@latest add web-preview
# For loading states
pnpm dlx ai-elements@latest add loader
When to add each:
tool: Building AI assistants with function callingreasoning: Showing AI's thinking process (like Claude or o1)sources: Adding citations and references (like Perplexity)code-block: Chat includes code snippetsbranch: Multi-turn conversations with variationstask: AI generates task lists with file referencesimage: AI generates images (DALL-E, Stable Diffusion)web-preview: AI generates HTML/websites (Claude artifacts)loader: Show loading states during streaming
Step 4: Create API Route
Create /app/api/chat/route.ts:
import { openai } from '@ai-sdk/opena
...
Repository
jackspace/claudeskillzParent repository
Repository Stats
Stars8
Forks2
LicenseMIT License