You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

224 lines
8.7 KiB

3 years ago
import 'package:cached_network_image/cached_network_image.dart';
import 'package:flutter/material.dart';
import 'package:location/location.dart';
import 'package:teso/Pages/Sub_Pages/@Generic/prominentDisclosure.dart';
import 'package:teso/Pages/Sub_Pages/Coupons/CouponLocation.dart';
import 'package:teso/providers/pageAnimations.dart';
import 'package:teso/util/SizeConfig.dart';
import 'package:teso/util/consts.dart';
import 'package:teso/Classes/API Clasess/CouponDetails.dart';
import 'package:flutter_countdown_timer/flutter_countdown_timer.dart';
buildMyCoupons(BuildContext context, CouponDetails coupon, Function dialog,
Function scan) {
SizeConfig().init(context);
return InkWell(
onTap: () => dialog(context, coupon),
child: Container(
width: MediaQuery.of(context).size.width,
height: 100,
child: Row(
mainAxisSize: MainAxisSize.max,
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
Container(
width: 80,
height: 80,
decoration: BoxDecoration(
border: Border.all(
color: Colors.grey,
width: 0.5,
),
borderRadius: BorderRadius.only(
topRight: Radius.circular(30),
topLeft: Radius.circular(30),
bottomLeft: Radius.circular(30),
bottomRight: Radius.circular(30),
),
),
child: ClipRRect(
borderRadius: BorderRadius.only(
topLeft: Radius.circular(30.0),
topRight: Radius.circular(30.0),
bottomLeft: Radius.circular(30),
bottomRight: Radius.circular(30),
),
child: CachedNetworkImage(
imageUrl: productURL + coupon.targetProduct.productImage,
imageBuilder: (context, imageProvider) => Image(
width: MediaQuery.of(context).size.width * 0.28,
height: 110,
fit: BoxFit.fill,
image: imageProvider,
),
),
),
),
Container(
width: SizeConfig.safeBlockHorizontal * 50,
height: 80,
padding: EdgeInsets.all(5),
child: Center(
child: Column(
children: [
Container(
width: double.infinity,
child: Text(
"Item Name : " + coupon.targetProduct.productName,
style: TextStyle(
fontSize: SizeConfig.safeBlockHorizontal * 2.8,
),
),
),
Container(
width: double.infinity,
child: Text(
"Shop Name : " + coupon.issuer.businessName,
style: TextStyle(
fontSize: SizeConfig.safeBlockHorizontal * 2.8,
),
),
),
Container(
width: double.infinity,
child: CountdownTimer(
endTime: coupon.expiration.millisecondsSinceEpoch,
widgetBuilder: (context, time) {
int day = time.days;
int hours = time.hours;
int min = time.min;
int sec = time.sec;
if (time.min == null) min = 0;
if (time.days == null) day = 0;
if (time.hours == null) hours = 0;
if (time.sec == null) sec = 0;
if (time == null) {
return Text('Calculating..');
} else if (time.days == null || time.days < 1) {
return Text(
"Expires in : ${hours}h : ${min}m : ${sec}s",
style: TextStyle(
color: Colors.red,
fontWeight: FontWeight.bold,
fontSize: SizeConfig.safeBlockHorizontal * 2.8,
),
);
} else if (time.days == 1) {
return Text(
"Expires in : ${day}day, ${hours}h : ${min}m : ${sec}s",
style: TextStyle(
color: Colors.green,
fontWeight: FontWeight.bold,
fontSize: SizeConfig.safeBlockHorizontal * 2.8,
),
);
} else {
return Text(
"Expires in : ${day}days, ${hours}h : ${min}m : ${sec}s",
style: TextStyle(
color: Colors.green,
fontWeight: FontWeight.bold,
fontSize: SizeConfig.safeBlockHorizontal * 2.8,
),
);
}
},
),
//Text("Expires : " + "00:00.0"),
),
Container(
width: double.infinity,
child: Text(
"Pay only : GH¢ " +
(coupon.targetProduct.unitPrice -
(coupon.targetProduct.unitPrice *
(coupon.lowerLimit / 100)))
.toStringAsFixed(2),
style: TextStyle(
color: Colors.red,
fontSize: SizeConfig.safeBlockHorizontal * 2.8,
),
),
),
],
),
),
),
new Wrap(
direction: Axis.vertical,
children: [
Container(
width: SizeConfig.safeBlockHorizontal * 25,
child: ElevatedButton(
style: ElevatedButton.styleFrom(
// shape: RoundedRectangleBorder(
// borderRadius: BorderRadius.all(
// Radius.circular(20.0),
// ),
// ),
primary: tesoBlue,
),
onPressed: () async {
PermissionStatus alreadyConsent =
await Location.instance.hasPermission();
if (alreadyConsent != PermissionStatus.granted) {
bool results = await Navigator.push(
context,
PageTransition(
child: ProminentDisclosure(),
type: PageTransitionType.leftToRight));
if (results) {
await Location.instance.requestPermission();
Navigator.push(
context,
PageTransition(
type: PageTransitionType.leftToRight,
child: CouponLocator(
shop: coupon.issuer,
),
),
);
}
} else {
Navigator.push(
context,
PageTransition(
type: PageTransitionType.leftToRight,
child: CouponLocator(
shop: coupon.issuer,
),
),
);
}
},
child: Text(
"Location",
style: TextStyle(
color: Colors.white,
),
),
),
),
Container(
width: SizeConfig.safeBlockHorizontal * 25,
child: ElevatedButton(
style: ElevatedButton.styleFrom(
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.all(
Radius.circular(20.0),
),
),
primary: accentMain,
),
onPressed: () => scan(context, coupon),
child: Text("Redeem"),
),
),
],
),
],
),
),
);
}