|
|
@ -3,6 +3,7 @@ import 'dart:convert'; |
|
|
|
import 'package:flutter/material.dart'; |
|
|
|
import 'package:flutter/material.dart'; |
|
|
|
import 'package:flutter_swiper/flutter_swiper.dart'; |
|
|
|
import 'package:flutter_swiper/flutter_swiper.dart'; |
|
|
|
import 'package:huixiang/retrofit/data/banner.dart'; |
|
|
|
import 'package:huixiang/retrofit/data/banner.dart'; |
|
|
|
|
|
|
|
import 'package:huixiang/retrofit/data/home_rank.dart'; |
|
|
|
import 'package:huixiang/retrofit/data/shopping_home_config.dart'; |
|
|
|
import 'package:huixiang/retrofit/data/shopping_home_config.dart'; |
|
|
|
import 'package:huixiang/retrofit/retrofit_api.dart'; |
|
|
|
import 'package:huixiang/retrofit/retrofit_api.dart'; |
|
|
|
import 'package:huixiang/view_widget/custom_image.dart'; |
|
|
|
import 'package:huixiang/view_widget/custom_image.dart'; |
|
|
@ -11,6 +12,8 @@ import 'package:huixiang/utils/font_weight.dart'; |
|
|
|
import 'package:flutter_screenutil/flutter_screenutil.dart'; |
|
|
|
import 'package:flutter_screenutil/flutter_screenutil.dart'; |
|
|
|
|
|
|
|
|
|
|
|
class TopSellingList extends StatefulWidget { |
|
|
|
class TopSellingList extends StatefulWidget { |
|
|
|
|
|
|
|
final HomeRank homeRank; |
|
|
|
|
|
|
|
TopSellingList(this.homeRank); |
|
|
|
@override |
|
|
|
@override |
|
|
|
State<StatefulWidget> createState() { |
|
|
|
State<StatefulWidget> createState() { |
|
|
|
return _TopSellingList(); |
|
|
|
return _TopSellingList(); |
|
|
@ -34,8 +37,10 @@ class _TopSellingList extends State<TopSellingList> { |
|
|
|
decoration: BoxDecoration( |
|
|
|
decoration: BoxDecoration( |
|
|
|
borderRadius: BorderRadius.circular(6), |
|
|
|
borderRadius: BorderRadius.circular(6), |
|
|
|
image: DecorationImage( |
|
|
|
image: DecorationImage( |
|
|
|
fit: BoxFit.fill, |
|
|
|
image: NetworkImage( |
|
|
|
image: AssetImage("assets/image/hot_list.webp"), |
|
|
|
widget?.homeRank?.commodityListImg ?? "" |
|
|
|
|
|
|
|
), |
|
|
|
|
|
|
|
fit: BoxFit.cover, |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
margin: EdgeInsets.only(left: 14.w,right: 14.w,top: 12.h,bottom: 23.h), |
|
|
|
margin: EdgeInsets.only(left: 14.w,right: 14.w,top: 12.h,bottom: 23.h), |
|
|
@ -63,11 +68,12 @@ class _TopSellingList extends State<TopSellingList> { |
|
|
|
child: ListView.builder( |
|
|
|
child: ListView.builder( |
|
|
|
scrollDirection: Axis.horizontal, |
|
|
|
scrollDirection: Axis.horizontal, |
|
|
|
physics: BouncingScrollPhysics(), |
|
|
|
physics: BouncingScrollPhysics(), |
|
|
|
itemCount:3, |
|
|
|
itemCount:widget.homeRank.commodityList.length ?? 0, |
|
|
|
itemBuilder: (context, position) { |
|
|
|
itemBuilder: (context, position) { |
|
|
|
return GestureDetector( |
|
|
|
return GestureDetector( |
|
|
|
onTap: () {}, |
|
|
|
onTap: () { |
|
|
|
child: hotSaleItem(), |
|
|
|
}, |
|
|
|
|
|
|
|
child: hotSaleItem(widget.homeRank.commodityList[position],position), |
|
|
|
); |
|
|
|
); |
|
|
|
}, |
|
|
|
}, |
|
|
|
), |
|
|
|
), |
|
|
@ -77,7 +83,7 @@ class _TopSellingList extends State<TopSellingList> { |
|
|
|
); |
|
|
|
); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Widget hotSaleItem() { |
|
|
|
Widget hotSaleItem(CommodityList commodityList,index) { |
|
|
|
return Container( |
|
|
|
return Container( |
|
|
|
width: 290.w, |
|
|
|
width: 290.w, |
|
|
|
decoration: BoxDecoration( |
|
|
|
decoration: BoxDecoration( |
|
|
@ -91,7 +97,7 @@ class _TopSellingList extends State<TopSellingList> { |
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
crossAxisAlignment: CrossAxisAlignment.start, |
|
|
|
children: [ |
|
|
|
children: [ |
|
|
|
Text( |
|
|
|
Text( |
|
|
|
"好喝榜", |
|
|
|
commodityList?.typeName ?? "", |
|
|
|
style: TextStyle( |
|
|
|
style: TextStyle( |
|
|
|
fontSize: 14.sp, |
|
|
|
fontSize: 14.sp, |
|
|
|
fontWeight: MyFontWeight.bold, |
|
|
|
fontWeight: MyFontWeight.bold, |
|
|
@ -102,15 +108,23 @@ class _TopSellingList extends State<TopSellingList> { |
|
|
|
), |
|
|
|
), |
|
|
|
Expanded(child: ListView.builder( |
|
|
|
Expanded(child: ListView.builder( |
|
|
|
padding: EdgeInsets.zero, |
|
|
|
padding: EdgeInsets.zero, |
|
|
|
itemCount:6, |
|
|
|
itemCount:widget.homeRank.commodityList[index].goodList.length>3?3:widget.homeRank.commodityList[index].goodList.length, |
|
|
|
scrollDirection: Axis.vertical, |
|
|
|
scrollDirection: Axis.vertical, |
|
|
|
shrinkWrap: true, |
|
|
|
shrinkWrap: true, |
|
|
|
physics: BouncingScrollPhysics(), |
|
|
|
physics: BouncingScrollPhysics(), |
|
|
|
itemBuilder: (context, position) { |
|
|
|
itemBuilder: (context, position) { |
|
|
|
return GestureDetector( |
|
|
|
return GestureDetector( |
|
|
|
onTap: () { |
|
|
|
onTap: () { |
|
|
|
|
|
|
|
Navigator.of(context).pushNamed( |
|
|
|
|
|
|
|
'/router/store_order', |
|
|
|
|
|
|
|
arguments: { |
|
|
|
|
|
|
|
"id": widget.homeRank.commodityList[index].goodList[position].storeId, |
|
|
|
|
|
|
|
"tenant": widget.homeRank.commodityList[index].goodList[position].tenantCode, |
|
|
|
|
|
|
|
"storeName": "" |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
); |
|
|
|
}, |
|
|
|
}, |
|
|
|
child: rankingItem(), |
|
|
|
child: rankingItem(widget.homeRank.commodityList[index].goodList[position],position), |
|
|
|
); |
|
|
|
); |
|
|
|
}, |
|
|
|
}, |
|
|
|
),) |
|
|
|
),) |
|
|
@ -119,7 +133,7 @@ class _TopSellingList extends State<TopSellingList> { |
|
|
|
); |
|
|
|
); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
Widget rankingItem() { |
|
|
|
Widget rankingItem(GoodList goodList,index) { |
|
|
|
return Container( |
|
|
|
return Container( |
|
|
|
margin: EdgeInsets.only(right:14.w,top: 12.h,bottom: 12.h), |
|
|
|
margin: EdgeInsets.only(right:14.w,top: 12.h,bottom: 12.h), |
|
|
|
child: Row( |
|
|
|
child: Row( |
|
|
@ -128,14 +142,18 @@ class _TopSellingList extends State<TopSellingList> { |
|
|
|
children: [ |
|
|
|
children: [ |
|
|
|
Stack( |
|
|
|
Stack( |
|
|
|
children: [ |
|
|
|
children: [ |
|
|
|
Image.asset( |
|
|
|
MImage( |
|
|
|
"assets/image/icon_story_td.webp", |
|
|
|
goodList.productImg ?? "", |
|
|
|
width: 54.w, |
|
|
|
|
|
|
|
height: 54, |
|
|
|
|
|
|
|
fit: BoxFit.cover, |
|
|
|
fit: BoxFit.cover, |
|
|
|
), Image.asset( |
|
|
|
radius: BorderRadius.circular(4), |
|
|
|
"assets/image/ranking1.webp", |
|
|
|
width: 54, |
|
|
|
width: 25.w, |
|
|
|
height: 54, |
|
|
|
|
|
|
|
errorSrc: "assets/image/default_2_1.webp", |
|
|
|
|
|
|
|
fadeSrc: "assets/image/default_2_1.webp", |
|
|
|
|
|
|
|
), |
|
|
|
|
|
|
|
Image.asset( |
|
|
|
|
|
|
|
index == 0 ? "assets/image/ranking1.webp" :(index == 1 ? "assets/image/ranking2.webp": "assets/image/ranking3.webp"), |
|
|
|
|
|
|
|
width: 25, |
|
|
|
height: 25, |
|
|
|
height: 25, |
|
|
|
fit: BoxFit.cover, |
|
|
|
fit: BoxFit.cover, |
|
|
|
), |
|
|
|
), |
|
|
@ -151,7 +169,7 @@ class _TopSellingList extends State<TopSellingList> { |
|
|
|
children: [ |
|
|
|
children: [ |
|
|
|
Padding(padding:EdgeInsets.only(top: 5.h,bottom: 8.h), |
|
|
|
Padding(padding:EdgeInsets.only(top: 5.h,bottom: 8.h), |
|
|
|
child: Text( |
|
|
|
child: Text( |
|
|
|
"暴打柠檬茶", |
|
|
|
goodList?.productName ?? "", |
|
|
|
style: TextStyle( |
|
|
|
style: TextStyle( |
|
|
|
fontSize: 13.sp, |
|
|
|
fontSize: 13.sp, |
|
|
|
fontWeight: MyFontWeight.regular, |
|
|
|
fontWeight: MyFontWeight.regular, |
|
|
@ -162,7 +180,7 @@ class _TopSellingList extends State<TopSellingList> { |
|
|
|
TextSpan( |
|
|
|
TextSpan( |
|
|
|
children: [ |
|
|
|
children: [ |
|
|
|
TextSpan( |
|
|
|
TextSpan( |
|
|
|
text: "¥22.00", |
|
|
|
text: goodList?.price ?? "", |
|
|
|
style: TextStyle( |
|
|
|
style: TextStyle( |
|
|
|
fontSize: 12.sp, |
|
|
|
fontSize: 12.sp, |
|
|
|
fontWeight: MyFontWeight.semi_bold, |
|
|
|
fontWeight: MyFontWeight.semi_bold, |
|
|
@ -170,7 +188,7 @@ class _TopSellingList extends State<TopSellingList> { |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
), |
|
|
|
TextSpan( |
|
|
|
TextSpan( |
|
|
|
text: "¥22.00", |
|
|
|
text: goodList?.applyPrice ?? "", |
|
|
|
style: TextStyle( |
|
|
|
style: TextStyle( |
|
|
|
fontSize:10.sp, |
|
|
|
fontSize:10.sp, |
|
|
|
decoration: TextDecoration.lineThrough, |
|
|
|
decoration: TextDecoration.lineThrough, |
|
|
|