- Reduce
intl
dependency constraint to match Flutter 3.16.0. - NumberValidator allows null values.
- Removed deprecated
onWillPop
fromReactiveForm
andReactiveFormBuilder
widgets. It was replaced with thePopScope
widget. Validators.number
allows now to define negative numbers and decimal numbers with the addition of two optional argumentsallowNegatives
andallowedDecimals
.
- Add
canPop
andonPopInvoked
toReactiveForm
andReactiveFormBuilder
widgets.
- Add default Context Menu to
ReactiveTextField
.
- Add
markAsPending()
method toAbstractControl
to allow set the status to PENDING by demand.
- Add missing properties to
ReactiveSwitchListTile.adaptative()
widget. - Add
showError()
toReactiveCheckbox
andReactiveCheckboxListTile
widgets. This does not display any error messages but it is now compatible with the Flutter builtin behavior of Checkboxes when Material 3 is enabled (ThemeData(useMaterial3: true)
) in the active App Theme.
- Update
Readme.md
file with testing examples in the sectionReactiveForm vs ReactiveFormBuilder which one?
- Fix an issue with
FormGroup
andFormArray
were recursiveRaw Value
was not working properly.
- Fix an issue with
FormBuilder
when trying to build a control with a nullable '?' data type. - Fix an issue with
FormGroup
that was not triggering the eventcollectionChanges
when a control is removed. - Fix an issue with
FormGroup
andFormArray
when trying to find a control with a nullable '?' data type.
- Update the intl dependency version, because in flutter 3.10,
flutter_localizations
depends on intl 0.18.0.
- Flutter >= 3.10 required for this version.
- Updated some documentation.
- Expose validator classes to allow direct instantiation.
- All validators have been changed to classes with
const
constructors. - The Asynchronous Validator is now a class from where any custom async validator can inherit.
- A new validator
Validators.delegate(...)
has been introduced to be used with a custom validation function. - A new validator
Validators.delegateAsync(...)
has been introduced to be used with a custom async validation functions.
- Fix the inkwell ripple effect in the ReactiveDropdownField.
- Add some other minor fixes.
- Update intl to latest version 0.18.0.
- Create new widget ReactiveFocusableFormField as a parent widget for all other widgets that requires to do focus management.
- The definition of validation messages is now more consistent.
- Methods like
onTab
inReactiveTextField
andonChanged
inReactiveDropdownField
now provides the control as argument of the callback.
- Add events like
onChanged
,onEditingComplete
to reactive widgets.
- Add widget ReactiveFormConfig to globally define validation messages at Flutter application level. This reliefs the need to define validation messages in each reactive widget.
- Upgrade example folder project to Flutter 3.0.0.
- Increase code coverage in FormArray.
- Reactive Forms is now migrated to Flutter 3.0.0.
- Update project to new Android wrappers in order to be able to run the example using latest Android SDK changes.
- Add Focus handling for several reactive widgets:
- ReactiveSlider
- ReactiveSwitch
- ReactiveRadio
- ReactiveRadioListTile
- ReactiveCheckbox
- ReactiveCheckboxListTile
- Small fix in the array_sample example application.
- Fix issues in ReactiveDatePicker when control value was before or after the range of firstDate and lastDate
- Add optional argument initialDate to the ReactiveDatePicker.
- Reactive Forms is now migrated to Flutter 2.8.0.
- Update reactive widgets with extra properties presents in Flutter 2.8.0.
- Expose TextEditingController as a property of the ReactiveTextField for text selection purposes only.
- Fix Async Validators that overrides validations errors from Sync Validators
- Improve Complex example in the demo application
- Improve the Array example in the demo application
- Better exception handler when creating FormGroups with controls that contains character '.' in the name of the control.
- Add an example of deleting item from a FormArray in the example folder project.
- Make public the previously private class InheritedStreamer
- Minor documentation fix.
- Add documentation of new advanced reactive widgets.
- Minor documentation fix.
- Converted ReactiveForm widget from Stateful to Stateless widget.
- Update the lint code analysis to use the las package lints.
- Minor internal code checks and improvements.
- Added optional argument to Validators.mustMatch that allows to define if we want to mark the matchingControlName control as DIRTY when the control is invalid. See related issue.
- Minor changes in model classes that allows to create custom AbstractControl implementations
- Added missing props pass through for widgets.
- Add minor internal changes for handling focus node in reactive text fields.
- Add Flutter sdk version restriction in pubspec.yaml file.
- Fix Validators.compare in release mode that has different behavior from debug mode.
- Add method in FormGroup that allows to remove a control by its name.
- Add missing extra properties to ReactiveRadioListTile and ReactiveRadio widgets.
- Add a SliderIntValueAccessor that allows ReactiveSlider to bind to controls of type int.
- Fix error when defining a ReactiveTextField with dynamic type and bound the widget with controls other than String.
- Add the optionally extra argument autoValidate to the method AbstractControl.setValidators to recalculate the validaity of the control after set the new validators without explicitly call updateValueAndValidity on that control.
- Add/Clear validators dynamically
- Fix error when defining a ReactiveTextField without specifying a model data type
- Change the data type of ValidatorFunction to returns Map<String, dynamic> instead of Map<String, Object>
- Fix exception when focus a control that does not exist in a group
- Better type definition in a control value accessor within a ReactiveFormField
- Set ReactiveTextField maxLines as optional nullable argument.
- Add minor changes in Validators.min and Validators.max for handlig type checks
- Add minor changes in ReactiveValueListenableBuilder for handlig type checks
- Fix the error when defining a ReactiveFormField (related to control value accessor)
- Reactive Forms is now migrated to Flutter 2.x.
- Reactive Forms is now Null-safety.
- New Definitions in Custom Reactive Widgets. ReactiveFormField now defines the data type of the model (control) and the data type of the view (widget).
- Validators.requiredTrue now has the 'requiredTrue' validation message and not 'requiredEquals' as in previous versions.
- Now you can specify a different validation message to the Validators.pattern validator.
- Add latest version of intl package
- Remove Validators String type to fix casts errors when calling form.control('').validators in a control with a non dynamic type validator.
- Add minor changes to successfully pass pub dev static analysis.
- Add Library documentation.
- An enhanced strongly typed system to improve casting at compilation time and improve casting exception handler in runtime. This version was created to be compatible with analysis options in "implicit-casts: false" and "implicit-dynamic: false".
- Code formatting issues
- Validators.pattern now validates against a RegExp instance.
- If a control is disabled, then it doesn't fire state change again when call markAsDisabled.
- Upgrade Reactive Forms to Flutter 1.20
- Add intl package and and optional argument to DateTimeValueAccessor to specify the format of the date.
- Add some extra properties to reactive forms widgets.
- Set cursor at the end of the text when set value to reactive text field from the FormControl.
- Exposes ReactiveSwitchListTile.
- Fix code formatting to pass pub static analysis.
- Expose focus controller of the FormControl. Now is possible to access UI FocusNode with in a control through control.focusController.focusNode.
- Add argument focusNode to ReactiveTextField to provide a custom FocusNode.
- Add some improvement to TimeOfDayValueAccessor.
- Add some improvement to example application.
- A disabled ReactiveDropdownField now tale into account the selectedItemBuilder method to show the disabledHint.
- More complete example app project inside Reactive Forms.
- Add FormGroup.rawValue and FormArray.rawValue to get the value of groups and array including any disabled controls.
- Fix exception when call FormGroup.addAll in a sub-group with parent.
- Add method patchValue to FormControl, FormGroup and FormArray to update partially the control value.
- Add Validators.any that requires any element of the control's iterable value satisfies a test function.
- Update value accessors in reactive widgets when widget didUpdateWidget.
- Add readOnly argument as not nullable in ReactiveDropdownField.
- Add readOnly argument in ReactiveDropdownField constructor to enable/disable widget.
- Add documentation about customizing when to show errors in reactive widgets.
- Dispose FocusNode after FocusNodeController is disposed.
- Improves code documentation for control, group and array constructors.
- Add async validators to FormGroup and FormArray.
- Add disabled optional argument to FormArrayConstructor.
- Fix now AbstractControl.removeError doesn't marks the control as dirty by default.
- Fix Validators.compare in DateTime controls type.
- Initialize a FormGroup as disabled is now possible with optional constructor argument.
- Fix Validators.maxLength and Validators.minLength when control value is null.
- Add new control value accessor Iso8601DateTimeValueAccessor that brings the possibility to bind a ReactiveDateTimePicker widget to a control of type String.
- Fix when the execution of asynchronous validators completes the control is not marked as dirty.
- Add new AbstractControl validator Validators.contains.
- Fix Validators.minLength and Validators.maxLength with FormControls of type dynamic when a value is a String.
- Change ReactiveFormField.validationMessages from a Map to a Function that receives the instance of the control and returns the Map with the customized validation messages. This upgrade now brings the possibility to dynamically change the validation messages based on the current error data.
- Change Validators.email response error Map. Now returns the current control value instead of true.
- Add AbstractControl.hasError(...) for asking if a control has an error based on error code and children path.
- Add AbstractControl.getError(...) to get error data based on error code and children path.
- Fix error when trying to get a deep control within an array of groups.
- Fix minor issues
- Fix some typos.
- Fix ReactiveDatePicker error when lastDate is previous to DateTime.now() and control value is null.
- FormArray.removeAt now returns the removed control.
- Improve code documentation.
- Add more tests.
- Add more strict data types in arguments.
- Add extra arguments to AbstractControl.setErrors and AbstractControl.removeError to marks the control as dirty or pristine.
- Refactor Validators.minLength and Validators.maxLength to be use with:
- FormArray
- FormControl of type Iterable
- FormControl of type String
- FormGroup
- Add better data types definition in FormBuilder.array declaration.
- Add arguments emitEvent and updateParent to FormArray.clear() method.
- Changes all arguments of data type Iterable with List data type to force compiler errors when not correctly cast MappedListIterable with List.
- Fix control value accessor that doesn't update the control when LengthLimitingTextInputFormatter reached the max length.
- Fix error when dispose a FocusController already registered in a control.
- Add big refactor in focus handlers of a FormControl. Change argument data type in FormControl.focusChanges event, from FocusEvent to bool.
- Fix infinity loop that freeze apps when two or more ReactiveTextField were binded to the same FormControl and changing focus between them.
- Fix FormGroup.addAll now updates group pristine/dirty state of the group and trigger FormControlCollection.collectionChanges event.
- Add FormArray.clear() that remove all children controls of the array.
- Add optionally argument showErrors to ReactiveTextField and ReactiveDropdownField to customize when to show up validations messages. Validation messages by default change to visible when control is invalid and touched. With showErrors function this default behavior can be customized.
- Rename FormControl.focused by FormControl.hasFocus.
- Change ReactiveFormBuilder.builder(context) by ReactiveFormBuilder.builder().
- Change argument in FormControl.focusChanges event from bool to FocusEvent.
- Add FormGroup.unfocus() and FormArray.unfocus() to remove focus of children controls.
- Add FormArray.focus(String name) to set focus on a control.
- Add optional argument to AbstractControl.unfocus(bool touched) to mark controls as untouched when remove focus.
- Add optional argument to AbstractControl.reset(bool removeFocus) to remove focus on control when reset the control/form/array.
- Fix ReactiveFormBuilder initializations in debug mode.
- Fix add custom valueAccessor to text field.
- Fix Validators.min and Validators.max with non comparable controls.
- Rename touch() and untouch() by markAsTouched() and markAsUntouched()
- Rename enable() and disable() by markAsEnabled() and markAsDisabled()
- Add AbstractControl.markAllAsTouched to mark all controls of a FromGroup or a FormArray as touched. AbstractControl.markAsTouched doesn't marks children as touched anymore.
- Validators.compose now act as and AND and returns a ValidatorFunction instead of a List of ValidatorFunction
- InputParsers have been replaced by ControlValueAccessor.
- Add new control status pristine and dirty.
- FormGroup.control(String name) and FormArray.control(String name) now let specify the name argument as a dot-delimited string that represents the path to the nested control as nested1.nested2.nested.3.etc.
- Add FormBuilder.array() and FormBuilder.control() for creating arrays and controls.
- ReactiveValueListenableBuilder brings now the possibility to provide directly the control instead of just the control name.
- Add Validators.composeOR to combines multiples validators in one and evaluates as an OR, if at least one validator evaluates to VALID then the control is valid.
- Add ControlValueAccessor to convert value data types from UI to model and vice versa.
- Add FormGroup.focus(String name) to set focus to a child control.
- Add ReactiveFormBuilder useful for defining a FormGroup and a ReactiveForm at the same time in a stateless widget.
- Add validators:
- Validators.requiredTrue
- Validators.equals
- Validators.min
- Validators.max
- Validators.composeOR
- Validators.compare
- ReactiveRadioListTile widget is now available.
- Fix FormBuilder.group() with initial value in null.
- Add FormBuilder.state to create a ControlState.
- Fix async update in InheritedStreamer widget that raised exception when declare a form group in a stateless widget.
- FormControl.reset() can now set the disabled status of the control as an optional argument.
- Implements FormGroup.resetState() and FormArray.resetState() to reset children controls with initial value and disabled status.
- FormControl constructor receives value instead of defaultValue. To reset a control to a initial value you must call FormControl.reset() and supply initial value.
- Fix Luhn algorithm in credit card validator.
-
Fixes:
- FormGroup.reset() marks control as untouched and hide UI validation errors.
- FormGroup.reset() sets empty string to input text fields if control value is null.
-
Features:
- InputParser added to ReactiveTextField. Now you can declare a FormControl with int or double data type and bind it to an input text field.
- Fixed card number length in Validators.creditCard
- Minor changes and code documentation.
- New Validator
- *Validators.creditCard* that validates a credit card number using the Luhn algorithm.
- Optimized FormGroup and FormArray value gets.
- FormBuilder docs added to README.md
- fixed ReactiveDropdownField.onChanged not triggered when control value didn't changes
- Minor fixes in ReactiveDropdownField.
- Minor fixes.
- Added basic implementation of FormBuilder to build FormGroup easily.
- Added onChanged callback to ReactiveDropdownField.
- Now ReactiveDropdownField not set value of control to null when no matching item founded.
- Added onWillPop to ReactiveForm widget.
- Enable/disable controls, groups and arrays.
- Now you can access the parent group or array with the property FormControl.parent.
- Removed restriction of empty item's array in ReactiveDropdown.
- Assert error in ReactiveDropdown when control value not match any item values.
- Slider assert error when control bounded to slider initialize in null value.
- Use of Streams to notify events.
- Renamed event names.
See Migration Guide to see how to migrate from version 1.x to 2.x.
- Async validators now have a debounce timer in milliseconds that can be passed as argument to FormControl. This is useful for example to reduce requests to an API.
- Now you can optionally pass a FormControl directly to reactive widgets instead of the control's name. You must provide a formControlName or a formControl but not both at the same time.
- Set value an array value to FormArray insert missing items
- Composing validators with Validators.compose
- Added optionally type to ReactiveFormArray widget
- Added utilities an extensions to AbstractControl
- AbstractControl.isNull
- AbstractControl.isNullOrEmpty for controls of type String
- Minor fixes
- FormArray and FormGroup now notify value changes when a control without validators changes its value.
-
FormGroup.touch mask all controls as touched.
-
Renamed FormGroup.formControl to FormGroup.control and FormArray.formControl to FormArray.control to get controls by name.
-
ReactiveValueListenableBuilder.builder now pass the control as parameter instead of the value so you can get access to the control within the builder function.
-
Added FormGroup.controls and FormArray.controls to iterate over child controls.
-
Bonus widgets:
- ReactiveDatePicker
- ReactiveTimePicker
- Fixed ReactiveCheckbox and ReactiveCheckboxListTile exception when binding with FormControl with null value.
- Increased code tests coverage to 92% (a lot of tests).
- FormArray.removeAt method added to remove a control given the index position.
- Added ReactiveTextField.onSubmitted for an example of how to handle moving to the next/previous field when using TextInputAction.next and TextInputAction.previous for textInputAction.
- Included property ReactiveSwitchListTile.inactiveThumbImage.
- Included properties autofocus to ReactiveCheckbox, ReactiveRadio and ReactiveSwitch.
- Included callbacks ReactiveSlider.onChangeEnd and ReactiveSlider.onChangeStart.
- FormArray now correctly notify status depending of children status.
- Async Validators (only FormControl for now...)
- Controls have now three different states: VALID, INVALID, PENDING (this last one was specially included due to async validators, the control is PENDING until validator completes)
- Added documentations about Validator.pattern
- Added Async Validator's example in example application /example/main.dart.
- FormArray (aggregates the values of each child FormControl into an array)
- ReactiveFormArray
- ReactiveCheckboxListTile
- ReactiveSwitchListTile
- ReactiveRadioListTile
- ReactiveStatusListenableBuilder
- Added class ValidationMessage for common validation messages key as: required, email, etc.
- Added Documentation of ValidationMessage.
- Minor typo fix in documentation text.
- Added an example application
- Validators.required
- Validators.email
- Validators.number
- Validators.minLength
- Validators.maxLength
- Validators.pattern
- ReactiveTextField
- ReactiveDropdownField
- ReactiveSwitch
- ReactiveCheckbox
- ReactiveRadio
- ReactiveSlider
- ReactiveForm
- ReactiveFormConsumer
- ReactiveValueListenableBuilder