React rules for the project Applies to files matching: **/*.tsx.
Installation
$skills install @FranciscoMoretti/react
Claude Code
Cursor
Copilot
Codex
Antigravity
Details
RepositoryFranciscoMoretti/sparka
Path.skillz/react/SKILL.md
Branchmain
Scoped Name@FranciscoMoretti/react
Usage
After installing, this skill will be available to your AI coding assistant.
Verify installation:
skills listSkill Instructions
name: react description: React rules for the project Applies to files matching: **/*.tsx.
Components
- Prefer function components: Use React function components with hooks over class components.
- Client vs server: Mark interactive components with
"use client"at the top of the file; keep non-interactive logic in server components or libraries. - No default exports: Use named exports for all components.
Hooks
- Hook ordering: Follow the standard rules of hooks; no conditional or looped hooks.
- Derived state: Prefer deriving values from props/form state instead of duplicating them in
useState. - Effects: Keep
useEffectminimal and side effect focused; avoid using it for basic data derivation.
Forms
- Validation: Use
react-hook-form+ Zod for all non-trivial forms. - UI primitives: Prefer shadcn
Formprimitives (Form,FormField,FormItem,FormLabel,FormControl,FormMessage) for form layout and error handling. - Schema location: Co-locate small form schemas with the component; extract only when reused across modules.
Styling & Layout
- Class merging: Use the shared
cnutility for conditional classes. - Composition: Prefer smaller composed components over deeply nested JSX in a single component.
Configuration Access
- Client components: Always use
useConfig()from@/components/config-providerto access site configuration in client components ("use client"). - Never import
siteConfigdirectly in client components—it derives values from server-only environment variables. TheConfigProviderreceives a serialized version that decouples client code from server secrets.
More by FranciscoMoretti
View allultracite
848Ultracite Rules - AI-Ready Formatter and Linter Applies to files matching: **/*.{ts,tsx,js,jsx,json,jsonc,html,vue,svelte,astro,css,yaml,yml,graphql,gql,md,mdx,grit}.
trpc-patterns
848TRPC with Tanstack Query patterns Applies to files matching: *.tsx.
trpc-patterns
848name: trpc-patterns
typescript
848Typescript rules for the project Applies to files matching: *.tsx,*.ts.