|
|
|
@ -17,6 +17,7 @@ import 'package:huixiang/view_widget/my_appbar.dart';
|
|
|
|
|
import 'package:flutter_screenutil/flutter_screenutil.dart'; |
|
|
|
|
import 'package:pull_to_refresh/pull_to_refresh.dart'; |
|
|
|
|
import 'package:shared_preferences/shared_preferences.dart'; |
|
|
|
|
import 'package:shimmer/shimmer.dart'; |
|
|
|
|
|
|
|
|
|
import '../retrofit/data/member_recharge_list.dart'; |
|
|
|
|
import '../retrofit/data/rechargeActLists.dart'; |
|
|
|
@ -55,6 +56,7 @@ class _MineShopRecharge extends State<MineShopRecharge> {
|
|
|
|
|
String storeId; |
|
|
|
|
String minToken; |
|
|
|
|
final RefreshController refreshController = RefreshController(); |
|
|
|
|
int networkStatus = 0; |
|
|
|
|
|
|
|
|
|
@override |
|
|
|
|
void dispose() { |
|
|
|
@ -87,9 +89,12 @@ class _MineShopRecharge extends State<MineShopRecharge> {
|
|
|
|
|
"id": widget.arguments["id"], |
|
|
|
|
"latitude": "", |
|
|
|
|
"longitude": "", |
|
|
|
|
}).catchError((onError) {}); |
|
|
|
|
}).catchError((onError) { |
|
|
|
|
networkStatus = -1; |
|
|
|
|
}); |
|
|
|
|
if (baseData != null && baseData.isSuccess) { |
|
|
|
|
vipCard = baseData.data; |
|
|
|
|
networkStatus = 1; |
|
|
|
|
} |
|
|
|
|
} finally { |
|
|
|
|
if (isSingle) |
|
|
|
@ -129,9 +134,12 @@ class _MineShopRecharge extends State<MineShopRecharge> {
|
|
|
|
|
queryRechargeActList() async { |
|
|
|
|
try { |
|
|
|
|
BaseData<List<MemberRechargeList>> baseData = |
|
|
|
|
await minService.memberRechargeList().catchError((onError) {}); |
|
|
|
|
await minService.memberRechargeList().catchError((onError) { |
|
|
|
|
networkStatus = -1; |
|
|
|
|
}); |
|
|
|
|
if (baseData != null && baseData.isSuccess) { |
|
|
|
|
memberRechargeList = baseData.data; |
|
|
|
|
networkStatus = 1; |
|
|
|
|
} |
|
|
|
|
} finally { |
|
|
|
|
addLoadCount(); |
|
|
|
@ -224,7 +232,7 @@ class _MineShopRecharge extends State<MineShopRecharge> {
|
|
|
|
|
Widget build(BuildContext context) { |
|
|
|
|
return Scaffold( |
|
|
|
|
appBar: MyAppBar( |
|
|
|
|
title: "店铺充值", |
|
|
|
|
title: S.of(context).dianpuchongzhi, |
|
|
|
|
titleColor: Colors.black, |
|
|
|
|
background: Colors.white, |
|
|
|
|
brightness: Brightness.dark, |
|
|
|
@ -242,7 +250,9 @@ class _MineShopRecharge extends State<MineShopRecharge> {
|
|
|
|
|
controller: refreshController, |
|
|
|
|
onRefresh: _onRefresh, |
|
|
|
|
physics: BouncingScrollPhysics(), |
|
|
|
|
child: Column( |
|
|
|
|
child: networkStatus == 0 |
|
|
|
|
? skeletonScreen() |
|
|
|
|
: Column( |
|
|
|
|
children: [ |
|
|
|
|
shopRechargeCard(), |
|
|
|
|
(memberRechargeList != null && |
|
|
|
@ -273,8 +283,8 @@ class _MineShopRecharge extends State<MineShopRecharge> {
|
|
|
|
|
isShowBtn: false, |
|
|
|
|
text: "当前店铺暂无充值套餐~", |
|
|
|
|
fontSize: 16.sp, |
|
|
|
|
margin: |
|
|
|
|
EdgeInsets.only(top: 90.h, left: 60.w, right: 60.w), |
|
|
|
|
margin: EdgeInsets.only( |
|
|
|
|
top: 90.h, left: 60.w, right: 60.w), |
|
|
|
|
), |
|
|
|
|
if (memberRechargeList != null && |
|
|
|
|
(memberRechargeList?.length ?? 0) > 0) |
|
|
|
@ -380,7 +390,10 @@ class _MineShopRecharge extends State<MineShopRecharge> {
|
|
|
|
|
borderRadius: BorderRadius.circular(27), |
|
|
|
|
), |
|
|
|
|
margin: EdgeInsets.only( |
|
|
|
|
top: 12.h, left: 16.w, right: 16.w, bottom: 21.h), |
|
|
|
|
top: 12.h, |
|
|
|
|
left: 16.w, |
|
|
|
|
right: 16.w, |
|
|
|
|
bottom: 21.h), |
|
|
|
|
child: Text( |
|
|
|
|
S.of(context).querenchongzhi, |
|
|
|
|
style: TextStyle( |
|
|
|
@ -410,6 +423,334 @@ class _MineShopRecharge extends State<MineShopRecharge> {
|
|
|
|
|
return 0xFF32A060; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
///整体骨架屏 |
|
|
|
|
Widget skeletonScreen() { |
|
|
|
|
return Container( |
|
|
|
|
child: Column( |
|
|
|
|
children: [ |
|
|
|
|
Column( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
children: [ |
|
|
|
|
Container( |
|
|
|
|
decoration: BoxDecoration( |
|
|
|
|
borderRadius: new BorderRadius.only( |
|
|
|
|
topLeft: Radius.circular(6), |
|
|
|
|
topRight: Radius.circular(6), |
|
|
|
|
), |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
), |
|
|
|
|
height: 62.h, |
|
|
|
|
), |
|
|
|
|
Container( |
|
|
|
|
decoration: BoxDecoration( |
|
|
|
|
borderRadius: new BorderRadius.only( |
|
|
|
|
bottomRight: Radius.circular(6), |
|
|
|
|
topRight: Radius.circular(6), |
|
|
|
|
), |
|
|
|
|
color: Colors.white, |
|
|
|
|
), |
|
|
|
|
padding: EdgeInsets.all(12.h), |
|
|
|
|
child: Column( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
children: [ |
|
|
|
|
Row( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
children: [ |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 68.w, |
|
|
|
|
height: 17.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 120.w, |
|
|
|
|
height: 17.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
SizedBox( |
|
|
|
|
height: 4.h, |
|
|
|
|
), |
|
|
|
|
Row( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center, |
|
|
|
|
children: [ |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 99.w, |
|
|
|
|
height: 34.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
Spacer(), |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 48.w, |
|
|
|
|
height: 17.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
SizedBox( |
|
|
|
|
width: 2, |
|
|
|
|
), |
|
|
|
|
Image.asset( |
|
|
|
|
"assets/image/icon_right_z.webp", |
|
|
|
|
width: 16, |
|
|
|
|
height: 16, |
|
|
|
|
color: Color(0xFF262626), |
|
|
|
|
) |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
Expanded( |
|
|
|
|
child: ListView.builder( |
|
|
|
|
itemCount: 4, |
|
|
|
|
physics: BouncingScrollPhysics(), |
|
|
|
|
shrinkWrap: true, |
|
|
|
|
itemBuilder: (context, position) { |
|
|
|
|
return Container( |
|
|
|
|
width: double.infinity, |
|
|
|
|
height: 69.h, |
|
|
|
|
decoration: BoxDecoration( |
|
|
|
|
borderRadius: BorderRadius.circular(4), |
|
|
|
|
color: Colors.white), |
|
|
|
|
margin: EdgeInsets.only(bottom: 14.h, left: 14.w, right: 14.w), |
|
|
|
|
padding: EdgeInsets.only(left: 16), |
|
|
|
|
child: Flex( |
|
|
|
|
direction: Axis.horizontal, |
|
|
|
|
children: [ |
|
|
|
|
Row( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.end, |
|
|
|
|
children: [ |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 20.w, |
|
|
|
|
height: 15.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
SizedBox( |
|
|
|
|
width: 10.w, |
|
|
|
|
), |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 50.w, |
|
|
|
|
height: 25.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
Container( |
|
|
|
|
width: 1.w, |
|
|
|
|
height: 37.h, |
|
|
|
|
color: Color(0xFF979797), |
|
|
|
|
margin: EdgeInsets.only(right: 16.w, left: 12), |
|
|
|
|
), |
|
|
|
|
Expanded( |
|
|
|
|
flex: 2, |
|
|
|
|
child: Column( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
children: [ |
|
|
|
|
Row( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.end, |
|
|
|
|
children: [ |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 50.w, |
|
|
|
|
height: 17.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
SizedBox( |
|
|
|
|
width: 10.w, |
|
|
|
|
), |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 48.w, |
|
|
|
|
height: 25.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
SizedBox( |
|
|
|
|
height: 4.h, |
|
|
|
|
), |
|
|
|
|
Row( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center, |
|
|
|
|
children: [ |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 50.w, |
|
|
|
|
height: 17.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
Icon( |
|
|
|
|
Icons.chevron_right, |
|
|
|
|
size: 20, |
|
|
|
|
color: Color(0xFF868686), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
) |
|
|
|
|
], |
|
|
|
|
)) |
|
|
|
|
], |
|
|
|
|
)); |
|
|
|
|
}, |
|
|
|
|
)), |
|
|
|
|
Column( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceAround, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
children: [ |
|
|
|
|
Padding( |
|
|
|
|
padding: EdgeInsets.only(bottom: 16.h), |
|
|
|
|
child: Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 64.w, |
|
|
|
|
height: 21.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
Row( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center, |
|
|
|
|
children: [ |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 20.h, |
|
|
|
|
height: 20.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
Padding( |
|
|
|
|
padding: EdgeInsets.only(left: 8.w), |
|
|
|
|
child: Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 51.w, |
|
|
|
|
height: 17.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
Spacer(), |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
decoration: BoxDecoration( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
borderRadius: BorderRadius.circular(100), |
|
|
|
|
), |
|
|
|
|
width: 15.h, |
|
|
|
|
height: 15.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
SizedBox(height: 10.h), |
|
|
|
|
Row( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center, |
|
|
|
|
children: [ |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 20.h, |
|
|
|
|
height: 20.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
Padding( |
|
|
|
|
padding: EdgeInsets.only(left: 8.w), |
|
|
|
|
child: Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
width: 51.w, |
|
|
|
|
height: 17.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
Spacer(), |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
decoration: BoxDecoration( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
borderRadius: BorderRadius.circular(100), |
|
|
|
|
), |
|
|
|
|
width: 15.h, |
|
|
|
|
height: 15.h, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
Shimmer.fromColors( |
|
|
|
|
baseColor: Color(0XFFD8D8D8), |
|
|
|
|
highlightColor: Color(0XFFD8D8D8), |
|
|
|
|
child: Container( |
|
|
|
|
height: 56.h, |
|
|
|
|
width: double.infinity, |
|
|
|
|
alignment: Alignment.center, |
|
|
|
|
decoration: BoxDecoration( |
|
|
|
|
color: Color(0XFFD8D8D8), |
|
|
|
|
borderRadius: BorderRadius.circular(27), |
|
|
|
|
), |
|
|
|
|
margin: EdgeInsets.only( |
|
|
|
|
top: 12.h, left: 16.w, right: 16.w, bottom: 21.h), |
|
|
|
|
), |
|
|
|
|
) |
|
|
|
|
], |
|
|
|
|
)); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
///卡片详情 |
|
|
|
|
Widget shopRechargeCard() { |
|
|
|
|
return GestureDetector( |
|
|
|
@ -617,9 +958,7 @@ class _MineShopRecharge extends State<MineShopRecharge> {
|
|
|
|
|
), |
|
|
|
|
TextSpan( |
|
|
|
|
text: |
|
|
|
|
"${((memberRechargeList?.limitNum ?? 0) != 0 && ((memberRechargeList?.limitNum ?? 0) - (memberRechargeList?.useNum ?? 0) <= 0)) ? |
|
|
|
|
(AppUtils.calculateDouble(double.tryParse(memberRechargeList.rechargeMoney) ?? 0)) : |
|
|
|
|
(AppUtils.calculateDouble((double.tryParse(memberRechargeList.rechargeMoney) ?? 0) + (double.tryParse(memberRechargeList.giftdMoney) ?? 0) + ((double.tryParse(memberRechargeList.rechargeMoney) ?? 0) - ((double.tryParse(memberRechargeList.rechargeMoney) ?? 0) * (discount / 100)))))}元", |
|
|
|
|
"${((memberRechargeList?.limitNum ?? 0) != 0 && ((memberRechargeList?.limitNum ?? 0) - (memberRechargeList?.useNum ?? 0) <= 0)) ? (AppUtils.calculateDouble(double.tryParse(memberRechargeList.rechargeMoney) ?? 0)) : (AppUtils.calculateDouble((double.tryParse(memberRechargeList.rechargeMoney) ?? 0) + (double.tryParse(memberRechargeList.giftdMoney) ?? 0) + ((double.tryParse(memberRechargeList.rechargeMoney) ?? 0) - ((double.tryParse(memberRechargeList.rechargeMoney) ?? 0) * (discount / 100)))))}元", |
|
|
|
|
style: TextStyle( |
|
|
|
|
fontSize: 18.sp, |
|
|
|
|
fontFamily: 'JDZhengHT', |
|
|
|
@ -677,7 +1016,7 @@ class _MineShopRecharge extends State<MineShopRecharge> {
|
|
|
|
|
checkIndex != index |
|
|
|
|
? "assets/image/icon_radio_unselected.webp" |
|
|
|
|
: "assets/image/icon_radio_selected.webp", |
|
|
|
|
width: 15.w, |
|
|
|
|
width: 15.h, |
|
|
|
|
height: 15.h, |
|
|
|
|
), |
|
|
|
|
); |
|
|
|
|