A Flutter package allows you to easily implement the Credit card's UI easily with the Card detection.
This plugin use https://binlist.io/lookup/ to lookup the Binn card and retrieve data
- Add dependency to
pubspec.yaml
Get the latest version in the 'Installing' tab on pub.dartlang.org
dependencies:
credit_card: 0.0.1
- Import the package
import 'package:credit_card/credit_card.dart';
- Create your own InputFields
TextField numberField;
TextField cvvField;
TextField expiryField;
TextField nameField;
- Create CardModel
CardModel cardModel;
- Get controllers from model and pass to fields
@override
void initState() {
cardModel = CardModel(); // PASS CUSTOM PARAMS HERE
numberField = TextField(controller: cardModel.numberController);
cvvField =
TextField(controller: cardModel.cvvController, focusNode: cvvFocus);
expiryField = TextField(controller: cardModel.expiryController);
nameField = TextField(controller: cardModel.nameController);
super.initState();
}
-
Customize card *Use CardModel class to cusotmize the entire card (OPTIONAL)) *
-
Complete Example
import 'package:flutter/material.dart';
import 'package:credit_card/credit_card.dart';
void main() => runApp(MySample());
class MySample extends StatefulWidget {
@override
State<StatefulWidget> createState() => MySampleState();
}
class MySampleState extends State<MySample> {
bool isCvvFocused = false;
TextField numberField;
TextField cvvField;
TextField expiryField;
TextField nameField;
CardModel cardModel;
FocusNode cvvFocus = FocusNode();
@override
void initState() {
cvvFocus.addListener(() => setState(() {}));
cardModel = CardModel(
frontCardColor: Colors.red, // OPTIONAL
backCardColor: Colors.black,// OPTIONAL
backTextStyle: TextStyle(color: Colors.white),// OPTIONAL
frontTextStyle: TextStyle(color: Colors.white),// OPTIONAL
animeDuration: Duration(seconds: 1),// OPTIONAL
cvvMask: '000',// OPTIONAL
expiryMask: '0000',// OPTIONAL
...// OPTIONAL
);
numberField = TextField(controller: cardModel.numberController);
cvvField =
TextField(controller: cardModel.cvvController, focusNode: cvvFocus);
expiryField = TextField(controller: cardModel.expiryController);
nameField = TextField(controller: cardModel.nameController);
super.initState();
}
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Credit Card View Demo',
debugShowCheckedModeBanner: false,
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: Scaffold(
resizeToAvoidBottomInset: true,
body: SafeArea(
child: Column(
children: <Widget>[
CreditCardWidget(
cardModel: cardModel,
showBackView: cvvFocus.hasFocus,
),
//USE YOUR OWN TEXTFIELDS
Expanded(child: numberField),
Expanded(child: nameField),
Expanded(child: expiryField),
Expanded(child: cvvField),
],
),
),
),
);
}
}