Unnamed Skill
React rules for the project Applies to files matching: **/*.tsx.
$ 安裝
git clone https://github.com/FranciscoMoretti/sparka /tmp/sparka && cp -r /tmp/sparka/.skillz/react ~/.claude/skills/sparka// tip: Run this command in your terminal to install the skill
SKILL.md
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.
Repository

FranciscoMoretti
Author
FranciscoMoretti/sparka/.skillz/react
844
Stars
89
Forks
Updated5d ago
Added6d ago