Awesome-omni-skill nextjs-tanstack-form

TanStack Form v1 for Next.js 16 with Server Actions, Zod validation, and shadcn/ui integration. Use when building forms, validation, multi-step wizards, or dynamic field arrays.

install
source · Clone the upstream repo
git clone https://github.com/diegosouzapw/awesome-omni-skill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/diegosouzapw/awesome-omni-skill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/development/nextjs-tanstack-form" ~/.claude/skills/diegosouzapw-awesome-omni-skill-nextjs-tanstack-form-b4ce97 && rm -rf "$T"
manifest: skills/development/nextjs-tanstack-form/SKILL.md
source content

TanStack Form for Next.js 16

Type-safe, performant forms with Server Actions and signal-based reactivity.

Agent Workflow (MANDATORY)

Before ANY implementation, use

TeamCreate
to spawn 3 agents:

  1. fuse-ai-pilot:explore-codebase - Analyze existing forms and validation patterns
  2. fuse-ai-pilot:research-expert - Verify latest TanStack Form docs via Context7/Exa
  3. mcp__context7__query-docs - Check form options and field API

After implementation, run fuse-ai-pilot:sniper for validation.


Overview

When to Use

  • Building forms with complex validation requirements
  • Need Server Actions integration for form submission
  • Implementing multi-step wizards or dynamic field arrays
  • Require real-time async validation (username availability)
  • Want type-safe forms with full TypeScript inference

Why TanStack Form

FeatureBenefit
Signal-based stateMinimal re-renders, optimal performance
Full TypeScriptDeepKeys, DeepValue inference
Server Actions nativeBuilt-in Next.js 16 integration
Zod adapterSchema-first validation
Framework agnosticSame API for React, Vue, Solid
HeadlessWorks with any UI library (shadcn/ui)

Critical Rules

  1. formOptions shared - Define once, use in client and server
  2. Server validation - DB checks in
    onServerValidate
    , not client
  3. Zod schemas - Client-side instant feedback
  4. useActionState - React 19 hook for Server Actions
  5. mergeForm - Combine server errors with client state
  6. SOLID paths - Forms in
    modules/[feature]/src/components/forms/

SOLID Architecture

Module Structure

Forms organized by feature module:

  • modules/auth/src/components/forms/
    - Auth forms (login, signup)
  • modules/auth/src/interfaces/
    - Form types and schemas
  • modules/auth/src/actions/
    - Server Actions for form submission
  • modules/cores/lib/forms/
    - Shared form utilities

File Organization

FilePurposeMax Lines
form-options.ts
Shared formOptions + Zod schema50
FormComponent.tsx
Client form UI with fields80
form.action.ts
Server Action with validation30
form.interface.ts
Types for form values30

Key Concepts

Form Options Pattern

Define form configuration once, share between client and server. Ensures type safety and consistency.

Field API

Each field has state (value, errors, touched, validating) and handlers (handleChange, handleBlur).

Validation Levels

  • onChange - Real-time as user types
  • onBlur - When field loses focus
  • onSubmit - Before form submission
  • onServer - Server-side in action

Error Management

Errors exist at field-level and form-level. Use

field.state.meta.errors
for field errors,
form.state.errorMap
for form errors.


Reference Guide

NeedReference
Initial setupinstallation.md
Basic patternsbasic-usage.md, field-api.md
Validationvalidation-zod.md, async-validation.md
Server Actionsserver-actions.md
Dynamic formsarray-fields.md, multi-step-form.md
UI integrationshadcn-integration.md
TypeScripttypescript.md
Migrationmigration-rhf.md

Best Practices

  1. Define schemas first - Zod schemas drive both validation and types
  2. Shared formOptions - Single source of truth for client/server
  3. Debounce async validation - Use
    asyncDebounceMs
    for API calls
  4. form.Subscribe - Selective re-renders for submit state
  5. Field composition - Reusable field components with shadcn/ui
  6. Server errors merge - Use
    mergeForm
    to show server validation errors

Comparison vs React Hook Form

AspectTanStack FormReact Hook Form
Type Safety100% (DeepKeys)Manual typing
PerformanceSignals (minimal)Refs (good)
Server ActionsNative supportManual integration
Bundle Size~12KB~9KB
Learning CurveMediumLow
Use CaseComplex appsStandard forms