Claude-skill-registry component-design
Design React/Vue components following atomic design and composition
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/component-design" ~/.claude/skills/majiayu000-claude-skill-registry-component-design && rm -rf "$T"
manifest:
skills/data/component-design/SKILL.mdsource content
Component Design Skill
Purpose
Create consistent, reusable UI components.
Atomic Design
Reference: patterns/atomic-design.md
Hierarchy
- Atoms: Basic elements (Button, Input, Label)
- Molecules: Simple groups (FormField, SearchBox)
- Organisms: Complex sections (Header, Form, Card)
- Templates: Page layouts
- Pages: Specific instances
Component Patterns
Reference: patterns/composition.md
Compound Components
<Select> <Select.Trigger /> <Select.Content> <Select.Item value="1">Option 1</Select.Item> </Select.Content> </Select>
Render Props
<DataFetcher url="/api/users"> {({ data, loading }) => ( loading ? <Spinner /> : <UserList users={data} /> )} </DataFetcher>
Custom Hooks
function useUser(id: string) { const [user, setUser] = useState(null); const [loading, setLoading] = useState(true); // ... return { user, loading, error }; }
Props Interface
interface ButtonProps { /** Visual variant of the button */ variant?: 'primary' | 'secondary' | 'ghost'; /** Size of the button */ size?: 'sm' | 'md' | 'lg'; /** Whether button is disabled */ disabled?: boolean; /** Click handler */ onClick?: () => void; /** Button content */ children: React.ReactNode; }
Component Template
Use: templates/component-template.tsx
State Management
Reference: patterns/state-management.md
Decision Tree
- UI-only state →
useState - Complex local state →
useReducer - Shared between siblings → Lift to parent
- Shared across app → Context or global store
- Server state → React Query/SWR