mirror of
https://github.com/Iconica-Development/flutter_input_library.git
synced 2025-05-18 17:03:45 +02:00
62 lines
1.7 KiB
Dart
62 lines
1.7 KiB
Dart
// SPDX-FileCopyrightText: 2022 Iconica
|
|
//
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_input_library/src/inputs/number_picker/number_picker_field.dart';
|
|
|
|
class FlutterFormInputNumberPicker extends StatelessWidget {
|
|
const FlutterFormInputNumberPicker({
|
|
super.key,
|
|
this.minValue = 0,
|
|
this.maxValue = 100,
|
|
this.onSaved,
|
|
this.onChanged,
|
|
this.initialValue,
|
|
this.validator,
|
|
}) : assert(minValue < maxValue, 'minValue must be less than maxValue');
|
|
|
|
final int minValue;
|
|
final int maxValue;
|
|
final Function(int?)? onSaved;
|
|
final String? Function(int?)? validator;
|
|
final int? initialValue;
|
|
final Function(int?)? onChanged;
|
|
|
|
@override
|
|
Widget build(BuildContext context) => NumberPickerFormField(
|
|
minValue: minValue,
|
|
maxValue: maxValue,
|
|
onSaved: (value) => onSaved?.call(value),
|
|
validator: (value) => validator?.call(value),
|
|
onChanged: (value) => onChanged?.call(value),
|
|
initialValue: initialValue ?? 0,
|
|
);
|
|
}
|
|
|
|
class NumberPickerFormField extends FormField<int> {
|
|
NumberPickerFormField({
|
|
required FormFieldSetter<int> super.onSaved,
|
|
required FormFieldValidator<int> super.validator,
|
|
super.key,
|
|
void Function(int value)? onChanged,
|
|
int super.initialValue = 0,
|
|
int minValue = 0,
|
|
int maxValue = 100,
|
|
}) : super(
|
|
builder: (FormFieldState<int> state) => NumberPicker(
|
|
minValue: minValue,
|
|
maxValue: maxValue,
|
|
value: initialValue,
|
|
onChanged: (int value) {
|
|
onChanged?.call(value);
|
|
|
|
state.didChange(value);
|
|
},
|
|
itemHeight: 35,
|
|
itemCount: 5,
|
|
),
|
|
);
|
|
}
|