app/lib/components/payment_body.dart

230 lines
8.6 KiB
Dart

import 'package:intl/intl.dart';
import 'package:flutter/material.dart';
import 'package:nekoya_app/api/api.dart';
import 'package:nekoya_app/data/cart.dart';
class PaymentBody extends StatefulWidget {
const PaymentBody({Key? key}) : super(key: key);
@override
State<PaymentBody> createState() => _PaymentBodyState();
}
class _PaymentBodyState extends State<PaymentBody> {
@override
Widget build(BuildContext context) {
Future<dynamic> getTotal() async {
dynamic totalPrice = 0;
var orderData = await viewCart();
await orderData.forEach((x) async {
var product = await getProduct(x['product_id']);
totalPrice += product[0]['PRICE'] * x['quantity'];
});
return Future.delayed(const Duration(seconds: 2), () {
return totalPrice;
});
}
return Container(
decoration: const BoxDecoration(color: Colors.transparent),
child: ListView(
scrollDirection: Axis.vertical,
shrinkWrap: true,
children: [
Container(
padding: const EdgeInsets.only(top: 40, bottom: 30),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
Flexible(
flex: 1,
child: Padding(
padding: const EdgeInsets.only(left: 20, right: 20),
child: Image.asset(
'assets/images/bca.webp',
),
),
),
Flexible(
flex: 1,
child: Padding(
padding: const EdgeInsets.only(left: 20, right: 20),
child: Image.asset(
'assets/images/bni.webp',
),
),
),
Flexible(
flex: 1,
child: Padding(
padding: const EdgeInsets.only(left: 20, right: 20),
child: Image.asset('assets/images/bri.webp'),
),
),
],
),
),
Padding(
padding: const EdgeInsets.only(right: 15, left: 15),
child: Container(
padding: const EdgeInsets.only(bottom: 20),
child: ClipRRect(
borderRadius: BorderRadius.circular(18),
child: const ExpansionTile(
backgroundColor: Color(0xff212226),
collapsedBackgroundColor: Color(0xff212226),
textColor: Colors.white,
collapsedTextColor: Colors.white,
title: Text(
'BCA',
style: TextStyle(
color: Colors.white,
fontWeight: FontWeight.bold,
fontSize: 20),
),
children: [
ListTile(
textColor: Colors.white,
title: Text(
'1. Login pada alamat Internet Banking BCA \n2. Pilih menu m-Transfer \n3. Pada Input No. Virtual Account masukkan kode Virtual Account (80777089676869186)\n4. Kemudian tekan send. Cetak/simpan stuck Transfer sebagai bukti pembayaran'),
)
],
),
),
),
),
Padding(
padding: const EdgeInsets.only(right: 15, left: 15),
child: Container(
padding: const EdgeInsets.only(bottom: 20),
child: ClipRRect(
borderRadius: BorderRadius.circular(18),
child: const ExpansionTile(
backgroundColor: Color(0xff212226),
collapsedBackgroundColor: Color(0xff212226),
textColor: Colors.white,
collapsedTextColor: Colors.white,
title: Text(
'BNI',
style: TextStyle(
color: Colors.white,
fontWeight: FontWeight.bold,
fontSize: 20),
),
children: [
ListTile(
textColor: Colors.white,
title: Text(
'1. Login pada alamat Internet Banking BNI \n2. Pilih menu m-Transfer \n3. Pada Input No. Virtual Account masukkan kode Virtual Account (8277089676869186)\n4. Kemudian tekan send. Cetak/simpan stuck Transfer sebagai bukti pembayaran'),
)
],
),
),
),
),
Padding(
padding: const EdgeInsets.only(right: 15, left: 15),
child: ClipRRect(
borderRadius: BorderRadius.circular(18),
child: const ExpansionTile(
backgroundColor: Color(0xff212226),
collapsedBackgroundColor: Color(0xff212226),
textColor: Colors.white,
collapsedTextColor: Colors.white,
title: Text(
'BRI',
style: TextStyle(
color: Colors.white,
fontWeight: FontWeight.bold,
fontSize: 20),
),
children: [
ListTile(
textColor: Colors.white,
title: Text(
'1. Login pada alamat Internet Banking BRI \n2. Pilih menu m-Transfer \n3. Pada Input No. Virtual Account masukkan kode Virtual Account (8077089676869186)\n4. Kemudian tekan send. Cetak/simpan stuck Transfer sebagai bukti pembayaran'),
)
],
),
),
),
Container(
padding: const EdgeInsets.only(top: 40),
color: Colors.transparent,
),
Padding(
padding: const EdgeInsets.only(right: 15, left: 15),
child: Container(
decoration: BoxDecoration(
border: Border.all(color: Colors.orange.shade800),
borderRadius: BorderRadius.circular(18),
//color: const Color.fromARGB(255, 38, 173, 54),
),
child: FutureBuilder<dynamic>(
future: getTotal(),
builder: (context, snapshot) {
if (snapshot.hasData) {
var price = snapshot.data;
return Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(
"Rp ${NumberFormat('#,##0.00', 'ID').format(price)}",
style: const TextStyle(
color: Colors.white,
fontSize: 30,
fontWeight: FontWeight.w600),
)
],
);
}
return const Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(
"Count total price on process!",
style: TextStyle(
color: Colors.white,
fontSize: 25,
fontWeight: FontWeight.w600),
)
],
);
},
),
),
),
Container(
padding: const EdgeInsets.only(top: 40),
color: Colors.transparent,
),
Padding(
padding: const EdgeInsets.only(right: 30, left: 30),
child: ElevatedButton(
style: ButtonStyle(
foregroundColor:
MaterialStateProperty.all(const Color(0xff8B0000)),
backgroundColor:
MaterialStateProperty.all(const Color(0xff8B0000)),
shape: MaterialStateProperty.all<RoundedRectangleBorder>(
RoundedRectangleBorder(
borderRadius: BorderRadius.circular(18.0),
side: const BorderSide(color: Color(0xff8B0000))))),
onPressed: () {
Navigator.pop(context);
Navigator.pushReplacementNamed(context, '/transactions');
},
child: const Text(
'Transaction',
style: TextStyle(color: Colors.white, fontSize: 30),
),
),
),
],
),
);
}
}