react-forms
TanStack Form v1 Core Features
Agent Workflow (MANDATORY)
Before ANY implementation, use TeamCreate to spawn 3 agents:
- fuse-ai-pilot:explore-codebase - Analyze existing form components and validation patterns
- fuse-ai-pilot:research-expert - Verify latest TanStack Form v1 docs via Context7/Exa
- mcp__context7__query-docs - Check Zod validation and React 19 Server Actions patterns
After implementation, run fuse-ai-pilot:sniper for validation.
MANDATORY: SOLID Principles
ALWAYS apply SOLID principles from solid-react skill.
→ See ../solid-react/SKILL.md for complete rules
Key Rules:
- Files < 100 lines (split at 90)
- Interfaces in
modules/[feature]/src/interfaces/ - JSDoc mandatory on all exports
- No business logic in components
Core Hooks
| Hook | Purpose | Guide |
|---|---|---|
useForm() |
Initialize form with validation | references/tanstack-form-basics.md |
useField() |
Subscribe to individual field | references/tanstack-form-basics.md |
form.Field |
Render prop component for fields | references/tanstack-form-basics.md |
form.Subscribe |
Watch form state changes | references/tanstack-form-basics.md |
→ See references/tanstack-form-basics.md for detailed usage
Validation Adapters
| Library | Adapter | Bundle Size |
|---|---|---|
| Zod | zodValidator() |
~12KB |
| Yup | yupValidator() |
~40KB |
| Valibot | valibotValidator() |
~6KB |
→ See references/zod-validation.md for Zod patterns
→ See references/yup-valibot.md for alternatives
Key Features
Async Validation
Server-side checks with debouncing and loading states.
→ See references/async-validation.md
Server Actions (React 19)
Integration with useActionState and progressive enhancement.
→ See references/server-actions.md
Arrays & Nested Fields
Dynamic field arrays and dot notation for nested objects.
→ See references/arrays-nested.md
TypeScript Integration
Full type inference from Zod schemas and defaultValues.
→ See references/typescript.md
shadcn/ui Integration
Field wrapper components with shadcn styling.
→ See references/shadcn-integration.md
Listeners (Side Effects)
onMount, onChange, onBlur, onSubmit with debouncing.
→ See references/listeners.md
Linked Fields
Cross-field validation and dependent dropdowns.
→ See references/linked-fields.md
Reactivity & Performance
useStore selectors and granular subscriptions.
→ See references/reactivity.md
Reset API
Form and field reset with custom values.
→ See references/reset-api.md
SSR & Hydration
TanStack Start integration and server state merge.
→ See references/ssr-hydration.md
Devtools
Debug form state with @tanstack/react-form-devtools.
→ See references/devtools.md
React Native
Mobile-specific patterns with TextInput.
→ See references/react-native.md
Standard Schema
ArkType and Effect Schema support.
→ See references/standard-schema.md
Templates
| Template | Use Case |
|---|---|
templates/basic-form.md |
Login/signup with Zod |
templates/multi-step-form.md |
Wizard with step validation |
templates/dynamic-fields.md |
Add/remove field arrays |
templates/file-upload-form.md |
File input with preview |
templates/server-action-form.md |
React 19 Server Actions |
templates/optimistic-form.md |
useOptimistic integration |
templates/nested-form.md |
Dot notation nested fields |
templates/search-form.md |
Debounced search |
templates/conditional-fields.md |
Show/hide based on values |
templates/form-composition.md |
Reusable field components |
templates/listeners-form.md |
Side effects & auto-save |
templates/linked-fields-form.md |
Cross-field validation |
templates/reactivity-form.md |
Performance optimization |
templates/reset-form.md |
Form/field reset patterns |
templates/ssr-form.md |
SSR & hydration |
templates/devtools-form.md |
Devtools integration |
templates/react-native-form.md |
React Native forms |
Best Practices
- Validation: Use Zod/Yup/Valibot, NOT custom regex
- Async: Debounce server validation (300-500ms)
- Errors: Display
field.state.meta.errors - Nested: Use dot notation (
address.street) - Arrays: Use
mode="array"with pushValue/removeValue - TypeScript: Infer types with
z.infer<typeof schema>
Forbidden (Anti-Patterns)
- ❌
useStatefor form state → useuseForm() - ❌ Regex validation → use Zod/Yup/Valibot
- ❌ No debounce on async → use
onChangeAsyncDebounceMs - ❌ Validation in components → move to schema
- ❌ Direct
onChange→ usefield.handleChange - ❌ No TypeScript types → use
z.infer<typeof schema>