2022-04-28 12:12:26 +07:00
|
|
|
import 'dart:convert';
|
2022-05-16 07:51:47 +07:00
|
|
|
import 'package:flutter/material.dart';
|
2022-05-12 21:46:55 +07:00
|
|
|
|
2023-09-22 14:29:07 +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
|
|
|
}
|
|
|
|
|
2022-05-12 10:27:43 +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,
|
|
|
|
};
|
2022-05-12 10:27:43 +07:00
|
|
|
|
2023-11-10 21:23:14 +07:00
|
|
|
await clearCart();
|
2022-05-12 10:27:43 +07:00
|
|
|
|
2023-11-10 21:23:14 +07:00
|
|
|
var statusCode = await loadCheckout(data);
|
|
|
|
return statusCode;
|
2022-05-12 10:27:43 +07:00
|
|
|
}
|
|
|
|
|
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,
|
2022-05-12 10:27:43 +07:00
|
|
|
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 {
|
2022-05-14 23:29:43 +07:00
|
|
|
Navigator.pushNamed(context, '/login');
|
2022-04-29 04:25:52 +07:00
|
|
|
}
|
2022-05-12 10:27:43 +07:00
|
|
|
});
|
2022-04-28 11:35:24 +07:00
|
|
|
},
|
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;
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|