app/lib/components/payment_body.dart

220 lines
8.3 KiB
Dart
Raw Normal View History

2022-05-16 07:51:47 +07:00
import 'package:intl/intl.dart';
2022-04-26 16:15:38 +07:00
import 'package:flutter/material.dart';
2022-05-16 07:51:47 +07:00
2022-05-15 15:14:07 +07:00
import 'package:nekoya_flutter/api/api.dart';
import 'package:nekoya_flutter/data/cart.dart';
2022-04-26 16:15:38 +07:00
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) {
2022-05-15 15:14:07 +07:00
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;
});
}
2022-04-26 16:15:38 +07:00
return Container(
2022-04-28 21:17:54 +07:00
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: [
Image.asset(
2022-05-16 07:58:54 +07:00
'assets/images/bca.webp',
2022-04-28 21:17:54 +07:00
cacheHeight: 40,
cacheWidth: 100,
),
Image.asset(
2022-05-16 07:58:54 +07:00
'assets/images/bni.webp',
2022-04-28 21:17:54 +07:00
cacheHeight: 40,
cacheWidth: 100,
),
Image.asset(
2022-05-16 07:58:54 +07:00
'assets/images/bri.webp',
2022-04-28 21:17:54 +07:00
cacheHeight: 40,
cacheWidth: 100,
),
],
),
),
2022-05-21 15:41:03 +07:00
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(
2022-05-21 17:12:03 +07:00
backgroundColor: Color(0xff212226),
collapsedBackgroundColor: Color(0xff212226),
2022-05-21 15:41:03 +07:00
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 Pembayaran Tagihan > Pembayaran \n3. Pada Ke Rekening masukkan Rekening perusahaan \n4. Masukkan Jumlah Nominal yang akan ditransfer \n5. Kemudian tekan send. Cetak/simpan stuck Transfer sebagai bukti pembayaran'),
)
],
2022-05-21 15:34:55 +07:00
),
2022-04-26 16:15:38 +07:00
),
2022-04-28 21:17:54 +07:00
),
),
2022-05-21 15:41:03 +07:00
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(
2022-05-21 17:12:03 +07:00
backgroundColor: Color(0xff212226),
collapsedBackgroundColor: Color(0xff212226),
2022-05-21 15:41:03 +07:00
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 Pembayaran Tagihan > Pembayaran > Antar Rekening\n3. Pada Ke Rekening masukkan Rekening perusahaan\n4. Masukkan Jumlah Nominal yang akan ditransfer\n5. Kemudian tekan send. Cetak/simpan stuck Transfer sebagai bukti pembayaran'),
)
],
),
),
),
),
Padding(
padding: const EdgeInsets.only(right: 15, left: 15),
2022-04-28 21:17:54 +07:00
child: ClipRRect(
borderRadius: BorderRadius.circular(18),
2022-04-29 20:32:17 +07:00
child: const ExpansionTile(
2022-05-21 17:12:03 +07:00
backgroundColor: Color(0xff212226),
collapsedBackgroundColor: Color(0xff212226),
textColor: Colors.white,
collapsedTextColor: Colors.white,
2022-05-21 15:34:55 +07:00
title: Text(
2022-05-21 15:41:03 +07:00
'BRI',
2022-05-21 15:34:55 +07:00
style: TextStyle(
color: Colors.white,
fontWeight: FontWeight.bold,
fontSize: 20),
),
2022-04-29 20:32:17 +07:00
children: [
ListTile(
textColor: Colors.white,
2022-04-27 17:16:07 +07:00
title: Text(
2022-05-21 15:41:03 +07:00
'1. Login pada alamat Internet Banking BRI (***)\n2. Pilih menu Pembayaran Tagihan > Pembayaran > Antar Rekening\n3. Pada Ke Rekening masukkan Rekening perusahaan\n4. Masukkan Jumlah Nominal yang akan ditransfer\n5. Kemudian tekan send. Cetak/simpan stuck Transfer sebagai bukti pembayaran'),
)
],
),
2022-04-28 21:17:54 +07:00
),
),
Container(
2022-04-29 02:20:36 +07:00
padding: const EdgeInsets.only(top: 40),
2022-04-28 21:17:54 +07:00
color: Colors.transparent,
),
2022-05-21 15:41:03 +07:00
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),
)
],
);
}
2022-05-15 15:14:07 +07:00
return Row(
mainAxisAlignment: MainAxisAlignment.center,
2022-05-21 15:41:03 +07:00
children: const [
2022-05-15 15:14:07 +07:00
Text(
2022-05-21 15:41:03 +07:00
"Count total price on process!",
style: TextStyle(
2022-05-15 15:14:07 +07:00
color: Colors.white,
2022-05-21 15:41:03 +07:00
fontSize: 25,
2022-05-15 15:14:07 +07:00
fontWeight: FontWeight.w600),
)
],
);
2022-05-21 15:41:03 +07:00
},
),
2022-04-28 21:17:54 +07:00
),
),
Container(
2022-04-29 02:20:36 +07:00
padding: const EdgeInsets.only(top: 40),
2022-04-28 21:17:54 +07:00
color: Colors.transparent,
),
2022-05-21 15:34:55 +07:00
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: () {
2022-05-21 17:22:27 +07:00
Navigator.pushReplacementNamed(context, '');
2022-05-21 15:34:55 +07:00
},
child: const Text(
'Transaction',
style: TextStyle(color: Colors.white, fontSize: 30),
),
2022-04-28 21:17:54 +07:00
),
),
],
),
);
2022-04-26 16:15:38 +07:00
}
}