ReactiveDatePicker<T> constructor

ReactiveDatePicker<T>({
  1. Key? key,
  2. String? formControlName,
  3. FormControl<T>? formControl,
  4. required ReactiveDatePickerBuilder<T> builder,
  5. required DateTime firstDate,
  6. required DateTime lastDate,
  7. DatePickerEntryMode initialEntryMode = DatePickerEntryMode.calendar,
  8. SelectableDayPredicate? selectableDayPredicate,
  9. String? helpText,
  10. String? cancelText,
  11. String? confirmText,
  12. Locale? locale,
  13. bool useRootNavigator = true,
  14. RouteSettings? routeSettings,
  15. TextDirection? textDirection,
  16. TransitionBuilder? transitionBuilder,
  17. DatePickerMode initialDatePickerMode = DatePickerMode.day,
  18. String? errorFormatText,
  19. String? errorInvalidText,
  20. String? fieldHintText,
  21. String? fieldLabelText,
  22. Widget? child,
  23. DateTime? currentDate,
  24. DateTime? initialDate,
  25. TextInputType? keyboardType,
  26. Offset? anchorPoint,
})

Creates a ReactiveDatePicker that wraps the function showDatePicker.

Can optionally provide a formControl to bind this widget to a control.

Can optionally provide a formControlName to bind this ReactiveFormField to a FormControl.

Must provide one of the arguments formControl or a formControlName, but not both at the same time.

The parameter transitionBuilder is the equivalent of builder parameter in the showTimePicker.

For documentation about the various parameters, see the showTimePicker function parameters.

Implementation

ReactiveDatePicker({
  Key? key,
  String? formControlName,
  FormControl<T>? formControl,
  required ReactiveDatePickerBuilder<T> builder,
  required DateTime firstDate,
  required DateTime lastDate,
  DatePickerEntryMode initialEntryMode = DatePickerEntryMode.calendar,
  SelectableDayPredicate? selectableDayPredicate,
  String? helpText,
  String? cancelText,
  String? confirmText,
  Locale? locale,
  bool useRootNavigator = true,
  RouteSettings? routeSettings,
  TextDirection? textDirection,
  TransitionBuilder? transitionBuilder,
  DatePickerMode initialDatePickerMode = DatePickerMode.day,
  String? errorFormatText,
  String? errorInvalidText,
  String? fieldHintText,
  String? fieldLabelText,
  Widget? child,
  DateTime? currentDate,
  DateTime? initialDate,
  TextInputType? keyboardType,
  Offset? anchorPoint,
}) : super(
        key: key,
        formControl: formControl,
        formControlName: formControlName,
        builder: (ReactiveFormFieldState<T, DateTime> field) {
          return builder(
            field.context,
            ReactiveDatePickerDelegate<T>._(
              field,
              (field) => showDatePicker(
                context: field.context,
                initialDate: _getInitialDate(firstDate, lastDate,
                    initialDate ?? field.value ?? DateTime.now()),
                firstDate: firstDate,
                lastDate: lastDate,
                initialEntryMode: initialEntryMode,
                selectableDayPredicate: selectableDayPredicate,
                helpText: helpText,
                cancelText: cancelText,
                confirmText: confirmText,
                locale: locale,
                useRootNavigator: useRootNavigator,
                routeSettings: routeSettings,
                textDirection: textDirection,
                builder: transitionBuilder,
                initialDatePickerMode: initialDatePickerMode,
                errorFormatText: errorFormatText,
                errorInvalidText: errorInvalidText,
                fieldHintText: fieldHintText,
                fieldLabelText: fieldLabelText,
                currentDate: currentDate,
                keyboardType: keyboardType,
                anchorPoint: anchorPoint,
              ).then((value) {
                if (value != null) {
                  field.didChange(value);
                }
              }),
            ),
            child,
          );
        },
      );