app/lib/components/checkout_form.dart

136 lines
4 KiB
Dart
Raw Normal View History

import 'dart:convert';
2022-05-16 07:51:47 +07:00
import 'package:flutter/material.dart';
2022-05-12 21:46:55 +07:00
import 'package:nekoya_app/api/api.dart';
import 'package:nekoya_app/data/auth.dart';
import 'package:nekoya_app/data/cart.dart';
2022-04-28 09:12:11 +07:00
2022-04-28 09:12:46 +07:00
class CheckoutForm extends StatefulWidget {
2022-04-29 02:20:36 +07:00
const CheckoutForm({Key? key}) : super(key: key);
2022-04-28 09:12:46 +07:00
@override
State<CheckoutForm> createState() => _CheckoutFormState();
}
class _CheckoutFormState extends State<CheckoutForm> {
2022-05-12 22:10:04 +07:00
Future<dynamic> loadCheckout(checkoutData) async {
var session = await getSession();
var data = await checkoutPost(session, checkoutData);
return data;
2022-05-12 21:46:55 +07:00
}
Future submitForm(BuildContext context) async {
2023-11-10 21:23:14 +07:00
var currentCart = await viewCart();
var cartData = jsonEncode(currentCart).toString();
Map<String, dynamic> data = {
"firstName": 'Moe',
"lastName": 'Poi',
"phoneNumber": '081234567890',
"streetAddress1": 'isekai',
"streetAddress2": '-',
"region": '-',
"province": '-',
"city": '-',
"district": '-',
"subDistrict": '-',
"postalCode": '12345',
"logistic": 'JNE',
"data": cartData,
};
2023-11-10 21:23:14 +07:00
await clearCart();
2023-11-10 21:23:14 +07:00
var statusCode = await loadCheckout(data);
return statusCode;
}
2022-04-28 09:12:46 +07:00
@override
Widget build(BuildContext context) {
2022-04-28 11:34:54 +07:00
return Container(
margin: const EdgeInsets.fromLTRB(10, 10, 10, 5),
child: Card(
color: const Color(0xff212226),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(15),
),
child: Container(
margin: const EdgeInsets.fromLTRB(5, 20, 5, 20),
padding: const EdgeInsets.fromLTRB(10, 0, 10, 0),
width: double.infinity,
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Column(
children: [
Padding(
padding: const EdgeInsets.symmetric(horizontal: 35),
child: Container(
padding: const EdgeInsets.only(top: 3, left: 3),
child: MaterialButton(
2022-05-23 09:03:36 +07:00
padding: const EdgeInsets.all(15.0),
2022-04-28 11:34:54 +07:00
minWidth: double.infinity,
height: 35,
onPressed: () {
2022-05-12 21:46:55 +07:00
checkSessionExist().then((isLoggedIn) {
if (isLoggedIn) {
2023-11-13 12:24:10 +07:00
clearCart()
.then((value) => showAlertDialog(context));
2022-05-12 21:46:55 +07:00
} else {
Navigator.pushNamed(context, '/login');
}
});
},
2022-04-28 11:34:54 +07:00
color: const Color(0xff8B0000),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(40)),
child: const Text(
"Pay",
style: TextStyle(
color: Colors.white,
fontWeight: FontWeight.w600,
2022-05-23 09:03:36 +07:00
fontSize: 20,
2022-04-28 11:34:54 +07:00
),
),
),
),
),
],
),
],
),
),
),
);
2022-04-28 09:12:46 +07:00
}
}
2023-11-13 12:24:10 +07:00
showAlertDialog(BuildContext context) {
Widget okButton = TextButton(
child: const Text("OK", style: TextStyle(color: Colors.white)),
onPressed: () {
Navigator.pop(context);
Navigator.pushReplacementNamed(context, '/products');
},
);
AlertDialog alert = AlertDialog(
backgroundColor: const Color(0xff1b1c1e),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(10),
),
content: const Text(
"Coming Soon",
style: TextStyle(color: Colors.white70),
),
actions: [
okButton,
],
);
showDialog(
context: context,
builder: (BuildContext context) {
return alert;
},
);
}