|
|
|
@ -5,6 +5,7 @@ import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart'; |
|
|
|
|
import 'package:huixiang/data/store_info.dart'; |
|
|
|
|
import 'package:huixiang/generated/l10n.dart'; |
|
|
|
|
import 'package:huixiang/utils/constant.dart'; |
|
|
|
|
import 'package:huixiang/utils/flutter_utils.dart'; |
|
|
|
|
import 'package:huixiang/utils/font_weight.dart'; |
|
|
|
|
import 'package:flutter_screenutil/flutter_screenutil.dart'; |
|
|
|
@ -30,150 +31,128 @@ class _StoreInfoView extends State<StoreInfoView> {
|
|
|
|
|
@override |
|
|
|
|
Widget build(BuildContext context) { |
|
|
|
|
return Container( |
|
|
|
|
height: MediaQuery.of(context).size.width >= 650 ? 180.h : 166.h, |
|
|
|
|
padding: EdgeInsets.all(12.w), |
|
|
|
|
decoration: BoxDecoration( |
|
|
|
|
color: Colors.white, |
|
|
|
|
borderRadius: BorderRadius.circular(8.w), |
|
|
|
|
), |
|
|
|
|
child: Column( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
children: [ |
|
|
|
|
Expanded( |
|
|
|
|
child: Row( |
|
|
|
|
children: [ |
|
|
|
|
Expanded( |
|
|
|
|
child: Column( |
|
|
|
|
children: [ |
|
|
|
|
Row( |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center, |
|
|
|
|
children: [ |
|
|
|
|
Expanded(child: Container( |
|
|
|
|
alignment: Alignment.centerLeft, |
|
|
|
|
child: Text( |
|
|
|
|
widget.storeInfo != null |
|
|
|
|
? (widget.storeInfo!.storeName ?? "") |
|
|
|
|
: "", |
|
|
|
|
overflow: TextOverflow.ellipsis, |
|
|
|
|
style: TextStyle( |
|
|
|
|
fontSize: 18.sp, |
|
|
|
|
color: Colors.black, |
|
|
|
|
fontWeight: MyFontWeight.medium, |
|
|
|
|
child: IntrinsicHeight( |
|
|
|
|
child: Column( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
children: [ |
|
|
|
|
Expanded( |
|
|
|
|
child: Row( |
|
|
|
|
children: [ |
|
|
|
|
Expanded( |
|
|
|
|
child: Column( |
|
|
|
|
children: [ |
|
|
|
|
Row( |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center, |
|
|
|
|
children: [ |
|
|
|
|
Expanded(child: Container( |
|
|
|
|
alignment: Alignment.centerLeft, |
|
|
|
|
child: Text( |
|
|
|
|
widget.storeInfo != null |
|
|
|
|
? (widget.storeInfo!.storeName ?? "") |
|
|
|
|
: "", |
|
|
|
|
overflow: TextOverflow.ellipsis, |
|
|
|
|
style: TextStyle( |
|
|
|
|
fontSize: 18.sp, |
|
|
|
|
color: Colors.black, |
|
|
|
|
fontWeight: MyFontWeight.medium, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
)), |
|
|
|
|
// GestureDetector( |
|
|
|
|
// behavior: HitTestBehavior.opaque, |
|
|
|
|
// onTap: (){ |
|
|
|
|
// Navigator.of(context).pushNamed('/router/store_html',arguments: {"remark":widget.storeInfo.remark}); |
|
|
|
|
// }, |
|
|
|
|
// child: Container( |
|
|
|
|
// padding: EdgeInsets.symmetric(horizontal:8.w,vertical:3.h), |
|
|
|
|
// decoration: BoxDecoration( |
|
|
|
|
// borderRadius: BorderRadius.circular(2), |
|
|
|
|
// border: Border.all( |
|
|
|
|
// color:Color(0xFFEDEDED), |
|
|
|
|
// ) |
|
|
|
|
// ), |
|
|
|
|
// child: Row( |
|
|
|
|
// children: [ |
|
|
|
|
// Text( |
|
|
|
|
// "店铺详情", |
|
|
|
|
// style: TextStyle( |
|
|
|
|
// fontWeight: MyFontWeight.regular, |
|
|
|
|
// fontSize: 12.sp, |
|
|
|
|
// color: Color(0xFF4C4C4C), |
|
|
|
|
// ), |
|
|
|
|
// ), |
|
|
|
|
// Image.asset( |
|
|
|
|
// "assets/image/icon_right_z.webp", |
|
|
|
|
// height:12.h, |
|
|
|
|
// width:12.w, |
|
|
|
|
// ) |
|
|
|
|
// ], |
|
|
|
|
// ), |
|
|
|
|
// ), |
|
|
|
|
// ) |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
Row( |
|
|
|
|
children: [ |
|
|
|
|
if( widget.storeInfo?.perCapitaConsumption != null && ( widget.storeInfo?.perCapitaConsumption ?? "") != "0") |
|
|
|
|
Padding(padding:EdgeInsets.only(right:20.w), |
|
|
|
|
child: Text( |
|
|
|
|
S.of(context).ren(widget.storeInfo?.perCapitaConsumption ?? ""), |
|
|
|
|
overflow: TextOverflow.ellipsis, |
|
|
|
|
style: TextStyle( |
|
|
|
|
fontSize: 12.sp, |
|
|
|
|
fontWeight: MyFontWeight.medium, |
|
|
|
|
color: Color(0xFF353535), |
|
|
|
|
), |
|
|
|
|
),), |
|
|
|
|
]..addAll(itemServer(widget.storeInfo?.businessService ?? "")), |
|
|
|
|
), |
|
|
|
|
Text( |
|
|
|
|
S.of(context).yingyeshijian(widget.storeInfo == null |
|
|
|
|
? "" |
|
|
|
|
: ((widget.storeInfo!.openStartTime?.isEmpty ?? true) && (widget.storeInfo!.openEndTime?.isEmpty ?? true)) |
|
|
|
|
? 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, |
|
|
|
|
)), |
|
|
|
|
// GestureDetector( |
|
|
|
|
// behavior: HitTestBehavior.opaque, |
|
|
|
|
// onTap: (){ |
|
|
|
|
// Navigator.of(context).pushNamed('/router/store_html',arguments: {"remark":widget.storeInfo.remark}); |
|
|
|
|
// }, |
|
|
|
|
// child: Container( |
|
|
|
|
// padding: EdgeInsets.symmetric(horizontal:8.w,vertical:3.h), |
|
|
|
|
// decoration: BoxDecoration( |
|
|
|
|
// borderRadius: BorderRadius.circular(2), |
|
|
|
|
// border: Border.all( |
|
|
|
|
// color:Color(0xFFEDEDED), |
|
|
|
|
// ) |
|
|
|
|
// ), |
|
|
|
|
// child: Row( |
|
|
|
|
// children: [ |
|
|
|
|
// Text( |
|
|
|
|
// "店铺详情", |
|
|
|
|
// style: TextStyle( |
|
|
|
|
// fontWeight: MyFontWeight.regular, |
|
|
|
|
// fontSize: 12.sp, |
|
|
|
|
// color: Color(0xFF4C4C4C), |
|
|
|
|
// ), |
|
|
|
|
// ), |
|
|
|
|
// Image.asset( |
|
|
|
|
// "assets/image/icon_right_z.webp", |
|
|
|
|
// height:12.h, |
|
|
|
|
// width:12.w, |
|
|
|
|
// ) |
|
|
|
|
// ], |
|
|
|
|
// ), |
|
|
|
|
// ), |
|
|
|
|
// ) |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceAround, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
8.d, |
|
|
|
|
Row( |
|
|
|
|
children: [ |
|
|
|
|
if( widget.storeInfo?.perCapitaConsumption != null && ( widget.storeInfo?.perCapitaConsumption ?? "") != "0") |
|
|
|
|
Padding(padding:EdgeInsets.only(right:20.w), |
|
|
|
|
child: Text( |
|
|
|
|
S.of(context).ren(widget.storeInfo?.perCapitaConsumption ?? ""), |
|
|
|
|
overflow: TextOverflow.ellipsis, |
|
|
|
|
style: TextStyle( |
|
|
|
|
fontSize: 12.sp, |
|
|
|
|
fontWeight: MyFontWeight.medium, |
|
|
|
|
color: Color(0xFF353535), |
|
|
|
|
), |
|
|
|
|
),), |
|
|
|
|
]..addAll(itemServer(widget.storeInfo?.businessService ?? "")), |
|
|
|
|
), |
|
|
|
|
8.d, |
|
|
|
|
Text( |
|
|
|
|
S.of(context).yingyeshijian(widget.storeInfo == null |
|
|
|
|
? "" |
|
|
|
|
: ((widget.storeInfo!.openStartTime?.isEmpty ?? true) && (widget.storeInfo!.openEndTime?.isEmpty ?? true)) |
|
|
|
|
? 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, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceAround, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
MImage( |
|
|
|
|
widget.storeInfo?.logo ?? "", |
|
|
|
|
width: 70, |
|
|
|
|
height: 70, |
|
|
|
|
fit: BoxFit.cover, |
|
|
|
|
errorSrc: "assets/image/default_1.webp", |
|
|
|
|
fadeSrc: "assets/image/default_1.webp", |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceAround, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
), |
|
|
|
|
flex: 1, |
|
|
|
|
), |
|
|
|
|
Row( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center, |
|
|
|
|
children: [ |
|
|
|
|
GestureDetector( |
|
|
|
|
behavior: HitTestBehavior.opaque, |
|
|
|
|
onTap: () { |
|
|
|
|
// Navigator.of(context).pushNamed( |
|
|
|
|
// '/router/location_map', |
|
|
|
|
// arguments: { |
|
|
|
|
// "lat": widget.storeInfo?.latitude, |
|
|
|
|
// "lng": widget.storeInfo?.longitude, |
|
|
|
|
// "storeInfo":widget.storeInfo, |
|
|
|
|
// "distance":widget.distance |
|
|
|
|
// }, |
|
|
|
|
// ); |
|
|
|
|
showMapSelect(); |
|
|
|
|
}, |
|
|
|
|
child: Container( |
|
|
|
|
color: Colors.transparent, |
|
|
|
|
padding:EdgeInsets.only(right: 8.w,bottom: 8.h) , |
|
|
|
|
child: Image.asset( |
|
|
|
|
"assets/image/icon_union_location.webp", |
|
|
|
|
width: 20, |
|
|
|
|
height: 20, |
|
|
|
|
MImage( |
|
|
|
|
widget.storeInfo?.logo ?? "", |
|
|
|
|
width: 70, |
|
|
|
|
height: 70, |
|
|
|
|
fit: BoxFit.cover, |
|
|
|
|
errorSrc: "assets/image/default_1.webp", |
|
|
|
|
fadeSrc: "assets/image/default_1.webp", |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceAround, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
|
), |
|
|
|
|
Expanded( |
|
|
|
|
child: GestureDetector( |
|
|
|
|
flex: 1, |
|
|
|
|
), |
|
|
|
|
10.d, |
|
|
|
|
Row( |
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween, |
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center, |
|
|
|
|
children: [ |
|
|
|
|
GestureDetector( |
|
|
|
|
behavior: HitTestBehavior.opaque, |
|
|
|
|
onTap: () { |
|
|
|
|
// Navigator.of(context).pushNamed( |
|
|
|
@ -186,45 +165,71 @@ class _StoreInfoView extends State<StoreInfoView> {
|
|
|
|
|
// }, |
|
|
|
|
// ); |
|
|
|
|
showMapSelect(); |
|
|
|
|
}, |
|
|
|
|
child:Padding( |
|
|
|
|
padding: EdgeInsets.only(bottom: 8.h,), |
|
|
|
|
child: Text( |
|
|
|
|
"${S.of(context).dizhi}:${widget.storeInfo != null ? widget.storeInfo!.address : ""}", |
|
|
|
|
maxLines: 2, |
|
|
|
|
textAlign: TextAlign.justify, |
|
|
|
|
style: TextStyle( |
|
|
|
|
color: Color(0xFF353535), |
|
|
|
|
fontWeight: MyFontWeight.regular, |
|
|
|
|
fontSize: 12.sp, |
|
|
|
|
), |
|
|
|
|
}, |
|
|
|
|
child: Container( |
|
|
|
|
color: Colors.transparent, |
|
|
|
|
padding:EdgeInsets.only(right: 8.w,bottom: 8.h) , |
|
|
|
|
child: Image.asset( |
|
|
|
|
"assets/image/icon_union_location.webp", |
|
|
|
|
width: 20, |
|
|
|
|
height: 20, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
if(widget.storeInfo?.tel?.isNotEmpty ?? false) |
|
|
|
|
GestureDetector( |
|
|
|
|
behavior: HitTestBehavior.opaque, |
|
|
|
|
onTap: () { |
|
|
|
|
showCallMobile(); |
|
|
|
|
}, |
|
|
|
|
child: Container( |
|
|
|
|
padding:EdgeInsets.only(left: 16.w,right: 8.w,bottom: 8.h) , |
|
|
|
|
child: Image.asset( |
|
|
|
|
"assets/image/icon_union_call.webp", |
|
|
|
|
width: 24, |
|
|
|
|
height: 24, |
|
|
|
|
Expanded( |
|
|
|
|
child: GestureDetector( |
|
|
|
|
behavior: HitTestBehavior.opaque, |
|
|
|
|
onTap: () { |
|
|
|
|
// Navigator.of(context).pushNamed( |
|
|
|
|
// '/router/location_map', |
|
|
|
|
// arguments: { |
|
|
|
|
// "lat": widget.storeInfo?.latitude, |
|
|
|
|
// "lng": widget.storeInfo?.longitude, |
|
|
|
|
// "storeInfo":widget.storeInfo, |
|
|
|
|
// "distance":widget.distance |
|
|
|
|
// }, |
|
|
|
|
// ); |
|
|
|
|
showMapSelect(); |
|
|
|
|
}, |
|
|
|
|
child:Padding( |
|
|
|
|
padding: EdgeInsets.only(bottom: 8.h,), |
|
|
|
|
child: Text( |
|
|
|
|
"${S.of(context).dizhi}:${widget.storeInfo != null ? widget.storeInfo!.address : ""}", |
|
|
|
|
maxLines: 2, |
|
|
|
|
textAlign: TextAlign.justify, |
|
|
|
|
style: TextStyle( |
|
|
|
|
color: Color(0xFF353535), |
|
|
|
|
fontWeight: MyFontWeight.regular, |
|
|
|
|
fontSize: 12.sp, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
Container( |
|
|
|
|
width: double.infinity, |
|
|
|
|
height: 1, |
|
|
|
|
color: Color(0xFFF4F5F2), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
if(widget.storeInfo?.tel?.isNotEmpty ?? false) |
|
|
|
|
GestureDetector( |
|
|
|
|
behavior: HitTestBehavior.opaque, |
|
|
|
|
onTap: () { |
|
|
|
|
showCallMobile(); |
|
|
|
|
}, |
|
|
|
|
child: Container( |
|
|
|
|
padding:EdgeInsets.only(left: 16.w,right: 8.w,bottom: 8.h) , |
|
|
|
|
child: Image.asset( |
|
|
|
|
"assets/image/icon_union_call.webp", |
|
|
|
|
width: 24, |
|
|
|
|
height: 24, |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
Container( |
|
|
|
|
width: double.infinity, |
|
|
|
|
height: 1, |
|
|
|
|
color: Color(0xFFF4F5F2), |
|
|
|
|
), |
|
|
|
|
], |
|
|
|
|
), |
|
|
|
|
), |
|
|
|
|
); |
|
|
|
|
} |
|
|
|
@ -255,7 +260,8 @@ class _StoreInfoView extends State<StoreInfoView> {
|
|
|
|
|
isDestructiveAction: true, |
|
|
|
|
), |
|
|
|
|
); |
|
|
|
|
}); |
|
|
|
|
}, |
|
|
|
|
); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
callMobile(mobile) async { |
|
|
|
|