Agent Skills: React TypeScript

Type React components and hooks with TypeScript patterns. Use when typing React props, hooks, event handlers, or component generics in TypeScript. (triggers: **/*.tsx, ReactNode, FC, PropsWithChildren, ComponentProps)

UncategorizedID: hoangnguyen0403/agent-skills-standard/react-typescript

Install this agent skill to your local

pnpm dlx add-skill https://github.com/HoangNguyen0403/agent-skills-standard/tree/HEAD/skills/react/react-typescript

Skill Files

Browse the full folder contents for react-typescript.

Download Skill

Loading file tree…

skills/react/react-typescript/SKILL.md

Skill Metadata

Name
react-typescript
Description
"Type React components and hooks with TypeScript patterns. Use when typing React props, hooks, event handlers, or component generics in TypeScript. (triggers: **/*.tsx, ReactNode, FC, PropsWithChildren, ComponentProps)"

React TypeScript

Priority: P1 (OPERATIONAL)

Type-safe React patterns.

Implementation Guidelines

  • Components: Prefer interface/type (Props) over React.FC (which has implicit children). Use JSX.Element or ReactNode as the return type.
  • Children: For components that accept children, use PropsWithChildren<T> or explicitly type them as React.ReactNode.
  • Events: Always type event handlers using specific React events, such as React.ChangeEvent<HTMLInputElement> or React.FormEvent<HTMLFormElement>.
  • Hooks: For useRef, avoid any; use useRef<HTMLDivElement>(null). For useState, use generics for complex types: useState<User | null>(null).
  • Native Elements: Use ComponentPropsWithoutRef<'button'> or ComponentPropsWithRef to extend native attributes safely.
  • Generics: Implement generic components for reusable UI like lists using <T,>(props: ListProps<T>).
  • Discriminated Unions: Use Discriminated Unions for mutually exclusive props (e.g., success vs error states).
  • Utility Types: Leverage Omit, Pick, and Partial to transform prop interfaces and avoid redundancy.

Anti-Patterns

  • No any: Use unknown.
  • No React.FC: Implicit children is deprecated/bad practice.
  • No Function: Use (args: T) => void.

References

See references/example.md for typed props, generic components, and hook ref patterns.