Changelog
All notable changes to the el-form project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
[3.11.0] - 2026-06-05
Released: el-form-react-hooks@3.11.0, el-form-react-components@4.5.0,
el-form-core@2.3.0, el-form-react@4.1.5.
✨ New Feature — el-form-react-hooks@3.11.0
useFieldArray: a new hook for dynamic array fields. Returns afieldsarray where each row carries a stableidto use as the Reactkey(fixing thekey={index}anti-pattern that breaks focus and values when rows are inserted, reordered, or removed from the middle), plusappend,prepend,insert,remove,move,swap,update, andreplace. Works inside<FormProvider>(re-renders only when its array changes) or with aformprop.nameis type-restricted to array-valued paths and item types are inferred. See the Array Fields guide.- Optional
keyName(default"id") lets items that already have a domainidfield choose a non-colliding key (e.g.keyName: "_key") so the generated row key never shadows their data. - The existing
addArrayItem/removeArrayItemhelpers are unchanged (now backed by a shared array engine). Fully backward-compatible — additive only.
- Optional
🆕 New API — el-form-react-hooks updateValue
updateValue(path, updater): apply a functional update to a field against the latest state (e.g.updateValue("items", (prev) => [...prev, item])). Avoids the stale-snapshot "lost update" pitfall when several updates run in one event handler.useFieldArrayuses this internally so multiple synchronous operations all apply correctly.
♿ Accessibility
- AutoForm and the standalone
TextField/TextareaField/SelectFieldare now accessible by default. Inputs wirearia-invalid,aria-describedby(pointing at the error element), andaria-required; field errors render withrole="alert"so screen readers announce them. No markup changes required in your code. - Focus-on-error:
useFormgainsshouldFocusError(defaulttrue). After a failed submit, focus moves to the first invalid field. To opt out:useForm({ shouldFocusError: false }). (registernow also returns aref, which is what makessetFocus/focus-on-error work.) - Fix: the standalone field components now show validation errors on the first blur. They previously could lag one render behind because they read form state through the context getter; they now subscribe via
useField.
⏱️ Validation debounce
validationDebounceMs: new config to debounce synchronous validation, at both form and field level (default0= validate every change, unchanged). Mirrors the existingasyncDebounceMs. Example:useForm({ validators: { onChange: schema, validationDebounceMs: 200 } }).
2026-06-01
🐞 Bug Fixes — el-form-react-hooks@3.10.2
handleSubmitnow blocks submission when a configuredvalidators.onChange(oronBlur) validator fails. Previously onlyvalidators.onSubmitgated submit, so a form validating on change could still submit invalid data. Forms following the quick-start (validators: { onChange: schema }) are now correctly blocked on invalid input.trigger()now writes validation errors intoformState.errors(and updatesisValid) so the UI reflects them, matching React Hook Form. Previously it returned the correct boolean but leftformStateuntouched.
🆕 New Package — el-form-mcp@0.1.0
el-form-mcp: a Model Context Protocol server that gives AI coding agents accurate El Form knowledge and code generation. Run it withnpx el-form-mcp. See the MCP Server guide.- Tools:
el_form_overview,el_form_list_topics,el_form_get_topic,el_form_search, andel_form_scaffold_form(generates AutoForm/useForm code plus a matching Zod schema from a field list). - Machine-readable docs also published at
/llms.txtand/llms-full.txt.
- Tools:
🔧 Maintenance
el-form-core@2.2.1,el-form-react-components@4.4.2,el-form-react@4.1.4: repaired the release pipeline (CSS build no longer usespnpm dlx;el-form-coretest script no longer hangs CI) and added a committed test suite foruseFormbehavior + a pre-launch example-app sweep.
[4.2.0] - 2025-08-24
✨ Changes
- FormSwitch (anchored API):
valuestuple is now optional. Provide a readonly tuple (as const) to enable compile-time duplicate detection and exhaustiveness checks. No breaking changes.
[4.1.0] - 2025-08-16
✨ New Features
-
Selector-based subscriptions to minimize re-renders
- New hooks in
el-form-react-hooks:useFormSelector(selector, equality?): subscribe to a selected slice of form stateuseField(path): subscribe to{ value, error, touched }for a field path
- Export
shallowEqualfor common array/object selector equality - SSR-safe snapshots: server snapshot equals client initial selector result
- New hooks in
-
FormSwitchoptimization (inel-form-react-components)- New props:
field?: Path<T>andselect?: (state) => string | number | boolean - Re-renders only when the discriminator changes
- Deprecated (back-compat for one minor):
onandformprops; dev-onlyconsole.warn
- New props:
🧪 Examples & Tests
- Added examples under
examples/react/testsdemonstratingfield,select, back-compat, anduseFieldre-render isolation - Added unit tests for selector subscriptions and
FormSwitchruntime behavior
📚 Docs
- Updated
Conditional Rendering (FormSwitch)guide to preferfield/select - Updated
Field Components APIfor newFormSwitchprops - Updated
useFormAPI with selector subscription guidance andshallowEqualnote - Updated
useFormAPI to reflect strictregister<Name extends Path<T>>typing (no string fallback). Invalid paths now error; array paths are supported when valid.
[4.0.0] - 2025-08-12
⚠️ Breaking
- Require
zod@^4.0.0. If you are on Zod 3, upgrade withpnpm add zod@^4.
✨ Changes
- Internal: Zod 4 introspection (no breaking surface changes to AutoForm/useForm APIs).
- Discriminated unions: more robust introspection; behavior unchanged for users.
- TypeScript:
useForm.registeris now type-safe for known paths- Literal field names and dot-paths infer exact field value type and return the appropriate props (
value,checked, orfiles). - Dynamic string paths remain supported and return a broadly-typed object to preserve backwards compatibility (no app code changes required).
- Other APIs now accept typed paths where applicable:
setValue,watch,resetField.
- Literal field names and dot-paths infer exact field value type and return the appropriate props (
[3.6.0] - 2025-08-06
✨ New Features
- Pre-compiled CSS Support: Added optional pre-compiled Tailwind CSS for zero-configuration styling
- Import
"el-form-react-components/styles.css"for instant beautiful forms - No Tailwind CSS installation required for end users
- Backwards compatible - existing Tailwind class approach continues to work
- 31KB minified CSS with semantic
.el-form-*classes - Professional gradient buttons, rounded inputs, focus states, and error styling
- Import
Previous Releases
File Upload Support (v3.3.0+)
- Native file input support with zero configuration
- File validation system with preset validators (image, document, avatar, gallery)
- Zod schema integration for file validation (z.instanceof(File))
- File management methods (addFile, removeFile, clearFiles)
- Automatic file preview generation
- Support for single and multiple file inputs
AutoForm Style Props (v3.4.0+)
- Enhanced styling capabilities for AutoForm components
- Better customization options
Cross-Package Navigation (v3.5.0+)
- Added comparison table to help users choose the right package
- Clear warnings about styling dependencies for AutoForm components
- Direct users to el-form-react-hooks for custom styling needs
- Better onboarding to reduce confusion about package selection
Migration Guide
Upgrading to Latest Version
No breaking changes in recent releases. All updates are backwards compatible.
For detailed technical changelogs, see individual package CHANGELOG.md files.