app/lib/components/payment_body.dart

188 lines
7 KiB
Dart
Raw Normal View History

2022-04-26 16:15:38 +07:00
import 'package:flutter/material.dart';
2022-05-15 15:14:07 +07:00
import 'package:nekoya_flutter/api/api.dart';
import 'package:nekoya_flutter/data/cart.dart';
import 'package:intl/intl.dart';
2022-04-29 17:50:01 +07:00
import 'package:nekoya_flutter/components/menu.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(
'assets/bca.webp',
cacheHeight: 40,
cacheWidth: 100,
),
Image.asset(
'assets/bni.webp',
cacheHeight: 40,
cacheWidth: 100,
),
Image.asset(
'assets/bri.webp',
cacheHeight: 40,
cacheWidth: 100,
),
],
),
),
Container(
2022-04-29 02:20:36 +07:00
padding: const EdgeInsets.only(bottom: 20),
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(
backgroundColor: Color(0xff8B0000),
collapsedBackgroundColor: Color(0xff8B0000),
textColor: Colors.white,
collapsedTextColor: Colors.white,
2022-04-29 20:32:17 +07:00
title: Text('BCA'),
children: [
ListTile(
textColor: Colors.white,
2022-04-27 17:16:07 +07:00
title: Text(
2022-04-29 02:20:36 +07:00
'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-04-26 16:15:38 +07:00
),
2022-04-28 21:17:54 +07:00
),
),
Container(
2022-04-29 02:20:36 +07:00
padding: const EdgeInsets.only(bottom: 20),
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(
backgroundColor: Color(0xff8B0000),
collapsedBackgroundColor: Color(0xff8B0000),
textColor: Colors.white,
collapsedTextColor: Colors.white,
2022-04-29 20:32:17 +07:00
title: Text('BNI'),
children: [
ListTile(
textColor: Colors.white,
2022-04-27 17:16:07 +07:00
title: Text(
2022-04-29 02:20:36 +07:00
'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'),
)
],
),
2022-04-28 21:17:54 +07:00
),
),
2022-04-29 02:20:36 +07:00
ClipRRect(
borderRadius: BorderRadius.circular(18),
2022-04-29 20:32:17 +07:00
child: const ExpansionTile(
backgroundColor: Color(0xff8B0000),
collapsedBackgroundColor: Color(0xff8B0000),
2022-04-29 02:20:36 +07:00
textColor: Colors.white,
collapsedTextColor: Colors.white,
2022-04-29 20:32:17 +07:00
title: Text('BRI'),
children: [
2022-04-29 02:20:36 +07:00
ListTile(
textColor: Colors.white,
title: Text(
'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,
),
Container(
decoration: BoxDecoration(
2022-05-15 15:14:07 +07:00
borderRadius: BorderRadius.circular(18),
color: const Color(0xff8B0000),
),
2022-05-15 15:14:07 +07:00
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: 25,
fontWeight: FontWeight.w600),
)
],
);
}
return Row(
mainAxisAlignment: MainAxisAlignment.center,
children: const [
Text(
"Count total price on process!",
style: TextStyle(
color: Colors.white,
fontSize: 25,
fontWeight: FontWeight.w600),
)
],
);
},
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-04-29 02:20:36 +07:00
ElevatedButton(
style: ButtonStyle(
foregroundColor:
2022-04-29 20:02:45 +07:00
MaterialStateProperty.all(const Color(0xff8B0000)),
2022-04-29 02:20:36 +07:00
backgroundColor:
2022-04-29 20:02:45 +07:00
MaterialStateProperty.all(const Color(0xff8B0000)),
2022-04-29 02:20:36 +07:00
shape: MaterialStateProperty.all<RoundedRectangleBorder>(
RoundedRectangleBorder(
borderRadius: BorderRadius.circular(18.0),
2022-05-10 11:52:50 +07:00
side: const BorderSide(color: Color(0xff8B0000))))),
2022-04-29 02:20:36 +07:00
onPressed: () {
2022-04-29 20:02:45 +07:00
Navigator.of(context).pushReplacement(MaterialPageRoute(
builder: (context) => const Menu(initialScreen: 4)));
2022-04-29 02:20:36 +07:00
},
child: const Text(
'Transaction',
style: TextStyle(color: Colors.white, fontSize: 25),
2022-04-28 21:17:54 +07:00
),
),
],
),
);
2022-04-26 16:15:38 +07:00
}
}