creditCardNumberFormatter static method

List<TextInputFormatter> creditCardNumberFormatter()

creditCardNumberFormatter formats input as a credit card number (e.g., XXXX XXXX XXXX XXXX).

Implementation

static List<TextInputFormatter> creditCardNumberFormatter() {
  return [
    TextInputFormatter.withFunction((oldValue, newValue) {
      String newText = newValue.text.replaceAll(RegExp(r'\s+\b|\b\s'), '');
      if (newText.length > 16) {
        newText = newText.substring(0, 16);
      }
      final StringBuffer buffer = StringBuffer();
      for (int i = 0; i < newText.length; i++) {
        buffer.write(newText[i]);
        final int index = i + 1;
        if (index % 4 == 0 && index != newText.length) {
          buffer.write(' '); // Add space after every 4 characters
        }
      }
      final String formattedText = buffer.toString();
      return TextEditingValue(
        text: formattedText,
        selection: TextSelection.collapsed(offset: formattedText.length),
      );
    }),
  ];
}