2022-05-16 02:51:47 +02:00
import ' package:intl/intl.dart ' ;
2022-04-26 11:15:38 +02:00
import ' package:flutter/material.dart ' ;
2022-05-16 02:51:47 +02:00
2022-05-15 10:14:07 +02:00
import ' package:nekoya_flutter/api/api.dart ' ;
import ' package:nekoya_flutter/data/cart.dart ' ;
2022-04-29 12:50:01 +02:00
import ' package:nekoya_flutter/components/menu.dart ' ;
2022-04-26 11:15:38 +02: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 10:14:07 +02: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 11:15:38 +02:00
return Container (
2022-04-28 16:17:54 +02: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 02:58:54 +02:00
' assets/images/bca.webp ' ,
2022-04-28 16:17:54 +02:00
cacheHeight: 40 ,
cacheWidth: 100 ,
) ,
Image . asset (
2022-05-16 02:58:54 +02:00
' assets/images/bni.webp ' ,
2022-04-28 16:17:54 +02:00
cacheHeight: 40 ,
cacheWidth: 100 ,
) ,
Image . asset (
2022-05-16 02:58:54 +02:00
' assets/images/bri.webp ' ,
2022-04-28 16:17:54 +02:00
cacheHeight: 40 ,
cacheWidth: 100 ,
) ,
] ,
) ,
) ,
Container (
2022-04-28 21:20:36 +02:00
padding: const EdgeInsets . only ( bottom: 20 ) ,
2022-04-28 16:17:54 +02:00
child: ClipRRect (
borderRadius: BorderRadius . circular ( 18 ) ,
2022-04-29 15:32:17 +02:00
child: const ExpansionTile (
backgroundColor: Color ( 0xff8B0000 ) ,
collapsedBackgroundColor: Color ( 0xff8B0000 ) ,
2022-04-27 11:01:34 +02:00
textColor: Colors . white ,
collapsedTextColor: Colors . white ,
2022-04-29 15:32:17 +02:00
title: Text ( ' BCA ' ) ,
children: [
2022-04-27 11:01:34 +02:00
ListTile (
textColor: Colors . white ,
2022-04-27 12:16:07 +02:00
title: Text (
2022-04-28 21:20:36 +02:00
' 1. Login pada alamat Internet Banking BCA (***) \n 2. Pilih menu Pembayaran Tagihan > Pembayaran \n 3. Pada Ke Rekening masukkan Rekening perusahaan \n 4. Masukkan Jumlah Nominal yang akan ditransfer \n 5. Kemudian tekan send. Cetak/simpan stuck Transfer sebagai bukti pembayaran ' ) ,
2022-04-27 11:01:34 +02:00
)
] ,
2022-04-26 11:15:38 +02:00
) ,
2022-04-28 16:17:54 +02:00
) ,
) ,
Container (
2022-04-28 21:20:36 +02:00
padding: const EdgeInsets . only ( bottom: 20 ) ,
2022-04-28 16:17:54 +02:00
child: ClipRRect (
borderRadius: BorderRadius . circular ( 18 ) ,
2022-04-29 15:32:17 +02:00
child: const ExpansionTile (
backgroundColor: Color ( 0xff8B0000 ) ,
collapsedBackgroundColor: Color ( 0xff8B0000 ) ,
2022-04-27 11:01:34 +02:00
textColor: Colors . white ,
collapsedTextColor: Colors . white ,
2022-04-29 15:32:17 +02:00
title: Text ( ' BNI ' ) ,
children: [
2022-04-27 11:01:34 +02:00
ListTile (
textColor: Colors . white ,
2022-04-27 12:16:07 +02:00
title: Text (
2022-04-28 21:20:36 +02:00
' 1. Login pada alamat Internet Banking BNI (***) \n 2. Pilih menu Pembayaran Tagihan > Pembayaran > Antar Rekening \n 3. Pada Ke Rekening masukkan Rekening perusahaan \n 4. Masukkan Jumlah Nominal yang akan ditransfer \n 5. Kemudian tekan send. Cetak/simpan stuck Transfer sebagai bukti pembayaran ' ) ,
2022-04-27 11:01:34 +02:00
)
] ,
) ,
2022-04-28 16:17:54 +02:00
) ,
) ,
2022-04-28 21:20:36 +02:00
ClipRRect (
borderRadius: BorderRadius . circular ( 18 ) ,
2022-04-29 15:32:17 +02:00
child: const ExpansionTile (
backgroundColor: Color ( 0xff8B0000 ) ,
collapsedBackgroundColor: Color ( 0xff8B0000 ) ,
2022-04-28 21:20:36 +02:00
textColor: Colors . white ,
collapsedTextColor: Colors . white ,
2022-04-29 15:32:17 +02:00
title: Text ( ' BRI ' ) ,
children: [
2022-04-28 21:20:36 +02:00
ListTile (
textColor: Colors . white ,
title: Text (
' 1. Login pada alamat Internet Banking BRI (***) \n 2. Pilih menu Pembayaran Tagihan > Pembayaran > Antar Rekening \n 3. Pada Ke Rekening masukkan Rekening perusahaan \n 4. Masukkan Jumlah Nominal yang akan ditransfer \n 5. Kemudian tekan send. Cetak/simpan stuck Transfer sebagai bukti pembayaran ' ) ,
)
] ,
) ,
) ,
2022-04-28 16:17:54 +02:00
Container (
2022-04-28 21:20:36 +02:00
padding: const EdgeInsets . only ( top: 40 ) ,
2022-04-28 16:17:54 +02:00
color: Colors . transparent ,
) ,
Container (
2022-05-12 05:28:04 +02:00
decoration: BoxDecoration (
2022-05-15 10:14:07 +02:00
borderRadius: BorderRadius . circular ( 18 ) ,
2022-05-12 05:28:04 +02:00
color: const Color ( 0xff8B0000 ) ,
) ,
2022-05-15 10:14:07 +02: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 16:17:54 +02:00
) ,
) ,
Container (
2022-04-28 21:20:36 +02:00
padding: const EdgeInsets . only ( top: 40 ) ,
2022-04-28 16:17:54 +02:00
color: Colors . transparent ,
) ,
2022-04-28 21:20:36 +02:00
ElevatedButton (
style: ButtonStyle (
foregroundColor:
2022-04-29 15:02:45 +02:00
MaterialStateProperty . all ( const Color ( 0xff8B0000 ) ) ,
2022-04-28 21:20:36 +02:00
backgroundColor:
2022-04-29 15:02:45 +02:00
MaterialStateProperty . all ( const Color ( 0xff8B0000 ) ) ,
2022-04-28 21:20:36 +02:00
shape: MaterialStateProperty . all < RoundedRectangleBorder > (
RoundedRectangleBorder (
borderRadius: BorderRadius . circular ( 18.0 ) ,
2022-05-10 06:52:50 +02:00
side: const BorderSide ( color: Color ( 0xff8B0000 ) ) ) ) ) ,
2022-04-28 21:20:36 +02:00
onPressed: ( ) {
2022-04-29 15:02:45 +02:00
Navigator . of ( context ) . pushReplacement ( MaterialPageRoute (
builder: ( context ) = > const Menu ( initialScreen: 4 ) ) ) ;
2022-04-28 21:20:36 +02:00
} ,
child: const Text (
' Transaction ' ,
style: TextStyle ( color: Colors . white , fontSize: 25 ) ,
2022-04-28 16:17:54 +02:00
) ,
) ,
] ,
) ,
) ;
2022-04-26 11:15:38 +02:00
}
}