home / skills / hoangnguyen0403 / agent-skills-standard / component-patterns
This skill enforces modern React component patterns, guiding hook usage, composition, typing, and exports to build scalable, maintainable UI.
npx playbooks add skill hoangnguyen0403/agent-skills-standard --skill component-patternsReview the files below or copy the command above to add this skill to your agents.
---
name: React Component Patterns
description: Modern React component architecture and composition patterns.
metadata:
labels: [react, components, composition, patterns]
triggers:
files: ['**/*.jsx', '**/*.tsx']
keywords: [component, props, children, composition, hoc, render-props]
---
# React Component Patterns
## **Priority: P0 (CRITICAL)**
Standards for building scalable, maintainable React components.
## Implementation Guidelines
- **Function Components**: Only hooks. No classes.
- **Composition**: Use `children` prop. Avoid inheritance.
- **Props**: Explicit TS interfaces. Destructure in params.
- **Boolean Props**: Shorthand `<Cmp isVisible />` vs `isVisible={true}`.
- **Imports**: Group: `Built-in` -> `External` -> `Internal` -> `Styles`.
- **Error Boundaries**: Wrap app/features with `react-error-boundary`.
- **Size**: Small (< 250 lines). One component per file.
- **Naming**: `PascalCase` components. `use*` hooks.
- **Exports**: Named exports only.
- **Conditionals**: Ternary (`Cond ? <A/> : <B/>`) over `&&` for rendering consistency.
- **Hoisting**: Extract static JSX/Objects outside component to prevent recreation.
## Anti-Patterns
- **No Classes**: Use hooks.
- **No Prop Drilling**: Use Context/Zustand.
- **No Nested Definitions**: Define components at top level.
- **No Index Keys**: Use stable IDs.
- **No Inline Handlers**: Define before return.
## Reference & Examples
See [references/patterns.md](references/patterns.md) for Composition, Compound Components, and Render Props examples.
## Related Topics
hooks | state-management | performance
This skill codifies modern React component architecture and composition patterns to build scalable, maintainable TypeScript React apps. It captures conventions for components, hooks, imports, error handling, and common anti-patterns. Use it to standardize component shape, improve performance, and reduce bugs across a codebase.
The skill inspects component structure and recommends or enforces patterns such as functional components with hooks, explicit TypeScript prop interfaces, and single-component-per-file sizing. It highlights composition approaches (children, compound components, render props), import ordering, error boundary placement, and anti-patterns like prop drilling or inline handlers. It also suggests hoisting static values and preferring named exports and PascalCase naming.
Should I ever use class components?
No—favor functional components with hooks for consistency, testability, and future maintenance.
How do I avoid prop drilling in complex trees?
Introduce Context or a state library (Zustand) and lift only necessary state, or use composition to surface handlers where needed.