diff --git a/lib/home/home_view/featured_acticvity.dart b/lib/home/home_view/featured_acticvity.dart index 057a0056..e9be0578 100644 --- a/lib/home/home_view/featured_acticvity.dart +++ b/lib/home/home_view/featured_acticvity.dart @@ -26,7 +26,7 @@ class _FeaturedActivity extends State { height: 10.h, ), Container( - margin: EdgeInsets.symmetric(horizontal: 11.w), + margin: EdgeInsets.symmetric(horizontal: 9.w), child: Row( children: [ Container( @@ -65,9 +65,6 @@ class _FeaturedActivity extends State { ), ), ), - SizedBox( - height: 10.h, - ), Container( child: stackItem(14.sp), margin: EdgeInsets.symmetric(horizontal: 5.w), diff --git a/lib/retrofit/min_api.dart b/lib/retrofit/min_api.dart index e97d7c93..e2c9400d 100644 --- a/lib/retrofit/min_api.dart +++ b/lib/retrofit/min_api.dart @@ -15,13 +15,18 @@ import 'data/findMiNiGroupList.dart'; import 'data/miNiDetail.dart'; import 'data/settleOrderInfo.dart'; import 'data/shoppingCart.dart'; + part 'min_api.g.dart'; // const base_url = "https://pos.platform.lotus-wallet.com/app/"; ///正式 // const baseUrl = "https://pos.platform.lotus-wallet.com/app/"; ///正式 -const base_url = "http://192.168.10.236:8765/app/"; ///费韬 -const baseUrl = "http://192.168.10.236:8765/app/"; ///费韬 +const base_url = "http://192.168.10.236:8765/app/"; + +///费韬 +const baseUrl = "http://192.168.10.236:8765/app/"; + +///费韬 // const base_url = "http://192.168.10.37:8766/app/"; // const baseUrl = "http://192.168.10.37:8766/app/"; @@ -29,7 +34,8 @@ const baseUrl = "http://192.168.10.236:8765/app/"; ///费韬 ///调用小程序的接口 @RestApi(baseUrl: baseUrl) abstract class MinApiService { - factory MinApiService(Dio dio, { + factory MinApiService( + Dio dio, { String baseUrl, BuildContext context, String token, @@ -38,7 +44,7 @@ abstract class MinApiService { bool pay = false, }) { Map headers = - (token == null || token == "") ? {} : {'token': "Bearer $token"}; + (token == null || token == "") ? {} : {'token': "Bearer $token"}; if (tenant != null && tenant != "") { headers["tenant"] = tenant; } @@ -53,7 +59,8 @@ abstract class MinApiService { ); dio.interceptors.add( InterceptorsWrapper(onRequest: (RequestOptions options) { - debugPrint("\n======================= Min_请求数据 ======================="); + debugPrint( + "\n======================= Min_请求数据 ======================="); debugPrint("method = ${options.method.toString()}"); debugPrint("url = ${options.uri.toString()}"); debugPrint("headers = ${options.headers}"); @@ -68,14 +75,16 @@ abstract class MinApiService { } debugPrint("params queryParameters = ${options.queryParameters}"); }, onResponse: (Response response) { - debugPrint("\n======================= Min_响应数据开始 ======================="); + debugPrint( + "\n======================= Min_响应数据开始 ======================="); if (showLoading && EasyLoading.isShow) { EasyLoading.dismiss(); } debugPrint("code = ${response.statusCode}"); // p(jsonEncode(response.data)); - debugPrint(jsonEncode(response.data), wrapWidth: response.data.toString().length); + debugPrint(jsonEncode(response.data), + wrapWidth: response.data.toString().length); Map map = response.data; if (map["code"] != 0) { @@ -90,12 +99,14 @@ abstract class MinApiService { ///高德地图的poi服务请求不需要toast SmartDialog.showToast(map["msg"], alignment: Alignment.center); } - debugPrint("======================= Min_响应数据结束 =======================\n"); + debugPrint( + "======================= Min_响应数据结束 =======================\n"); }, onError: (DioError e) { if (EasyLoading.isShow) { EasyLoading.dismiss(); } - debugPrint("\n======================= Min_错误响应数据 ======================="); + debugPrint( + "\n======================= Min_错误响应数据 ======================="); debugPrint("type = ${e.type}"); debugPrint("message = ${e.message}"); debugPrint("\n"); @@ -122,7 +133,6 @@ abstract class MinApiService { Future>> findMiNiGroupList( @Body() Map param); - ///小程序查询商品详情/規格选择 @GET("/product/queryMiNiProductDetail?id={id}") Future> miNiDetail(@Path("id") String id); @@ -130,13 +140,10 @@ abstract class MinApiService { ///添加购物车 @POST("shoppingcart") Future> shoppingCart( - @Body() Map param,Map header); + @Body() Map param, Map header); ///订单结算信息 @POST("order/getOrderInfo") Future> getOrderInfo( @Body() Map param); - - - -} \ No newline at end of file +} diff --git a/lib/store/store_order.dart b/lib/store/store_order.dart index ed3c23de..7c80989c 100644 --- a/lib/store/store_order.dart +++ b/lib/store/store_order.dart @@ -420,7 +420,7 @@ class _StoreOrderPage extends State toDownOrder() { if (shopCarGoods == null || shopCarGoods.length == 0) { SmartDialog.showToast("请选择要购买的商品~"); - return ; + return; } getShopCarGoods(); @@ -494,7 +494,6 @@ class _StoreOrderPage extends State ///购物车弹窗 showShoppingCart() { - getShopCarGoods(); showModalBottomSheet( @@ -537,7 +536,7 @@ class _StoreOrderPage extends State addsShoppingCart() async { BaseData baseDate = await apiService.creditOrder({ "parentId": widget.arguments["parentId"], - "skuImg": widget.arguments["skuImg"], + "skuImg": null, "skuNameStr": widget.arguments["skuNameStr"], "skuPrice": widget.arguments["skuPrice"], "skuStock": widget.arguments["skuStock"], diff --git a/lib/store/store_view/settlement.dart b/lib/store/store_view/settlement.dart index bc24b065..29fedfd3 100644 --- a/lib/store/store_view/settlement.dart +++ b/lib/store/store_view/settlement.dart @@ -615,7 +615,10 @@ class _Settlement extends State { ), ), Text( - "满30减10", + (settleOrderInfo?.couponList == null || settleOrderInfo.couponList.length == 0) + ? "暂无可用优惠券" : (selectedCouponIndex == -1 + ? "拥有${settleOrderInfo.couponList.length}张优惠券": + settleOrderInfo.couponList[selectedCouponIndex].promotionName), textAlign: TextAlign.end, style: TextStyle( fontSize: 14.sp, @@ -674,7 +677,6 @@ class _Settlement extends State { ); } - ///支付方式 Widget payMethod() { return Container( width: double.infinity, diff --git a/lib/store/store_view/settlement_order_commodity.dart b/lib/store/store_view/settlement_order_commodity.dart index fdd9bbc5..9b7f9d93 100644 --- a/lib/store/store_view/settlement_order_commodity.dart +++ b/lib/store/store_view/settlement_order_commodity.dart @@ -1,9 +1,7 @@ - - import 'package:flutter/material.dart'; import 'package:flutter_screenutil/flutter_screenutil.dart'; import 'package:huixiang/generated/l10n.dart'; -import 'package:huixiang/retrofit/data/order_info.dart'; +import 'package:huixiang/retrofit/data/findMiNiGroupList.dart'; import 'package:huixiang/retrofit/data/settleOrderInfo.dart'; import 'package:huixiang/utils/font_weight.dart'; import 'package:huixiang/view_widget/custom_image.dart'; @@ -11,15 +9,16 @@ import 'package:huixiang/view_widget/separator.dart'; class SettlementOrderCommodity extends StatefulWidget { final int isTakeOut; - final SettleOrderInfo orderInfo; + final List orderInfo; + final List> shopCarGood; + final SettleOrderInfo settleOrderInfo; - SettlementOrderCommodity(this.orderInfo,this.isTakeOut); + SettlementOrderCommodity(this.orderInfo, this.isTakeOut,this.shopCarGood,this.settleOrderInfo); @override State createState() { return _SettlementOrderCommodity(); } - } class _SettlementOrderCommodity extends State { @@ -66,13 +65,12 @@ class _SettlementOrderCommodity extends State { ); } - List commodityList() { if (widget.orderInfo == null) return []; List widgets = []; - if (widget.orderInfo.orderProductList != null) { - widgets - .addAll(widget.orderInfo.orderProductList.map((e) => commodityItem(e)).toList()); + if (widget.orderInfo != null) { + widgets.addAll( + widget.orderInfo.map((e) => commodityItem(e)).toList()); } widgets.add(SizedBox(height: 20.h)); @@ -84,7 +82,8 @@ class _SettlementOrderCommodity extends State { ? S.of(context).peisongfei : S.of(context).yunfei, "", - "+${widget.orderInfo.postAge}")); + "+${widget.settleOrderInfo?.postAge??"0"}" + )); } widgets.add(Container( @@ -102,13 +101,20 @@ class _SettlementOrderCommodity extends State { return widgets; } - Widget commodityItem(OrderProductListBean productList) { + Widget commodityItem(ProductListBean productList) { + Map goodsBuyInfo; + widget.shopCarGood.forEach((element) { + if(element["id"] == productList.id){ + goodsBuyInfo = element; + return; + } + }); return Container( margin: EdgeInsets.only(top: 8.h, bottom: 8.h), child: Row( children: [ MImage( - productList.skuImg, + productList.imgPath, width: 44.w, height: 44, fit: BoxFit.cover, @@ -139,7 +145,7 @@ class _SettlementOrderCommodity extends State { ), ), Text( - "x${productList.buyNum}", + "x${goodsBuyInfo["count"]}", style: TextStyle( fontSize: 12.sp, color: Color(0xFF727272), @@ -165,7 +171,7 @@ class _SettlementOrderCommodity extends State { ), ), Text( - S.of(context).yuan_(productList.sellPrice), + S.of(context).yuan_(productList.price), style: TextStyle( fontWeight: FontWeight.bold, fontSize: 12.sp, @@ -312,15 +318,14 @@ class _SettlementOrderCommodity extends State { children: [ Expanded( child: Text( - S.of(context).gongjijianshangpin( - (widget.orderInfo != null && widget.orderInfo.orderProductList != null) - ? widget.orderInfo.orderProductList.length - : "0"), + S.of(context).gongjijianshangpin((widget.orderInfo != null && + widget.orderInfo != null) + ? widget.orderInfo.length + : "0"), style: TextStyle( - fontSize: 10.sp, - color: Color(0xFFA29E9E), - fontWeight: MyFontWeight.semi_bold - ), + fontSize: 10.sp, + color: Color(0xFFA29E9E), + fontWeight: MyFontWeight.semi_bold), ), flex: 1, ), @@ -328,10 +333,9 @@ class _SettlementOrderCommodity extends State { child: Text( S.of(context).jiesuanjine, style: TextStyle( - fontSize: 12.sp, - color: Color(0xFF353535), - fontWeight:MyFontWeight.semi_bold - ), + fontSize: 12.sp, + color: Color(0xFF353535), + fontWeight: MyFontWeight.semi_bold), ), ), SizedBox( @@ -341,10 +345,9 @@ class _SettlementOrderCommodity extends State { totalPrice(), textAlign: TextAlign.end, style: TextStyle( - fontSize:14.sp, - color: Color(0xFF32A060), - fontWeight: MyFontWeight.semi_bold - ), + fontSize: 14.sp, + color: Color(0xFF32A060), + fontWeight: MyFontWeight.semi_bold), ) ], ), @@ -352,10 +355,11 @@ class _SettlementOrderCommodity extends State { } String totalPrice() { - if (widget.orderInfo == null) return ""; - double totalPrice = (double.tryParse(widget.orderInfo.orderSum) + - double.tryParse(widget.orderInfo.postAge)); + if (widget.shopCarGood == null) return ""; + double totalPrice = 0; + widget.shopCarGood.forEach((element) { + totalPrice += double.tryParse(element["price"]) * element["count"]; + }); return "$totalPrice"; } - -} \ No newline at end of file +} diff --git a/lib/store/store_view/store_order_list.dart b/lib/store/store_view/store_order_list.dart index 02d02cd3..695b7874 100644 --- a/lib/store/store_view/store_order_list.dart +++ b/lib/store/store_view/store_order_list.dart @@ -86,42 +86,40 @@ class _StoreOrderListPage extends State { @override Widget build(BuildContext context) { return Container( - width: MediaQuery.of(context).size.width, - height: MediaQuery.of(context).size.height - (kToolbarHeight + 38 + 54.h), - margin: EdgeInsets.only( - top: (MediaQuery.of(context).padding.top + 38 + kToolbarHeight), - ), - child: Row( - mainAxisAlignment: MainAxisAlignment.start, - mainAxisSize: MainAxisSize.max, - children: [ - Container( - width: 100.w, - child: ListView.builder( - itemCount: - appletProducts == null ? 0 : appletProducts.length, - controller: controller1, - physics: BouncingScrollPhysics(), - padding: EdgeInsets.only(top: 0, bottom: 25), - itemBuilder: (context, position) { - return orderItem(appletProducts[position], position); - }, - ), + width: MediaQuery.of(context).size.width, + height: MediaQuery.of(context).size.height - (kToolbarHeight + 38 + 54.h), + margin: EdgeInsets.only( + top: (MediaQuery.of(context).padding.top + 38 + kToolbarHeight), + ), + child: Row( + mainAxisAlignment: MainAxisAlignment.start, + mainAxisSize: MainAxisSize.max, + children: [ + Container( + width: 100.w, + child: ListView.builder( + itemCount: appletProducts == null ? 0 : appletProducts.length, + controller: controller1, + physics: BouncingScrollPhysics(), + padding: EdgeInsets.only(top: 0, bottom: 25), + itemBuilder: (context, position) { + return orderItem(appletProducts[position], position); + }, ), - Container( - width: MediaQuery.of(context).size.width - 100.w, - child: ListView.builder( - itemCount: productListBeans == null - ? 0 : productListBeans.length, - physics: BouncingScrollPhysics(), - padding: EdgeInsets.zero, - itemBuilder: (context, position) { - return goodsItem(position); - }, - ), + ), + Container( + width: MediaQuery.of(context).size.width - 100.w, + child: ListView.builder( + itemCount: productListBeans == null ? 0 : productListBeans.length, + physics: BouncingScrollPhysics(), + padding: EdgeInsets.zero, + itemBuilder: (context, position) { + return goodsItem(position); + }, ), - ], - ), + ), + ], + ), ); } @@ -226,8 +224,10 @@ class _StoreOrderListPage extends State { double singlePrice = double.tryParse(element2["price"]); allCount += element2["count"]; - AiDecimalAccuracy aiDecimalAccuracy = AiDecimalAccuracy.fromInt(element2["count"]); - AiDecimalAccuracy aiPrice = AiDecimalAccuracy.tryParse("$singlePrice"); + AiDecimalAccuracy aiDecimalAccuracy = + AiDecimalAccuracy.fromInt(element2["count"]); + AiDecimalAccuracy aiPrice = + AiDecimalAccuracy.tryParse("$singlePrice"); allPrice += (aiPrice * aiDecimalAccuracy); }