I\'m trying to use NumberFromatter
in TextInputFormatter
but when I try to use it, it completely messed up! This is my TextInputFormatter
This is because after you format the value you are adding a new char but the the text selection remains at the same position, one char less, this cause an expected behavior
You can modified your TextInputFormatter
like this :
Fixed to support all locales and to remember cursor position
class NumericTextFormatter extends TextInputFormatter {
@override
TextEditingValue formatEditUpdate(
TextEditingValue oldValue, TextEditingValue newValue) {
if (newValue.text.isEmpty) {
return newValue.copyWith(text: '');
} else if (newValue.text.compareTo(oldValue.text) != 0) {
final int selectionIndexFromTheRight =
newValue.text.length - newValue.selection.end;
final f = NumberFormat("#,###");
final number =
int.parse(newValue.text.replaceAll(f.symbols.GROUP_SEP, ''));
final newString = f.format(number);
return TextEditingValue(
text: newString,
selection: TextSelection.collapsed(
offset: newString.length - selectionIndexFromTheRight),
);
} else {
return newValue;
}
}
}