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.
489 lines
18 KiB
489 lines
18 KiB
import 'dart:io'; |
|
|
|
import 'package:flutter/cupertino.dart'; |
|
import 'package:flutter/material.dart'; |
|
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart'; |
|
import 'package:flutter_swiper_view/flutter_swiper_view.dart'; |
|
import 'package:huixiang/generated/l10n.dart'; |
|
import 'package:huixiang/data/store_info.dart'; |
|
import 'package:huixiang/utils/flutter_utils.dart'; |
|
import 'package:huixiang/utils/font_weight.dart'; |
|
import 'package:huixiang/view_widget/custom_image.dart'; |
|
import 'package:flutter_screenutil/flutter_screenutil.dart'; |
|
import 'package:huixiang/view_widget/round_button.dart'; |
|
import 'package:url_launcher/url_launcher.dart'; |
|
|
|
import '../../utils/location.dart'; |
|
|
|
class StoreInfos extends StatefulWidget { |
|
final StoreInfo? storeInfo; |
|
|
|
StoreInfos(this.storeInfo); |
|
|
|
@override |
|
State<StatefulWidget> createState() { |
|
return _StoreInfos(); |
|
} |
|
} |
|
|
|
class _StoreInfos extends State<StoreInfos> { |
|
@override |
|
Widget build(BuildContext context) { |
|
return Container( |
|
margin: EdgeInsets.fromLTRB(17, 20, 15, 8), |
|
padding: EdgeInsets.fromLTRB(10, 20, 10, 14), |
|
width: double.infinity, |
|
decoration: BoxDecoration( |
|
color: Colors.white, |
|
borderRadius: BorderRadius.circular(8), |
|
boxShadow: [ |
|
BoxShadow( |
|
color: Colors.black.withAlpha(25), |
|
offset: Offset(0, 1), |
|
blurRadius: 12, |
|
spreadRadius: 0, |
|
), |
|
], |
|
), |
|
child: Row( |
|
mainAxisSize: MainAxisSize.min, |
|
children: [ |
|
Expanded( |
|
flex: 1, |
|
child: Column( |
|
mainAxisAlignment: MainAxisAlignment.start, |
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
children: [ |
|
Text( |
|
widget.storeInfo?.storeName ?? "", |
|
overflow: TextOverflow.ellipsis, |
|
style: TextStyle( |
|
fontSize: 18.sp, |
|
color: Colors.black, |
|
fontWeight: MyFontWeight.medium, |
|
), |
|
), |
|
SizedBox( |
|
height: 8.h, |
|
), |
|
Row( |
|
children: [ |
|
Text( |
|
S |
|
.of(context) |
|
.ren(widget.storeInfo!.perCapitaConsumption ?? ""), |
|
overflow: TextOverflow.ellipsis, |
|
style: TextStyle( |
|
fontSize: 14.sp, |
|
fontWeight: MyFontWeight.regular, |
|
color: Color(0xFF353535), |
|
), |
|
), |
|
SizedBox( |
|
width: 22.w, |
|
), |
|
Row( |
|
children: |
|
itemServer(widget.storeInfo?.businessService ?? ""), |
|
), |
|
], |
|
), |
|
SizedBox( |
|
height: 12.h, |
|
), |
|
Text( |
|
widget.storeInfo?.address ?? "", |
|
maxLines: 2, |
|
textAlign: TextAlign.justify, |
|
style: TextStyle( |
|
color: Color(0xFF353535), |
|
fontWeight: MyFontWeight.regular, |
|
fontSize: 12.sp, |
|
), |
|
), |
|
SizedBox( |
|
height: 6.h, |
|
), |
|
Text( |
|
S.of(context).yingyeshijian(widget.storeInfo == null |
|
? "" |
|
: ((widget.storeInfo!.openStartTime?.isEmpty ?? true) && |
|
widget.storeInfo?.openEndTime == null) |
|
? S.of(context).quantian |
|
: "${widget.storeInfo?.openStartTime?.substring(0, widget.storeInfo?.openStartTime?.lastIndexOf(":"))} " |
|
"- ${widget.storeInfo?.openEndTime?.substring(0, widget.storeInfo?.openEndTime?.lastIndexOf(":"))}"), |
|
style: TextStyle( |
|
color: Color(0xFF353535), |
|
fontWeight: MyFontWeight.regular, |
|
fontSize: 12.sp, |
|
), |
|
), |
|
], |
|
)), |
|
Column( |
|
children: [ |
|
MImage( |
|
widget.storeInfo!.logo ?? "", |
|
width: 69, |
|
height: 69, |
|
fit: BoxFit.cover, |
|
errorSrc: "assets/image/default_1.webp", |
|
fadeSrc: "assets/image/default_1.webp", |
|
), |
|
SizedBox( |
|
height: 21.h, |
|
), |
|
Row( |
|
mainAxisAlignment: MainAxisAlignment.spaceBetween, |
|
crossAxisAlignment: CrossAxisAlignment.end, |
|
children: [ |
|
InkWell( |
|
onTap: () { |
|
if (widget.storeInfo == null || |
|
widget.storeInfo?.latitude == null || |
|
widget.storeInfo?.longitude == null || |
|
widget.storeInfo?.latitude == "" || |
|
widget.storeInfo?.longitude == "") return; |
|
showMapSelect(); |
|
}, |
|
child: Image.asset( |
|
"assets/image/icon_union_location.webp", |
|
width: 24.w, |
|
height: 24.h, |
|
), |
|
), |
|
SizedBox( |
|
width: 16.w, |
|
), |
|
InkWell( |
|
onTap: () { |
|
showCallMobile(); |
|
}, |
|
child: Image.asset( |
|
"assets/image/icon_union_call.webp", |
|
width: 24, |
|
height: 24, |
|
), |
|
), |
|
], |
|
), |
|
], |
|
), |
|
], |
|
), |
|
); |
|
// return AspectRatio( |
|
// aspectRatio: 1, |
|
// child: Container( |
|
// margin: EdgeInsets.fromLTRB(16, 20, 16, 8), |
|
// padding: EdgeInsets.fromLTRB(10, 20, 10, 14), |
|
// decoration: BoxDecoration( |
|
// color: Colors.white, |
|
// borderRadius: BorderRadius.circular(8), |
|
// boxShadow: [ |
|
// BoxShadow( |
|
// color: Colors.black.withAlpha(25), |
|
// offset: Offset(0, 1), |
|
// blurRadius: 12, |
|
// spreadRadius: 0, |
|
// ), |
|
// ], |
|
// ), |
|
// child: Column( |
|
// mainAxisAlignment: MainAxisAlignment.spaceAround, |
|
// crossAxisAlignment: CrossAxisAlignment.start, |
|
// children: [ |
|
// AspectRatio( |
|
// aspectRatio: 1.8, |
|
// child: buildSwiper(), |
|
// ), |
|
// Expanded( |
|
// child: Container( |
|
// margin: EdgeInsets.only( |
|
// left: 10.w, |
|
// right: 10.w, |
|
// top: 16.h, |
|
// ), |
|
// child: Column( |
|
// mainAxisAlignment: |
|
// MainAxisAlignment.spaceBetween, |
|
// crossAxisAlignment: |
|
// CrossAxisAlignment.start, |
|
// children: [ |
|
// Row( |
|
// children: [ |
|
// Expanded( |
|
// child: Container( |
|
// alignment: |
|
// Alignment.centerLeft, |
|
// child: Text( |
|
// widget.storeInfo != null |
|
// ? widget.storeInfo.storeName |
|
// : "", |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// fontSize: 16.sp, |
|
// color: Colors.black, |
|
// fontWeight: MyFontWeight.medium, |
|
// ), |
|
// ), |
|
// ), |
|
// ), |
|
// Text( |
|
// S.of(context).ren( |
|
// widget.storeInfo != null |
|
// ? widget.storeInfo |
|
// .perCapitaConsumption |
|
// : "", |
|
// ), |
|
// overflow: TextOverflow.ellipsis, |
|
// style: TextStyle( |
|
// fontSize: 14.sp, |
|
// fontWeight: MyFontWeight.regular, |
|
// color: Color(0xFF353535), |
|
// ), |
|
// ), |
|
// ], |
|
// ), |
|
// Text( |
|
// widget.storeInfo != null |
|
// ? widget.storeInfo.address |
|
// : "", |
|
// maxLines: 2, |
|
// textAlign: TextAlign.justify, |
|
// style: TextStyle( |
|
// color: Color(0xFF353535), |
|
// fontWeight: MyFontWeight.regular, |
|
// fontSize: 12.sp, |
|
// ), |
|
// ), |
|
// Row( |
|
// children: itemServer( |
|
// widget.storeInfo != null |
|
// ? widget.storeInfo.businessService |
|
// : "", |
|
// ), |
|
// ), |
|
// Row( |
|
// mainAxisAlignment: MainAxisAlignment.spaceBetween, |
|
// crossAxisAlignment: CrossAxisAlignment.end, |
|
// children: [ |
|
// Expanded( |
|
// child: Text( |
|
// S.of(context).yingyeshijian(widget.storeInfo == |
|
// null |
|
// ? "" |
|
// : (widget.storeInfo.openStartTime == |
|
// null && |
|
// widget.storeInfo |
|
// .openEndTime == |
|
// null) |
|
// ? S.of(context).quantian |
|
// : "${widget.storeInfo.openStartTime.substring(0, widget.storeInfo.openStartTime.lastIndexOf(":"))} " |
|
// "- ${widget.storeInfo.openEndTime.substring(0, widget.storeInfo.openEndTime.lastIndexOf(":"))}"), |
|
// style: TextStyle( |
|
// color: Color(0xFF353535), |
|
// fontWeight: MyFontWeight.regular, |
|
// fontSize: 12.sp, |
|
// ), |
|
// ), |
|
// ), |
|
// SizedBox( |
|
// width: 16.w, |
|
// ), |
|
// InkWell( |
|
// onTap: () { |
|
// if (widget.storeInfo == null || |
|
// widget.storeInfo.latitude == |
|
// null || |
|
// widget.storeInfo.longitude == |
|
// null || |
|
// widget.storeInfo.latitude == "" || |
|
// widget.storeInfo.longitude == "") |
|
// return; |
|
// Navigator.of(context).pushNamed( |
|
// '/router/location_map', |
|
// arguments: { |
|
// "lat": widget.storeInfo.latitude, |
|
// "lng": |
|
// widget.storeInfo.longitude, |
|
// "storeName": |
|
// widget.storeInfo.storeName, |
|
// }); |
|
// }, |
|
// child: Image.asset( |
|
// "assets/image/icon_union_location.webp", |
|
// width: 24.w, |
|
// height: 24.h, |
|
// ), |
|
// ), |
|
// SizedBox( |
|
// width: 16.w, |
|
// ), |
|
// InkWell( |
|
// onTap: () { |
|
// showCallMobile(); |
|
// }, |
|
// child: Image.asset( |
|
// "assets/image/icon_union_call.webp", |
|
// width: 24, |
|
// height: 24, |
|
// ), |
|
// ), |
|
// ], |
|
// ), |
|
// ], |
|
// ), |
|
// ), |
|
// flex: 1, |
|
// ), |
|
// ], |
|
// ), |
|
// ), |
|
// ); |
|
} |
|
|
|
Widget buildSwiper() { |
|
return Container( |
|
child: Swiper( |
|
pagination: SwiperPagination( |
|
alignment: Alignment.bottomCenter, |
|
builder: DotSwiperPaginationBuilder( |
|
size: 8.w, |
|
activeSize: 8.w, |
|
space: 5.w, |
|
activeColor: Colors.white, |
|
color: Colors.white.withAlpha(76), |
|
), |
|
), |
|
itemBuilder: (context, position) { |
|
return Container( |
|
margin: EdgeInsets.only(left: 10.w, right: 10.w), |
|
child: MImage( |
|
(position < (widget.storeInfo!.bannerList?.length ?? 0)) |
|
? (widget.storeInfo!.bannerList![position].imgUrl ?? "") |
|
: "", |
|
fit: BoxFit.cover, |
|
radius: BorderRadius.circular(4), |
|
errorSrc: "assets/image/default_2_1.webp", |
|
fadeSrc: "assets/image/default_2_1.webp", |
|
), |
|
); |
|
}, |
|
itemCount: widget.storeInfo?.bannerList?.length ?? 1, |
|
)); |
|
} |
|
|
|
List<Widget> itemServer(String businessService) { |
|
if (businessService == "") return []; |
|
var list = businessService.split(","); |
|
return list |
|
.map((e) => Container( |
|
margin: EdgeInsets.only(right: 8.w), |
|
child: RoundButton( |
|
height: 14.h * AppUtils.textScale(context), |
|
text: "$e", |
|
backgroup: Color(0xFFFF7A1A), |
|
padding: EdgeInsets.only( |
|
left: 2.w, |
|
right: 2.w, |
|
), |
|
fontSize: 10.sp, |
|
textColor: Colors.white, |
|
), |
|
)) |
|
.toList(); |
|
} |
|
|
|
showCallMobile() { |
|
showCupertinoModalPopup( |
|
context: context, |
|
builder: (context) { |
|
return CupertinoActionSheet( |
|
title: Text(S.of(context).bodadianhua), |
|
actions: [ |
|
if (widget.storeInfo?.tel?.isNotEmpty ?? false) |
|
CupertinoActionSheetAction( |
|
child: Text(widget.storeInfo!.tel ?? ""), |
|
onPressed: () { |
|
callMobile(widget.storeInfo!.tel); |
|
Navigator.of(context).pop(); |
|
}, |
|
isDefaultAction: true, |
|
isDestructiveAction: false, |
|
), |
|
], |
|
cancelButton: CupertinoActionSheetAction( |
|
onPressed: () { |
|
Navigator.of(context).pop(); |
|
}, |
|
child: Text(S.of(context).quxiao), |
|
isDestructiveAction: true, |
|
), |
|
); |
|
}, |
|
); |
|
} |
|
|
|
callMobile(mobile) async { |
|
String url = "tel:$mobile"; |
|
if (await canLaunch(url)) { |
|
await launch(url); |
|
} else { |
|
throw 'Could not launch $url'; |
|
} |
|
} |
|
|
|
showMapSelect() { |
|
showCupertinoModalPopup( |
|
context: context, |
|
builder: (context) { |
|
return CupertinoActionSheet( |
|
actions: [ |
|
CupertinoActionSheetAction( |
|
child: Text( |
|
"使用高德地图导航", |
|
style: TextStyle( |
|
fontWeight: MyFontWeight.regular, |
|
), |
|
), |
|
onPressed: () { |
|
onOpenBaiduMap(); |
|
Navigator.of(context).pop(); |
|
}, |
|
isDefaultAction: true, |
|
isDestructiveAction: false, |
|
), |
|
], |
|
cancelButton: CupertinoActionSheetAction( |
|
onPressed: () { |
|
Navigator.of(context).pop(); |
|
}, |
|
child: Text( |
|
S.of(context).quxiao, |
|
style: TextStyle( |
|
color: Colors.blue, |
|
), |
|
), |
|
isDestructiveAction: true, |
|
), |
|
); |
|
}); |
|
} |
|
|
|
void onOpenBaiduMap() async { |
|
LocationInstance.instance.startLocation(context, (locationData) { |
|
String url = |
|
"${Platform.isIOS ? 'ios' : 'android'}amap://path?sourceApplication=haixia&sid=" |
|
"&slat=${locationData?.latitude.toStringAsFixed(8)}&slon=${locationData?.longitude.toStringAsFixed(8)}&sname=&did=&dlat=${widget.storeInfo?.latitude}&dlon=${widget.storeInfo?.longitude}&dname=&dev=0&t=0"; |
|
launch(url).then((value) { |
|
if (!value) { |
|
SmartDialog.showToast( |
|
"未检测到安装高德地图", |
|
alignment: Alignment.center, |
|
); |
|
} |
|
}); |
|
}); |
|
} |
|
}
|
|
|