shadcn-ui

Install and use shadcn/ui with Tailwind v4 and Next.js (App Router), Vite, or manual setup; configure components.json, add components via CLI, theming with CSS only. Use when adding shadcn/ui, installing shadcn, using Button, Card, Dialog, Form, or other shadcn components, or when the user mentions shadcn, shadcn/ui, or Radix UI with Tailwind.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "shadcn-ui" with this command: npx skills add enderpuentes/ai-agent-skills/enderpuentes-ai-agent-skills-shadcn-ui

shadcn/ui

Overview

shadcn/ui is a collection of accessible, customizable React components built on Radix UI and Tailwind CSS. Components are copied into your project (no npm package); you own and edit the code. Works with Next.js (App Router), Vite, and other React frameworks.

Principles: Open code (AI-ready), composable API, beautiful defaults, distribution via CLI and schema. Requires Tailwind v4 and path alias @/*. We do not use tailwind.config.js; theme and setup are CSS-only (@import "tailwindcss" + @theme).


Prerequisites

  • Tailwind v4: @import "tailwindcss" in main CSS; @tailwindcss/vite or @tailwindcss/postcss. No tailwind.config.js. See the tailwind-css skill.
  • Path alias @/*./src/* (or your source root) in tsconfig and in the bundler (e.g. Vite resolve.alias).
  • React (Next.js App Router, Vite, etc.).

Installation

New project (recommended)

Scaffold with Tailwind and shadcn:

pnpm dlx shadcn@latest create
# or: npx shadcn@latest create

Choose framework (Next.js, Vite, etc.), style (new-york recommended), base color, and CSS variables. Then add components as needed.

Existing project (Next.js App Router)

  1. Init (creates components.json, optional cn helper and base styles):
pnpm dlx shadcn@latest init
  1. Paths and Tailwind

    • tsconfig: "baseUrl": ".", "paths": { "@/*": ["./src/*"] } (in both root and app tsconfig if split).
    • Tailwind v4: Main CSS (e.g. app/globals.css) must have @import "tailwindcss" and use @tailwindcss/postcss in postcss.config.mjs. Do not add tailwind.config.js.
  2. Add components (see list below):

pnpm dlx shadcn@latest add button
pnpm dlx shadcn@latest add card dialog

Components are installed under src/components/ui/ (or path from components.json).

Existing project (Vite)

  • Use resolve.alias: { "@": path.resolve(__dirname, "./src") } in vite.config.ts; install @types/node if using path.
  • Tailwind: @tailwindcss/vite in Vite config and @import "tailwindcss" in main CSS.

components.json

Controls style, paths, and Tailwind integration. Key fields:

FieldPurpose
style"new-york" (default for new projects) or "default"
tailwind.configLeave "" with Tailwind v4; we do not use a JS config file
tailwind.cssPath to global CSS (e.g. src/styles/globals.css or app/globals.css) with @import "tailwindcss"
tailwind.baseColorBase color for theme: neutral, slate, gray, zinc, stone
tailwind.cssVariablestrue for CSS variables theming (recommended)
aliases.componentse.g. @/components
aliases.utilse.g. @/lib/utils
aliases.uie.g. @/components/ui
rsctrue for Next.js App Router with Server Components; false for client-only

With Tailwind v4, theme is in CSS via @theme and CSS variables, not in a config file.


Official components (current list)

Add with: pnpm dlx shadcn@latest add <name> (multiple: add button card dialog).

Layout & structure

ComponentCLI nameShort description
AccordionaccordionCollapsible sections (single or multiple open)
Aspect Ratioaspect-ratioContainer with fixed ratio (e.g. 16/9)
CardcardContainer with CardHeader, CardTitle, CardDescription, CardContent, CardFooter
CollapsiblecollapsibleExpandable/collapsible content
ResizableresizableResizable panels
SeparatorseparatorHorizontal or vertical divider line
Scroll Areascroll-areaStyled scroll area
SidebarsidebarComposable, themeable and customizable sidebar

Forms & input

ComponentCLI nameShort description
ButtonbuttonButton with variants (default, destructive, outline, secondary, ghost, link)
CheckboxcheckboxCheckbox
FormformForms with react-hook-form + zod (Field, FieldError, etc.)
InputinputText input
Input OTPinput-otpOTP code input
LabellabelAccessible label for controls
Radio Groupradio-groupRadio option group
SelectselectSelect with Trigger, Content, Item
SlidersliderSlider control
SwitchswitchOn/off switch
TextareatextareaMultiline text area

Navigation & menus

ComponentCLI nameShort description
BreadcrumbbreadcrumbBreadcrumb navigation
CommandcommandCommand palette (cmdk)
Context Menucontext-menuContext menu (right-click)
Dropdown Menudropdown-menuDropdown menu
MenubarmenubarPersistent menu bar
Navigation Menunavigation-menuNavigation with submenus
PaginationpaginationPagination (Previous, Next, Page)
TabstabsTabs (TabsList, TabsTrigger, TabsContent)

Overlays & feedback

ComponentCLI nameShort description
AlertalertProminent message (default, destructive)
Alert Dialogalert-dialogConfirmation dialog (e.g. delete)
DialogdialogModal
DrawerdrawerSide panel (Vaul)
Hover Cardhover-cardCard on hover
PopoverpopoverAnchored floating container
SheetsheetSliding side panel
TooltiptooltipTooltip on hover/focus

Data & state

ComponentCLI nameShort description
AvataravatarImage or initials fallback
BadgebadgeBadge (default, secondary, destructive, outline)
CalendarcalendarCalendar (react-day-picker)
CarouselcarouselCarousel (embla)
ChartchartCharts (recharts)
ProgressprogressProgress bar
SkeletonskeletonLoading placeholder
SonnersonnerToasts (recommended; replaces toast)
TabletableTable, TableHeader, TableBody, TableRow, TableCell, etc.
ToasttoastToasts (deprecated in favor of Sonner)

Toggle & toggle group

ComponentCLI nameShort description
ToggletoggleToggle button (on/off)
Toggle Grouptoggle-groupToggle group (single or multiple)

Using components

Import from the aliased path (not from shadcn/ui):

import { Button } from "@/components/ui/button"
import { Card, CardHeader, CardTitle, CardContent } from "@/components/ui/card"

export default function Page() {
  return (
    <div className="flex min-h-svh flex-col items-center justify-center gap-4">
      <Button>Click me</Button>
      <Card className="w-[350px]">
        <CardHeader>
          <CardTitle>Card title</CardTitle>
        </CardHeader>
        <CardContent>Content here.</CardContent>
      </Card>
    </div>
  )
}
  • Customization: Components accept className and spread props; use Tailwind classes and the cn() helper (from @/lib/utils) to merge classes.
  • Composition: Prefer composition (e.g. CardHeader + CardContent) over props for layout.

Theming (Tailwind v4, no config file)

We use Tailwind v4 only; no tailwind.config.js. Theming is CSS-only:

  • CSS variables: With tailwind.cssVariables: true, theme is driven by variables in your global CSS (e.g. --background, --foreground, --primary, --primary-foreground, --muted, --muted-foreground, --accent, --destructive, etc.). Override them in that file.
  • @theme: Use @theme { ... } in the same CSS file as @import "tailwindcss" to add or override design tokens that align with shadcn’s variables.
  • Base color: Set in components.json (tailwind.baseColor) or by editing the CSS variables in your global CSS.

Common patterns

  • Forms: Add form; pair with react-hook-form and zod. Use Input, Label, Button, Select, Checkbox, etc.
  • Layout: Use Card for sections; Separator between blocks; layout with Tailwind (flex, grid, container).
  • Modals & panels: Dialog for modals; Sheet or Drawer for side panels.
  • Menus: DropdownMenu, Context Menu, Navigation Menu, Command (palette).
  • Feedback: Alert for messages; Sonner for toasts; Skeleton for loading.
  • Icons: Many examples use lucide-react; add it if the project uses icons.

Common mistakes

  • Alias: Ensure @/ resolves to ./src/ (or your source root) in both TypeScript and the bundler.
  • CSS not loaded: The file set in components.json (tailwind.css) must be imported in the app entry (e.g. app/layout.tsx) and contain @import "tailwindcss".
  • Tailwind config: Do not create or suggest tailwind.config.js. Theme only in CSS (@theme and variables).
  • Import: Import from @/components/ui/<component> (per components.json), not from shadcn/ui.
  • RSC: In Next.js App Router, set rsc: true in components.json if components are used in Server Components where applicable.

Additional resources

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

typescript

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

pagespeed-insights

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

conventional-commits

No summary provided by upstream source.

Repository SourceNeeds Review
Automation

tailwind-css

No summary provided by upstream source.

Repository SourceNeeds Review