#601

Global Rank · of 601 Skills

tanstack-form AI Agent Skill

View Source: oakoss/agent-skills

Safe

Installation

npx skills add oakoss/agent-skills --skill tanstack-form

67

Installs

TanStack Form

Overview

TanStack Form is a headless form state manager, not a UI component library. You provide your own inputs and handle their events; TanStack Form manages validation, state, and submission logic.

When to use: Complex multi-step forms, reusable form patterns, dynamic field arrays, cross-field validation, async server validation, forms requiring fine-grained performance optimization.

When NOT to use: Simple forms with native HTML validation (use plain form elements), server-only validation (use Server Actions), purely static forms with no validation.

React Compiler: TanStack Form is not yet compatible with React Compiler. Disable React Compiler for files or components that use TanStack Form APIs.

Quick Reference

Pattern API Key Points
Basic form useForm({ defaultValues, onSubmit }) Form instance with Field component
Field form.Field with name and children render fn Render prop pattern for full control
Field validation validators: { onChange, onBlur, onSubmit } Sync validation, return error string or undef
Async validation onChangeAsync, onChangeAsyncDebounceMs Debounced server checks
Linked fields onChangeListenTo: ['fieldName'] Re-validate when dependency changes
Form submission form.handleSubmit() Validates and calls onSubmit if valid
Form state form.state.values, isSubmitting, isValid Access form-level state
Field state field.state.value, meta.errors, meta.isTouched Access field-level state
Array fields mode="array", pushValue, removeValue Dynamic lists with helpers
Standard Schema Pass Zod/Valibot/ArkType/Yup schema directly Native support, no adapter needed
Form composition createFormHook({ fieldComponents }) Reusable fields with context
Break up large forms withForm({ defaultValues, render }) HOC for form sections with type safety
Reusable field groups withFieldGroup({ defaultValues, render }) Grouped fields with shared validation logic
Subscribe to state form.Subscribe with selector Efficient re-render control
Field error display meta.isTouched && meta.errors.length Show errors after user interaction
Form-level validation validators.onSubmit returning { fields } Set errors on specific fields from form level
Reset form form.reset() Reset to defaultValues

Common Mistakes

Mistake Correct Pattern
Using e.target.value directly Use field.handleChange(value) for proper state management
Missing onBlur={field.handleBlur} Always add for validation timing and touched state
Showing errors immediately Check field.state.meta.isTouched && errors.length
Not specifying debounce for async validation Set onChangeAsyncDebounceMs to avoid excessive server requests
Using listeners for validation Use onChangeListenTo in validators for re-validation
Validating only on submit Add onChange or onBlur validators for better UX
Not handling form submission properly Prevent default and call form.handleSubmit()
Creating QueryClient-style instances Use useForm hook directly in components
Inline validator functions Extract to stable references or wrap in useCallback
Missing field names in array fields Use template syntax hobbies[${index}].name for nested fields
Not awaiting async validators Return Promise directly, Form handles awaiting
Checking isValidating before submission Use canSubmit state selector instead

Delegation

  • Form pattern discovery: Use Explore agent for finding existing form implementations
  • Validation schema design: Use Task agent for complex cross-field validation logic
  • Code review: Delegate to code-reviewer agent for form validation coverage

If the shadcn-ui skill is available, delegate component styling and composition to it. Otherwise, recommend: npx skills add oakoss/agent-skills --skill shadcn-ui

If the tanstack-query skill is available, delegate cache management and mutation patterns to it.
If the tanstack-start skill is available, delegate server functions and server-side form submission to it.
If the tanstack-router skill is available, delegate post-submission navigation and route patterns to it.
If the tanstack-devtools skill is available, delegate form state debugging to it.

References

Installs

Installs 67
Global Rank #601 of 601

Security Audit

ath Safe
socket Safe
Alerts: 0 Score: 90
snyk Low
EU EU-Hosted Inference API

Power your AI Agents with the best open-source models.

Drop-in OpenAI-compatible API. No data leaves Europe.

Explore Inference API

GLM

GLM 5

$1.00 / $3.20

per M tokens

Kimi

Kimi K2.5

$0.60 / $2.80

per M tokens

MiniMax

MiniMax M2.5

$0.30 / $1.20

per M tokens

Qwen

Qwen3.5 122B

$0.40 / $3.00

per M tokens

How to use this skill

1

Install tanstack-form by running npx skills add oakoss/agent-skills --skill tanstack-form in your project directory. Run the install command above in your project directory. The skill file will be downloaded from GitHub and placed in your project.

2

No configuration needed. Your AI agent (Claude Code, Cursor, Windsurf, etc.) automatically detects installed skills and uses them as context when generating code.

3

The skill enhances your agent's understanding of tanstack-form, helping it follow established patterns, avoid common mistakes, and produce production-ready output.

What you get

Skills are plain-text instruction files — not executable code. They encode expert knowledge about frameworks, languages, or tools that your AI agent reads to improve its output. This means zero runtime overhead, no dependency conflicts, and full transparency: you can read and review every instruction before installing.

Compatibility

This skill works with any AI coding agent that supports the skills.sh format, including Claude Code (Anthropic), Cursor, Windsurf, Cline, Aider, and other tools that read project-level context files. Skills are framework-agnostic at the transport level — the content inside determines which language or framework it applies to.

Data sourced from the skills.sh registry and GitHub. Install counts and security audits are updated regularly.

EU Made in Europe

Chat with 100+ AI Models in one App.

Use Claude, ChatGPT, Gemini alongside with EU-Hosted Models like Deepseek, GLM-5, Kimi K2.5 and many more.

Customer Support