buildFrontCard method
Implementation
Widget buildFrontCard() {
return Card(
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(12.0),
),
elevation: 8,
child: Container(
height: 200,
padding: const EdgeInsets.all(16.0),
decoration: BoxDecoration(
gradient: const LinearGradient(
colors: [Color(0xFFC69C6D), Color(0xFF9E7B4F)],
begin: Alignment.topLeft,
end: Alignment.bottomRight,
),
boxShadow: [
BoxShadow(
color: Colors.black.withOpacity(0.3),
blurRadius: 12,
spreadRadius: 3,
),
],
borderRadius: BorderRadius.circular(12.0),
),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Align(
alignment: Alignment.topRight,
child: Obx(() => Image.asset(
controller.logo.value,
height: 40,
)),
),
const SizedBox(height: 16),
TextField(
controller: controller.cardNumberController,
keyboardType: TextInputType.number,
maxLength: 19,
inputFormatters: [
FilteringTextInputFormatter.digitsOnly,
LengthLimitingTextInputFormatter(19),
CardNumberInputFormatter(),
],
decoration: const InputDecoration(
counterText: "",
hintText: '**** **** **** 5678',
hintStyle: TextStyle(color: Colors.white54),
border: InputBorder.none,
),
style: const TextStyle(
color: Colors.white,
fontSize: 24,
fontWeight: FontWeight.bold,
),
),
const Spacer(),
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Expanded(
child: TextField(
controller: controller.cardHolderController,
decoration: const InputDecoration(
hintText: 'Card Holder',
hintStyle: TextStyle(color: Colors.white54),
border: InputBorder.none,
),
style: const TextStyle(color: Colors.white, fontSize: 16),
),
),
Expanded(
child: TextField(
controller: controller.expiryDateController,
maxLength: 5,
keyboardType: TextInputType.datetime,
inputFormatters: [
FilteringTextInputFormatter.allow(RegExp(r'[0-9/]')),
LengthLimitingTextInputFormatter(5),
DateInputFormatter(),
],
decoration: const InputDecoration(
counterText: "",
hintText: 'MM/YY',
hintStyle: TextStyle(color: Colors.white54),
border: InputBorder.none,
),
style: const TextStyle(color: Colors.white, fontSize: 16),
),
),
],
),
],
),
),
);
}