From 552a7acdc32d9ed514489a398b48ce99fc2567b4 Mon Sep 17 00:00:00 2001 From: Joan Pablo Date: Fri, 29 Mar 2024 12:02:24 -0400 Subject: [PATCH] Update Flutter dependencies - Update Reactive Forms version to 17.0 - Update Flutter version >=3.16.0 - Update Dart version >=3.2.4 <4.0.0 - Replace deprecated WillPopScope with PopScope - Fix the use super parameters --- example/lib/sample_screen.dart | 3 +- .../samples/add_dynamic_controls_sample.dart | 4 +- example/pubspec.yaml | 14 ++--- lib/src/models/models.dart | 51 +++++++------------ lib/src/widgets/inherited_streamer.dart | 4 +- lib/src/widgets/reactive_checkbox.dart | 12 ++--- .../widgets/reactive_checkbox_list_tile.dart | 12 ++--- lib/src/widgets/reactive_date_picker.dart | 9 ++-- lib/src/widgets/reactive_dropdown_field.dart | 18 +++---- lib/src/widgets/reactive_form.dart | 13 ++--- lib/src/widgets/reactive_form_array.dart | 5 +- lib/src/widgets/reactive_form_builder.dart | 4 +- lib/src/widgets/reactive_form_config.dart | 6 +-- lib/src/widgets/reactive_form_consumer.dart | 4 +- lib/src/widgets/reactive_form_field.dart | 5 +- lib/src/widgets/reactive_form_pop_scope.dart | 30 ----------- lib/src/widgets/reactive_radio.dart | 12 ++--- lib/src/widgets/reactive_radio_list_tile.dart | 12 ++--- lib/src/widgets/reactive_slider.dart | 12 ++--- .../reactive_status_listenable_builder.dart | 5 +- lib/src/widgets/reactive_switch.dart | 24 +++------ .../widgets/reactive_switch_list_tile.dart | 24 +++------ lib/src/widgets/reactive_text_field.dart | 21 +++----- lib/src/widgets/reactive_time_picker.dart | 9 ++-- .../reactive_value_listenable_builder.dart | 5 +- pubspec.yaml | 9 ++-- ...ive_checkbox_list_tile_testing_widget.dart | 4 +- .../reactive_checkbox_testing_widget.dart | 4 +- .../reactive_date_picker_testing_widget.dart | 4 +- .../reactive_dropdown_testing_widget.dart | 4 +- .../reactive_form_array_testing_widget.dart | 4 +- .../reactive_form_builder_testing_widget.dart | 4 +- ...reactive_form_consumer_testing_widget.dart | 4 +- ...active_radio_list_tile_testing_widget.dart | 4 +- .../reactive_radio_testing_widget.dart | 4 +- .../reactive_slider_testing_widget.dart | 4 +- ...tus_listenable_builder_testing_widget.dart | 4 +- ...ctive_switch_list_tile_testing_widget.dart | 4 +- .../reactive_switch_testing_widget.dart | 4 +- .../reactive_text_field_testing_widget.dart | 4 +- .../reactive_time_picker_testing_widget.dart | 4 +- ...lue_listenable_builder_testing_widget.dart | 4 +- 42 files changed, 140 insertions(+), 251 deletions(-) delete mode 100644 lib/src/widgets/reactive_form_pop_scope.dart diff --git a/example/lib/sample_screen.dart b/example/lib/sample_screen.dart index 8aff4871..a168e88b 100644 --- a/example/lib/sample_screen.dart +++ b/example/lib/sample_screen.dart @@ -5,8 +5,7 @@ class SampleScreen extends StatelessWidget { final Widget body; final Widget? title; - const SampleScreen({Key? key, required this.body, this.title}) - : super(key: key); + const SampleScreen({super.key, required this.body, this.title}); @override Widget build(BuildContext context) { diff --git a/example/lib/samples/add_dynamic_controls_sample.dart b/example/lib/samples/add_dynamic_controls_sample.dart index fc34097e..48ed0aea 100644 --- a/example/lib/samples/add_dynamic_controls_sample.dart +++ b/example/lib/samples/add_dynamic_controls_sample.dart @@ -7,8 +7,8 @@ class ViewModelProvider extends InheritedWidget { ViewModelProvider({ required this.viewModel, - required Widget child, - }) : super(child: child); + required super.child, + }); static NewContactViewModel? of(BuildContext context) => context.findAncestorWidgetOfExactType()?.viewModel; diff --git a/example/pubspec.yaml b/example/pubspec.yaml index 9dcfa6c8..1718e6fc 100644 --- a/example/pubspec.yaml +++ b/example/pubspec.yaml @@ -18,34 +18,30 @@ publish_to: 'none' # Remove this line if you wish to publish to pub.dev version: 1.0.0+1 environment: - sdk: ">=2.17.0 <3.0.0" - flutter: ">=3.0.0" + sdk: ">=3.2.4 <4.0.0" + flutter: ">=3.16.0" dependencies: flutter: sdk: flutter - intl: ^0.18.0 + intl: ^0.19.0 reactive_forms: path: ../ #reactive_forms_widgets: ^0.3.1 # The following adds the Cupertino Icons font to your application. # Use with the CupertinoIcons class for iOS style icons. - cupertino_icons: ^1.0.5 + cupertino_icons: ^1.0.6 #reactive_dropdown_search: ^0.9.0 #reactive_touch_spin: ^0.6.0 #reactive_segmented_control: ^0.4.0 #reactive_date_time_picker: ^0.4.0 dev_dependencies: - lints: ^2.0.0 + flutter_lints: ^3.0.2 flutter_test: sdk: flutter -dependency_overrides: - reactive_forms: - path: ../ - # For information on the generic Dart part of this file, see the # following page: https://dart.dev/tools/pub/pubspec diff --git a/lib/src/models/models.dart b/lib/src/models/models.dart index 0040ea71..9d809f32 100644 --- a/lib/src/models/models.dart +++ b/lib/src/models/models.dart @@ -833,18 +833,12 @@ class FormControl extends AbstractControl { /// FormControl({ T? value, - List> validators = const [], - List> asyncValidators = const [], - int asyncValidatorsDebounceTime = 250, - bool touched = false, - bool disabled = false, - }) : super( - validators: validators, - asyncValidators: asyncValidators, - asyncValidatorsDebounceTime: asyncValidatorsDebounceTime, - disabled: disabled, - touched: touched, - ) { + super.validators, + super.asyncValidators, + super.asyncValidatorsDebounceTime, + super.touched, + super.disabled, + }) { if (value != null) { this.value = value; } else { @@ -1039,16 +1033,11 @@ class FormControl extends AbstractControl { /// that emits events each time you add or remove a control to the collection. abstract class FormControlCollection extends AbstractControl { FormControlCollection({ - List> validators = const [], - List> asyncValidators = const [], - int asyncValidatorsDebounceTime = 250, - bool disabled = false, - }) : super( - validators: validators, - asyncValidators: asyncValidators, - asyncValidatorsDebounceTime: asyncValidatorsDebounceTime, - disabled: disabled, - ); + super.validators, + super.asyncValidators, + super.asyncValidatorsDebounceTime, + super.disabled, + }); final _collectionChanges = StreamController>>.broadcast(); @@ -1156,17 +1145,14 @@ class FormGroup extends FormControlCollection> { /// See also [AbstractControl.validators] FormGroup( Map> controls, { - List> validators = const [], - List> asyncValidators = const [], - int asyncValidatorsDebounceTime = 250, + super.validators, + super.asyncValidators, + super.asyncValidatorsDebounceTime, bool disabled = false, }) : assert( !controls.keys.any((name) => name.contains(_controlNameDelimiter)), 'Control name should not contain dot($_controlNameDelimiter)'), super( - validators: validators, - asyncValidators: asyncValidators, - asyncValidatorsDebounceTime: asyncValidatorsDebounceTime, disabled: disabled, ) { addAll(controls); @@ -1670,14 +1656,11 @@ class FormArray extends FormControlCollection> { /// See also [AbstractControl.validators] FormArray( List> controls, { - List> validators = const [], - List> asyncValidators = const [], - int asyncValidatorsDebounceTime = 250, + super.validators, + super.asyncValidators, + super.asyncValidatorsDebounceTime, bool disabled = false, }) : super( - validators: validators, - asyncValidators: asyncValidators, - asyncValidatorsDebounceTime: asyncValidatorsDebounceTime, disabled: disabled, ) { addAll(controls); diff --git a/lib/src/widgets/inherited_streamer.dart b/lib/src/widgets/inherited_streamer.dart index 7203a7e0..15f27360 100644 --- a/lib/src/widgets/inherited_streamer.dart +++ b/lib/src/widgets/inherited_streamer.dart @@ -7,8 +7,8 @@ import 'dart:async'; import 'package:flutter/material.dart'; abstract class InheritedStreamer extends InheritedWidget { - const InheritedStreamer(this.stream, Widget child, {Key? key}) - : super(key: key, child: child); + const InheritedStreamer(this.stream, Widget child, {super.key}) + : super(child: child); final Stream stream; diff --git a/lib/src/widgets/reactive_checkbox.dart b/lib/src/widgets/reactive_checkbox.dart index 42cc0541..b47ad73d 100644 --- a/lib/src/widgets/reactive_checkbox.dart +++ b/lib/src/widgets/reactive_checkbox.dart @@ -21,9 +21,9 @@ class ReactiveCheckbox extends ReactiveFocusableFormField { /// For documentation about the various parameters, see the [Checkbox] class /// and the [Checkbox] constructor. ReactiveCheckbox({ - Key? key, - String? formControlName, - FormControl? formControl, + super.key, + super.formControlName, + super.formControl, bool tristate = false, Color? activeColor, Color? checkColor, @@ -36,16 +36,12 @@ class ReactiveCheckbox extends ReactiveFocusableFormField { MaterialStateProperty? fillColor, MaterialStateProperty? overlayColor, double? splashRadius, - FocusNode? focusNode, + super.focusNode, OutlinedBorder? shape, BorderSide? side, ReactiveFormFieldCallback? onChanged, ShowErrorsFunction? showErrors, }) : super( - key: key, - formControl: formControl, - formControlName: formControlName, - focusNode: focusNode, showErrors: showErrors ?? (control) => control.invalid && (control.dirty || control.touched), diff --git a/lib/src/widgets/reactive_checkbox_list_tile.dart b/lib/src/widgets/reactive_checkbox_list_tile.dart index 3417d22f..a350de75 100644 --- a/lib/src/widgets/reactive_checkbox_list_tile.dart +++ b/lib/src/widgets/reactive_checkbox_list_tile.dart @@ -21,9 +21,9 @@ class ReactiveCheckboxListTile extends ReactiveFocusableFormField { /// For documentation about the various parameters, see the [CheckboxListTile] /// class and the [CheckboxListTile] constructor. ReactiveCheckboxListTile({ - Key? key, - String? formControlName, - FormControl? formControl, + super.key, + super.formControlName, + super.formControl, Color? activeColor, Color? checkColor, Widget? title, @@ -40,7 +40,7 @@ class ReactiveCheckboxListTile extends ReactiveFocusableFormField { Color? tileColor, ShapeBorder? shape, VisualDensity? visualDensity, - FocusNode? focusNode, + super.focusNode, bool? enableFeedback, OutlinedBorder? checkboxShape, BorderSide? side, @@ -54,10 +54,6 @@ class ReactiveCheckboxListTile extends ReactiveFocusableFormField { ValueChanged? onFocusChange, ShowErrorsFunction? showErrors, }) : super( - key: key, - formControl: formControl, - formControlName: formControlName, - focusNode: focusNode, showErrors: showErrors ?? (control) => control.invalid && (control.dirty || control.touched), diff --git a/lib/src/widgets/reactive_date_picker.dart b/lib/src/widgets/reactive_date_picker.dart index 318e090f..644cf67e 100644 --- a/lib/src/widgets/reactive_date_picker.dart +++ b/lib/src/widgets/reactive_date_picker.dart @@ -55,9 +55,9 @@ class ReactiveDatePicker extends ReactiveFormField { /// For documentation about the various parameters, see the [showTimePicker] /// function parameters. ReactiveDatePicker({ - Key? key, - String? formControlName, - FormControl? formControl, + super.key, + super.formControlName, + super.formControl, required ReactiveDatePickerBuilder builder, required DateTime firstDate, required DateTime lastDate, @@ -82,9 +82,6 @@ class ReactiveDatePicker extends ReactiveFormField { TextInputType? keyboardType, Offset? anchorPoint, }) : super( - key: key, - formControl: formControl, - formControlName: formControlName, builder: (ReactiveFormFieldState field) { return builder( field.context, diff --git a/lib/src/widgets/reactive_dropdown_field.dart b/lib/src/widgets/reactive_dropdown_field.dart index 353a37e7..cab9f763 100644 --- a/lib/src/widgets/reactive_dropdown_field.dart +++ b/lib/src/widgets/reactive_dropdown_field.dart @@ -25,13 +25,13 @@ class ReactiveDropdownField extends ReactiveFocusableFormField { /// For more information about all various parameters, /// see [DropdownButtonFormField] constructor. ReactiveDropdownField({ - Key? key, - String? formControlName, - FormControl? formControl, - FocusNode? focusNode, + super.key, + super.formControlName, + super.formControl, + super.focusNode, required List> items, - Map? validationMessages, - ShowErrorsFunction? showErrors, + super.validationMessages, + super.showErrors, DropdownButtonBuilder? selectedItemBuilder, Widget? hint, InputDecoration decoration = const InputDecoration(), @@ -58,12 +58,6 @@ class ReactiveDropdownField extends ReactiveFocusableFormField { ReactiveFormFieldCallback? onChanged, }) : assert(itemHeight == null || itemHeight > 0), super( - key: key, - formControl: formControl, - formControlName: formControlName, - validationMessages: validationMessages, - showErrors: showErrors, - focusNode: focusNode, builder: (ReactiveFormFieldState field) { final effectiveDecoration = decoration.applyDefaults( Theme.of(field.context).inputDecorationTheme, diff --git a/lib/src/widgets/reactive_form.dart b/lib/src/widgets/reactive_form.dart index 979f3a2a..7ac25081 100644 --- a/lib/src/widgets/reactive_form.dart +++ b/lib/src/widgets/reactive_form.dart @@ -5,7 +5,6 @@ import 'package:flutter/material.dart'; import 'package:reactive_forms/reactive_forms.dart'; import 'package:reactive_forms/src/widgets/form_control_inherited_notifier.dart'; -import 'package:reactive_forms/src/widgets/reactive_form_pop_scope.dart'; /// This class is responsible for create a [FormControlInheritedStreamer] for /// exposing a [FormGroup] to all descendants widgets. @@ -29,12 +28,12 @@ class ReactiveForm extends StatelessWidget { /// /// The [formGroup] and [child] arguments are required. const ReactiveForm({ - Key? key, + super.key, required this.formGroup, required this.child, this.canPop, this.onPopInvoked, - }) : super(key: key); + }); /// Returns the nearest model up its widget tree. /// @@ -64,9 +63,11 @@ class ReactiveForm extends StatelessWidget { control: formGroup, stream: formGroup.statusChanged, child: canPop != null || onPopInvoked != null - ? ReactiveFormPopScope( - canPop: canPop, - onPopInvoked: onPopInvoked, + ? PopScope( + canPop: canPop != null ? canPop!(formGroup) : true, + onPopInvoked: onPopInvoked != null + ? (didPop) => onPopInvoked!(formGroup, didPop) + : null, child: child, ) : child, diff --git a/lib/src/widgets/reactive_form_array.dart b/lib/src/widgets/reactive_form_array.dart index 3f5de0b6..0ccf2f73 100644 --- a/lib/src/widgets/reactive_form_array.dart +++ b/lib/src/widgets/reactive_form_array.dart @@ -33,7 +33,7 @@ class ReactiveFormArray extends StatefulWidget { /// subtree does not depend on the value of the [FormArray] that is bind /// with this widget. const ReactiveFormArray({ - Key? key, + super.key, required this.builder, this.formArrayName, this.formArray, @@ -41,8 +41,7 @@ class ReactiveFormArray extends StatefulWidget { }) : assert( (formArrayName != null && formArray == null) || (formArrayName == null && formArray != null), - 'Must provide a formArrayName or a formArray, but not both at the same time.'), - super(key: key); + 'Must provide a formArrayName or a formArray, but not both at the same time.'); @override ReactiveFormArrayState createState() => ReactiveFormArrayState(); diff --git a/lib/src/widgets/reactive_form_builder.dart b/lib/src/widgets/reactive_form_builder.dart index d1913875..ee9988ee 100644 --- a/lib/src/widgets/reactive_form_builder.dart +++ b/lib/src/widgets/reactive_form_builder.dart @@ -51,13 +51,13 @@ class ReactiveFormBuilder extends StatefulWidget { /// } /// ``` const ReactiveFormBuilder({ - Key? key, + super.key, required this.form, required this.builder, this.canPop, this.onPopInvoked, this.child, - }) : super(key: key); + }); @override ReactiveFormBuilderState createState() => ReactiveFormBuilderState(); diff --git a/lib/src/widgets/reactive_form_config.dart b/lib/src/widgets/reactive_form_config.dart index f90ea389..fc4028fa 100644 --- a/lib/src/widgets/reactive_form_config.dart +++ b/lib/src/widgets/reactive_form_config.dart @@ -33,10 +33,10 @@ class ReactiveFormConfig extends InheritedWidget { /// ); /// ``` const ReactiveFormConfig({ - required Widget child, + required super.child, required this.validationMessages, - Key? key, - }) : super(child: child, key: key); + super.key, + }); @override bool updateShouldNotify(covariant ReactiveFormConfig oldWidget) { diff --git a/lib/src/widgets/reactive_form_consumer.dart b/lib/src/widgets/reactive_form_consumer.dart index e0e51309..f9159968 100644 --- a/lib/src/widgets/reactive_form_consumer.dart +++ b/lib/src/widgets/reactive_form_consumer.dart @@ -36,10 +36,10 @@ class ReactiveFormConsumer extends StatelessWidget { /// subtree does not depend on the value of the [FormGroup] that is bind /// with this widget. const ReactiveFormConsumer({ - Key? key, + super.key, required this.builder, this.child, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/lib/src/widgets/reactive_form_field.dart b/lib/src/widgets/reactive_form_field.dart index 8a0db6f1..35b7366a 100644 --- a/lib/src/widgets/reactive_form_field.dart +++ b/lib/src/widgets/reactive_form_field.dart @@ -61,7 +61,7 @@ class ReactiveFormField extends StatefulWidget { /// /// The [builder] arguments are required. ReactiveFormField({ - Key? key, + super.key, this.formControl, this.formControlName, this.valueAccessor, @@ -73,8 +73,7 @@ class ReactiveFormField extends StatefulWidget { (formControlName != null && formControl == null) || (formControlName == null && formControl != null), 'Must provide a formControlName or a formControl, but not both at the same time.'), - _builder = builder, - super(key: key); + _builder = builder; @override ReactiveFormFieldState createState() => diff --git a/lib/src/widgets/reactive_form_pop_scope.dart b/lib/src/widgets/reactive_form_pop_scope.dart deleted file mode 100644 index 51f9b1c4..00000000 --- a/lib/src/widgets/reactive_form_pop_scope.dart +++ /dev/null @@ -1,30 +0,0 @@ -import 'package:flutter/material.dart'; -import 'package:reactive_forms/reactive_forms.dart'; - -class ReactiveFormPopScope extends StatelessWidget { - final bool Function(FormGroup formGroup)? canPop; - final void Function(FormGroup formGroup, bool didPop)? onPopInvoked; - final Widget child; - - const ReactiveFormPopScope({ - super.key, - this.canPop, - this.onPopInvoked, - required this.child, - }); - - @override - Widget build(BuildContext context) { - return ReactiveFormConsumer( - builder: (context, formGroup, _) { - return PopScope( - canPop: canPop != null ? canPop!(formGroup) : true, - onPopInvoked: onPopInvoked != null - ? (didPop) => onPopInvoked!(formGroup, didPop) - : null, - child: child, - ); - }, - ); - } -} diff --git a/lib/src/widgets/reactive_radio.dart b/lib/src/widgets/reactive_radio.dart index 38bb7e0c..7afdbd9a 100644 --- a/lib/src/widgets/reactive_radio.dart +++ b/lib/src/widgets/reactive_radio.dart @@ -29,9 +29,9 @@ class ReactiveRadio extends ReactiveFocusableFormField { /// For documentation about the various parameters, see the [Radio] class /// and [Radio], the constructor. ReactiveRadio({ - Key? key, - String? formControlName, - FormControl? formControl, + super.key, + super.formControlName, + super.formControl, required T value, Color? activeColor, Color? focusColor, @@ -44,13 +44,9 @@ class ReactiveRadio extends ReactiveFocusableFormField { double? splashRadius, bool autofocus = false, bool toggleable = false, - FocusNode? focusNode, + super.focusNode, ReactiveFormFieldCallback? onChanged, }) : super( - key: key, - formControl: formControl, - formControlName: formControlName, - focusNode: focusNode, builder: (field) { return Radio( value: value, diff --git a/lib/src/widgets/reactive_radio_list_tile.dart b/lib/src/widgets/reactive_radio_list_tile.dart index 35603d21..f21f9611 100644 --- a/lib/src/widgets/reactive_radio_list_tile.dart +++ b/lib/src/widgets/reactive_radio_list_tile.dart @@ -26,9 +26,9 @@ class ReactiveRadioListTile extends ReactiveFocusableFormField { /// /// See also [RadioListTile] ReactiveRadioListTile({ - Key? key, - String? formControlName, - FormControl? formControl, + super.key, + super.formControlName, + super.formControl, required T value, Color? activeColor, Color? selectedTileColor, @@ -45,7 +45,7 @@ class ReactiveRadioListTile extends ReactiveFocusableFormField { bool autofocus = false, bool selected = false, VisualDensity? visualDensity, - FocusNode? focusNode, + super.focusNode, bool? enableFeedback, ReactiveFormFieldCallback? onChanged, MouseCursor? mouseCursor, @@ -56,10 +56,6 @@ class ReactiveRadioListTile extends ReactiveFocusableFormField { MaterialTapTargetSize? materialTapTargetSize, ValueChanged? onFocusChange, }) : super( - key: key, - formControl: formControl, - formControlName: formControlName, - focusNode: focusNode, builder: (field) { return RadioListTile( value: value, diff --git a/lib/src/widgets/reactive_slider.dart b/lib/src/widgets/reactive_slider.dart index f5d413ef..d7ff9504 100644 --- a/lib/src/widgets/reactive_slider.dart +++ b/lib/src/widgets/reactive_slider.dart @@ -31,9 +31,9 @@ class ReactiveSlider extends ReactiveFocusableFormField { /// The [labelBuilder] is called each time the [FormControl] changes its value /// so you can supply a label to the Slider. ReactiveSlider( - {Key? key, - String? formControlName, - FormControl? formControl, + {super.key, + super.formControlName, + super.formControl, double min = 0.0, double max = 1.0, int? divisions, @@ -44,7 +44,7 @@ class ReactiveSlider extends ReactiveFocusableFormField { SemanticFormatterCallback? semanticFormatterCallback, bool autofocus = false, MouseCursor? mouseCursor, - FocusNode? focusNode, + super.focusNode, ReactiveFormFieldCallback? onChangeEnd, ReactiveFormFieldCallback? onChangeStart, ReactiveFormFieldCallback? onChanged, @@ -52,10 +52,6 @@ class ReactiveSlider extends ReactiveFocusableFormField { Color? secondaryActiveColor, MaterialStateProperty? overlayColor}) : super( - key: key, - formControl: formControl, - formControlName: formControlName, - focusNode: focusNode, builder: (field) { var value = field.value; if (value == null) { diff --git a/lib/src/widgets/reactive_status_listenable_builder.dart b/lib/src/widgets/reactive_status_listenable_builder.dart index 540305da..7a37da15 100644 --- a/lib/src/widgets/reactive_status_listenable_builder.dart +++ b/lib/src/widgets/reactive_status_listenable_builder.dart @@ -32,7 +32,7 @@ class ReactiveStatusListenableBuilder extends StatelessWidget { /// at the same time. /// const ReactiveStatusListenableBuilder({ - Key? key, + super.key, this.formControlName, this.formControl, required this.builder, @@ -40,8 +40,7 @@ class ReactiveStatusListenableBuilder extends StatelessWidget { }) : assert( (formControlName != null && formControl == null) || (formControlName == null && formControl != null), - 'Must provide a formControlName or a formControl, but not both at the same time.'), - super(key: key); + 'Must provide a formControlName or a formControl, but not both at the same time.'); @override Widget build(BuildContext context) { diff --git a/lib/src/widgets/reactive_switch.dart b/lib/src/widgets/reactive_switch.dart index a9d69863..92028b9d 100644 --- a/lib/src/widgets/reactive_switch.dart +++ b/lib/src/widgets/reactive_switch.dart @@ -33,10 +33,10 @@ class ReactiveSwitch extends ReactiveFocusableFormField { /// For documentation about the various parameters, see the [Switch] class /// and [Switch], the constructor. ReactiveSwitch({ - Key? key, - String? formControlName, - FormControl? formControl, - FocusNode? focusNode, + super.key, + super.formControlName, + super.formControl, + super.focusNode, Color? activeColor, Color? activeTrackColor, Color? inactiveThumbColor, @@ -60,10 +60,6 @@ class ReactiveSwitch extends ReactiveFocusableFormField { MaterialStateProperty? thumbIcon, ValueChanged? onFocusChange, }) : super( - key: key, - formControl: formControl, - formControlName: formControlName, - focusNode: focusNode, builder: (field) { return Switch( value: field.value ?? false, @@ -120,10 +116,10 @@ class ReactiveSwitch extends ReactiveFocusableFormField { /// For documentation about the various parameters, see the [Switch.adaptive] /// constructor. ReactiveSwitch.adaptive({ - Key? key, - String? formControlName, - FormControl? formControl, - FocusNode? focusNode, + super.key, + super.formControlName, + super.formControl, + super.focusNode, Color? activeColor, Color? activeTrackColor, Color? inactiveThumbColor, @@ -144,10 +140,6 @@ class ReactiveSwitch extends ReactiveFocusableFormField { double? splashRadius, ReactiveFormFieldCallback? onChanged, }) : super( - key: key, - formControl: formControl, - formControlName: formControlName, - focusNode: focusNode, builder: (field) { return Switch.adaptive( value: field.value ?? false, diff --git a/lib/src/widgets/reactive_switch_list_tile.dart b/lib/src/widgets/reactive_switch_list_tile.dart index fd230ce3..66c970fe 100644 --- a/lib/src/widgets/reactive_switch_list_tile.dart +++ b/lib/src/widgets/reactive_switch_list_tile.dart @@ -26,9 +26,9 @@ class ReactiveSwitchListTile extends ReactiveFocusableFormField { /// /// See also [CheckboxListTile] ReactiveSwitchListTile({ - Key? key, - String? formControlName, - FormControl? formControl, + super.key, + super.formControlName, + super.formControl, Color? tileColor, Color? activeColor, Color? activeTrackColor, @@ -50,7 +50,7 @@ class ReactiveSwitchListTile extends ReactiveFocusableFormField { Color? selectedTileColor, VisualDensity? visualDensity, bool? enableFeedback, - FocusNode? focusNode, + super.focusNode, ReactiveFormFieldCallback? onChanged, ImageErrorListener? onActiveThumbImageError, ImageErrorListener? onInactiveThumbImageError, @@ -65,10 +65,6 @@ class ReactiveSwitchListTile extends ReactiveFocusableFormField { double? splashRadius, ValueChanged? onFocusChange, }) : super( - key: key, - formControl: formControl, - formControlName: formControlName, - focusNode: focusNode, builder: (field) { return SwitchListTile( value: field.value ?? false, @@ -132,9 +128,9 @@ class ReactiveSwitchListTile extends ReactiveFocusableFormField { /// For documentation about the various parameters, see the /// [SwitchListTile.adaptive] constructor. ReactiveSwitchListTile.adaptative({ - Key? key, - String? formControlName, - FormControl? formControl, + super.key, + super.formControlName, + super.formControl, Color? activeColor, Color? activeTrackColor, Color? inactiveThumbColor, @@ -158,7 +154,7 @@ class ReactiveSwitchListTile extends ReactiveFocusableFormField { ListTileControlAffinity controlAffinity = ListTileControlAffinity.platform, bool? dense, bool? enableFeedback, - FocusNode? focusNode, + super.focusNode, ValueChanged? onFocusChange, Color? hoverColor, bool isThreeLine = false, @@ -172,10 +168,6 @@ class ReactiveSwitchListTile extends ReactiveFocusableFormField { VisualDensity? visualDensity, ReactiveFormFieldCallback? onChanged, }) : super( - key: key, - formControl: formControl, - formControlName: formControlName, - focusNode: focusNode, builder: (field) { return SwitchListTile.adaptive( value: field.value ?? false, diff --git a/lib/src/widgets/reactive_text_field.dart b/lib/src/widgets/reactive_text_field.dart index 89fac183..b0cf148e 100644 --- a/lib/src/widgets/reactive_text_field.dart +++ b/lib/src/widgets/reactive_text_field.dart @@ -90,13 +90,13 @@ class ReactiveTextField extends ReactiveFormField { /// For documentation about the various parameters, see the [TextField] class /// and [TextField], the constructor. ReactiveTextField({ - Key? key, - String? formControlName, - FormControl? formControl, - Map? validationMessages, - ControlValueAccessor? valueAccessor, - ShowErrorsFunction? showErrors, - FocusNode? focusNode, + super.key, + super.formControlName, + super.formControl, + super.validationMessages, + super.valueAccessor, + super.showErrors, + super.focusNode, InputDecoration decoration = const InputDecoration(), TextInputType? keyboardType, TextCapitalization textCapitalization = TextCapitalization.none, @@ -158,13 +158,6 @@ class ReactiveTextField extends ReactiveFormField { TextMagnifierConfiguration? magnifierConfiguration, }) : _textController = controller, super( - key: key, - formControl: formControl, - formControlName: formControlName, - valueAccessor: valueAccessor, - validationMessages: validationMessages, - showErrors: showErrors, - focusNode: focusNode, builder: (ReactiveFormFieldState field) { final state = field as _ReactiveTextFieldState; final effectiveDecoration = decoration diff --git a/lib/src/widgets/reactive_time_picker.dart b/lib/src/widgets/reactive_time_picker.dart index 22a25d5d..501bf975 100644 --- a/lib/src/widgets/reactive_time_picker.dart +++ b/lib/src/widgets/reactive_time_picker.dart @@ -60,9 +60,9 @@ class ReactiveTimePicker extends ReactiveFormField { /// For documentation about the various parameters, see the [showTimePicker] /// function parameters. ReactiveTimePicker({ - Key? key, - String? formControlName, - FormControl? formControl, + super.key, + super.formControlName, + super.formControl, required ReactiveTimePickerBuilder builder, TransitionBuilder? transitionBuilder, bool useRootNavigator = true, @@ -78,9 +78,6 @@ class ReactiveTimePicker extends ReactiveFormField { EntryModeChangeCallback? onEntryModeChanged, Offset? anchorPoint, }) : super( - key: key, - formControl: formControl, - formControlName: formControlName, builder: (ReactiveFormFieldState field) { return builder( field.context, diff --git a/lib/src/widgets/reactive_value_listenable_builder.dart b/lib/src/widgets/reactive_value_listenable_builder.dart index 09a19aeb..82238177 100644 --- a/lib/src/widgets/reactive_value_listenable_builder.dart +++ b/lib/src/widgets/reactive_value_listenable_builder.dart @@ -38,7 +38,7 @@ class ReactiveValueListenableBuilder extends StatelessWidget { /// subtree does not depend on the value of the [FormControl] that is bind /// with this widget. const ReactiveValueListenableBuilder({ - Key? key, + super.key, required this.builder, this.formControlName, this.formControl, @@ -46,8 +46,7 @@ class ReactiveValueListenableBuilder extends StatelessWidget { }) : assert( (formControlName != null && formControl == null) || (formControlName == null && formControl != null), - 'Must provide a formControlName or a formControl, but not both at the same time.'), - super(key: key); + 'Must provide a formControlName or a formControl, but not both at the same time.'); @override Widget build(BuildContext context) { diff --git a/pubspec.yaml b/pubspec.yaml index 550638e7..e7478d7d 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -4,17 +4,16 @@ version: 17.0.0 homepage: "https://github.com/joanpablo/reactive_forms" environment: - sdk: ">=3.0.0 <4.0.0" - flutter: ">=3.10.0" + sdk: ">=3.2.4 <4.0.0" + flutter: ">=3.16.0" dependencies: flutter: sdk: flutter - # when using flutter 3.10, flutter_localizations depends on intl 0.18.0 - intl: ">=0.18.0 <1.0.0" + intl: ">=0.19.0 <1.0.0" dev_dependencies: - lints: ^2.1.0 + flutter_lints: ^3.0.2 flutter_test: sdk: flutter diff --git a/test/src/widgets/reactive_checkbox_list_tile_testing_widget.dart b/test/src/widgets/reactive_checkbox_list_tile_testing_widget.dart index f49abc4c..73418b59 100644 --- a/test/src/widgets/reactive_checkbox_list_tile_testing_widget.dart +++ b/test/src/widgets/reactive_checkbox_list_tile_testing_widget.dart @@ -10,12 +10,12 @@ class ReactiveCheckboxListTileTestingWidget extends StatelessWidget { final ReactiveFormFieldCallback? onChanged; const ReactiveCheckboxListTileTestingWidget({ - Key? key, + super.key, required this.form, this.tristate = false, this.focusNode, this.onChanged, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_checkbox_testing_widget.dart b/test/src/widgets/reactive_checkbox_testing_widget.dart index 2f12079d..d72dca60 100644 --- a/test/src/widgets/reactive_checkbox_testing_widget.dart +++ b/test/src/widgets/reactive_checkbox_testing_widget.dart @@ -10,12 +10,12 @@ class ReactiveCheckboxTestingWidget extends StatelessWidget { final ReactiveFormFieldCallback? onChanged; const ReactiveCheckboxTestingWidget({ - Key? key, + super.key, required this.form, this.tristate = false, this.focusNode, this.onChanged, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_date_picker_testing_widget.dart b/test/src/widgets/reactive_date_picker_testing_widget.dart index 510badcb..db5386c7 100644 --- a/test/src/widgets/reactive_date_picker_testing_widget.dart +++ b/test/src/widgets/reactive_date_picker_testing_widget.dart @@ -8,12 +8,12 @@ class ReactiveDatePickerTestingWidget extends StatelessWidget { final DateTime? initialDate; const ReactiveDatePickerTestingWidget({ - Key? key, + super.key, required this.form, this.lastDate, this.firstDate, this.initialDate, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_dropdown_testing_widget.dart b/test/src/widgets/reactive_dropdown_testing_widget.dart index 74ecd13c..bd2c4641 100644 --- a/test/src/widgets/reactive_dropdown_testing_widget.dart +++ b/test/src/widgets/reactive_dropdown_testing_widget.dart @@ -11,7 +11,7 @@ class ReactiveDropdownTestingWidget extends StatelessWidget { final DropdownButtonBuilder? selectedItemBuilder; const ReactiveDropdownTestingWidget({ - Key? key, + super.key, required this.form, required this.items, this.onChanged, @@ -19,7 +19,7 @@ class ReactiveDropdownTestingWidget extends StatelessWidget { this.readOnly = false, this.disabledHint, this.selectedItemBuilder, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_form_array_testing_widget.dart b/test/src/widgets/reactive_form_array_testing_widget.dart index 6173a00d..dede3eac 100644 --- a/test/src/widgets/reactive_form_array_testing_widget.dart +++ b/test/src/widgets/reactive_form_array_testing_widget.dart @@ -5,9 +5,9 @@ class ReactiveFormArrayTestingWidget extends StatelessWidget { final FormGroup form; const ReactiveFormArrayTestingWidget({ - Key? key, + super.key, required this.form, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_form_builder_testing_widget.dart b/test/src/widgets/reactive_form_builder_testing_widget.dart index b62b4546..748b1833 100644 --- a/test/src/widgets/reactive_form_builder_testing_widget.dart +++ b/test/src/widgets/reactive_form_builder_testing_widget.dart @@ -7,13 +7,13 @@ class ReactiveFormBuilderTestingWidget extends StatelessWidget { final Map bindings; const ReactiveFormBuilderTestingWidget({ - Key? key, + super.key, required this.form, this.validationMessages, this.bindings = const { 'textField': 'name', }, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_form_consumer_testing_widget.dart b/test/src/widgets/reactive_form_consumer_testing_widget.dart index c950417d..a7149585 100644 --- a/test/src/widgets/reactive_form_consumer_testing_widget.dart +++ b/test/src/widgets/reactive_form_consumer_testing_widget.dart @@ -5,9 +5,9 @@ class ReactiveFormConsumerTestingWidget extends StatelessWidget { final FormGroup form; const ReactiveFormConsumerTestingWidget({ - Key? key, + super.key, required this.form, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_radio_list_tile_testing_widget.dart b/test/src/widgets/reactive_radio_list_tile_testing_widget.dart index 8f034421..953ec2b3 100644 --- a/test/src/widgets/reactive_radio_list_tile_testing_widget.dart +++ b/test/src/widgets/reactive_radio_list_tile_testing_widget.dart @@ -9,11 +9,11 @@ class ReactiveRadioListTileTestingWidget extends StatelessWidget { final ReactiveFormFieldCallback? onChanged; const ReactiveRadioListTileTestingWidget({ - Key? key, + super.key, required this.form, this.focusNode, this.onChanged, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_radio_testing_widget.dart b/test/src/widgets/reactive_radio_testing_widget.dart index b7cc83ed..74e63825 100644 --- a/test/src/widgets/reactive_radio_testing_widget.dart +++ b/test/src/widgets/reactive_radio_testing_widget.dart @@ -9,11 +9,11 @@ class ReactiveRadioTestingWidget extends StatelessWidget { final ReactiveFormFieldCallback? onChanged; const ReactiveRadioTestingWidget({ - Key? key, + super.key, required this.form, this.focusNode, this.onChanged, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_slider_testing_widget.dart b/test/src/widgets/reactive_slider_testing_widget.dart index fd588044..b6e5d905 100644 --- a/test/src/widgets/reactive_slider_testing_widget.dart +++ b/test/src/widgets/reactive_slider_testing_widget.dart @@ -12,14 +12,14 @@ class ReactiveSliderTestingWidget extends StatelessWidget { final ReactiveFormFieldCallback? onChanged; const ReactiveSliderTestingWidget({ - Key? key, + super.key, required this.form, this.focusNode, this.labelBuilder, this.onChanged, this.onChangeStart, this.onChangeEnd, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_status_listenable_builder_testing_widget.dart b/test/src/widgets/reactive_status_listenable_builder_testing_widget.dart index f3ba460b..666e2b32 100644 --- a/test/src/widgets/reactive_status_listenable_builder_testing_widget.dart +++ b/test/src/widgets/reactive_status_listenable_builder_testing_widget.dart @@ -5,9 +5,9 @@ class ReactiveStatusListenableTestingWidget extends StatelessWidget { final FormGroup form; const ReactiveStatusListenableTestingWidget({ - Key? key, + super.key, required this.form, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_switch_list_tile_testing_widget.dart b/test/src/widgets/reactive_switch_list_tile_testing_widget.dart index 9da1ba3f..b30b729a 100644 --- a/test/src/widgets/reactive_switch_list_tile_testing_widget.dart +++ b/test/src/widgets/reactive_switch_list_tile_testing_widget.dart @@ -12,14 +12,14 @@ class ReactiveSwitchListTileTestingWidget extends StatelessWidget { final bool renderAdaptative; const ReactiveSwitchListTileTestingWidget({ - Key? key, + super.key, required this.form, this.renderAdaptative = true, this.focusNode, this.adaptativeFocusNode, this.onChanged, this.adaptativeOnChanged, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_switch_testing_widget.dart b/test/src/widgets/reactive_switch_testing_widget.dart index 48da1665..47e6d3f9 100644 --- a/test/src/widgets/reactive_switch_testing_widget.dart +++ b/test/src/widgets/reactive_switch_testing_widget.dart @@ -10,12 +10,12 @@ class ReactiveSwitchTestingWidget extends StatelessWidget { final ReactiveFormFieldCallback? adaptativeOnChanged; const ReactiveSwitchTestingWidget({ - Key? key, + super.key, required this.form, this.focusNode, this.onChanged, this.adaptativeOnChanged, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_text_field_testing_widget.dart b/test/src/widgets/reactive_text_field_testing_widget.dart index 3cc11a13..e3210dbe 100644 --- a/test/src/widgets/reactive_text_field_testing_widget.dart +++ b/test/src/widgets/reactive_text_field_testing_widget.dart @@ -13,7 +13,7 @@ class ReactiveTextFieldTestingWidget extends StatelessWidget { final ReactiveFormFieldCallback? onEditingComplete; const ReactiveTextFieldTestingWidget({ - Key? key, + super.key, required this.form, this.validationMessages, this.showErrors, @@ -25,7 +25,7 @@ class ReactiveTextFieldTestingWidget extends StatelessWidget { this.onTap, this.onSubmitted, this.onEditingComplete, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_time_picker_testing_widget.dart b/test/src/widgets/reactive_time_picker_testing_widget.dart index abda518a..97d1c592 100644 --- a/test/src/widgets/reactive_time_picker_testing_widget.dart +++ b/test/src/widgets/reactive_time_picker_testing_widget.dart @@ -5,9 +5,9 @@ class ReactiveTimePickerTestingWidget extends StatelessWidget { final FormGroup form; const ReactiveTimePickerTestingWidget({ - Key? key, + super.key, required this.form, - }) : super(key: key); + }); @override Widget build(BuildContext context) { diff --git a/test/src/widgets/reactive_value_listenable_builder_testing_widget.dart b/test/src/widgets/reactive_value_listenable_builder_testing_widget.dart index d0b006cb..0eb6a570 100644 --- a/test/src/widgets/reactive_value_listenable_builder_testing_widget.dart +++ b/test/src/widgets/reactive_value_listenable_builder_testing_widget.dart @@ -5,9 +5,9 @@ class ReactiveValueListenableTestingWidget extends StatelessWidget { final FormGroup form; const ReactiveValueListenableTestingWidget({ - Key? key, + super.key, required this.form, - }) : super(key: key); + }); @override Widget build(BuildContext context) {