Full-stack-skills stitch-shadcn-ui
Expert guidance for integrating and building applications with shadcn/ui. Component discovery, installation npx shadcn@latest add customization, blocks, and best practices. Use with Stitch-generated React apps for consistent, accessible UI built on Radix/Base UI and Tailwind.
git clone https://github.com/partme-ai/full-stack-skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/partme-ai/full-stack-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/stitch-skills/stitch-shadcn-ui" ~/.claude/skills/partme-ai-full-stack-skills-stitch-shadcn-ui && rm -rf "$T"
skills/stitch-skills/stitch-shadcn-ui/SKILL.mdshadcn/ui Component Integration
Constraint: Use when the user asks about shadcn/ui, Stitch + React + shadcn, or building React UIs with shadcn components.
You are a frontend engineer specializing in shadcn/ui—reusable, accessible, customizable components (Radix UI or Base UI + Tailwind). You help discover, install, customize, and extend components following best practices.
Core Principles
shadcn/ui is not a library—components are copied into your project:
- Full ownership: Code lives in your repo, not node_modules
- Full customization: Style, behavior, and structure under your control
- No version lock-in: Update components when you choose
- Zero runtime overhead: No extra bundle, only the code you add
Component Discovery and Installation
Browse and install
- List components: Use shadcn MCP
(or browse ui.shadcn.com).list_components - Install (recommended):
Downloads source, installs deps, places files innpx shadcn@latest add [component-name]
, updatescomponents/ui/
.components.json - Manual: Use MCP
to get source; createget_component
; install peer deps.components/ui/[name].tsx
Project setup
- New project:
(style, baseColor, RSC, etc.).npx shadcn@latest create - Existing project:
→ createsnpx shadcn@latest init
with:components.json- style: default, new-york (classic), or newer visual styles (Vega, Nova, Maia, Lyra, Mira).
- baseColor: slate, gray, zinc, neutral, stone.
- cssVariables, tailwind paths, aliases, rsc (React Server Components), rtl (optional).
Dependencies: React 18+, Tailwind 3+, Radix UI or Base UI, class-variance-authority, clsx, tailwind-merge.
Custom registries (optional)
For custom or third-party registries (defined in
components.json): use MCP get_project_registries, list_items_in_registries, view_items_in_registries, search_items_in_registries to discover and install components.
Architecture
- File structure:
for shadcn components;src/components/ui/
for your composed components.src/components/[custom]/ - cn() utility: All shadcn components use
(clsx + tailwind-merge) for class merging; keepcn()
with this helper.lib/utils.ts
Customization
- Theme: Edit Tailwind config and CSS variables in
(globals.css
and:root
)..dark - Variants: Use
for variant logic (e.g. button variant/size).cva - Wrappers: Create wrapper components in
(notcomponents/
) that extend shadcn components.components/ui/
Blocks and Complex Components
shadcn provides blocks (auth, dashboard, sidebar, etc.): use MCP
list_blocks, get_block to retrieve and install. Blocks are organized by category (e.g. calendar, dashboard, login, sidebar, products).
Validation and Quality (align with official)
Before committing components:
- Type check: Run
.tsc --noEmit - Lint: Run the project linter.
- Accessibility: Use tools like axe DevTools.
- Visual QA: Test light and dark modes.
- Responsive: Verify at different breakpoints.
Accessibility
Components use Radix primitives: keyboard navigation, ARIA, focus management. When customizing, preserve ARIA, keyboard handlers, and focus indicators.
Integration with Stitch
- After converting Stitch screens to React with stitch-react-components, add shadcn components for forms, dialogs, tables, etc. using this skill.
- Align theme (colors, spacing) with DESIGN.md from stitch-design-md if the project uses it.
Troubleshooting
- Import errors: Check
andcomponents.json
paths (tsconfig.json
).@/* - Style conflicts: Ensure Tailwind and
are configured; match CSS variable names.globals.css - Missing deps: Run
to auto-install; or usenpx shadcn@latest add [component]
for dependency list.get_component_metadata
Keywords
English: shadcn, shadcn/ui, Radix, Tailwind, React, components, blocks.
中文关键词: shadcn、Radix、Tailwind、组件。
References
- Examples
- Tailwind → shadcn/ui — When converting Stitch HTML to React + shadcn: keep Tailwind, map Stitch tokens to globals.css (--primary, --background, etc.); use shadcn components (Button, Card, Input) with className/cn().
- shadcn/ui docs
- Radix UI