From 6d4447cc955103277b215e691e44244cdb3a58f5 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期五, 16 六月 2023 12:08:07 +0800
Subject: [PATCH] 代理商修改使用优惠券,订单新增关闭订单

---
 management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TAgentServiceImpl.java      |   44 ++++++++++++---------
 management/guns-admin/src/main/webapp/WEB-INF/view/system/tOrder/tOrder.html                                   |    3 +
 management/guns-admin/src/main/webapp/static/modular/system/tAgent/tAgent.js                                   |    2 
 management/guns-admin/src/main/webapp/static/modular/system/tOrder/tOrder.js                                   |   28 ++++++++++++++
 management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/TOrderController.java |   13 ++++++
 5 files changed, 70 insertions(+), 20 deletions(-)

diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/TOrderController.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/TOrderController.java
index 5887e8b..047e59f 100644
--- a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/TOrderController.java
+++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/TOrderController.java
@@ -10,6 +10,7 @@
 import com.stylefeng.guns.modular.system.controller.resp.TDriverCommissionResp;
 import com.stylefeng.guns.modular.system.controller.resp.TOrderResp;
 import com.stylefeng.guns.modular.system.controller.util.ExcelUtil;
+import com.stylefeng.guns.modular.system.enums.OrderStateEnum;
 import com.stylefeng.guns.modular.system.model.TAppUser;
 import com.stylefeng.guns.modular.system.model.TDriver;
 import com.stylefeng.guns.modular.system.model.TOrder;
@@ -226,6 +227,18 @@
         return list;
     }
 
+    /**
+     * 关闭订单
+     */
+    @RequestMapping(value = "/cancelOrderUpdate")
+    @ResponseBody
+    public Object cancelOrderUpdate(@RequestParam Integer tOrderId) {
+        TOrder tOrder = tOrderService.selectById(tOrderId);
+        tOrder.setState(OrderStateEnum.CANCELED.getCode());
+        tOrderService.updateById(tOrder);
+        return SUCCESS_TIP;
+    }
+
 
     /**
      * 获取列表
diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TAgentServiceImpl.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TAgentServiceImpl.java
index 65c05dc..d607725 100644
--- a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TAgentServiceImpl.java
+++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TAgentServiceImpl.java
@@ -192,7 +192,13 @@
                 // 过滤已使用优惠券
                 List<TOrder> usedCoupon = tOrders.stream().filter(order -> (order.getState().equals(OrderStateEnum.FINISH.getCode()) || order.getState().equals(OrderStateEnum.WAIT_EVALUATED.getCode()))
                         && Objects.nonNull(order.getCouponId()) && tAgent.getId().equals(order.getAgentId())).collect(Collectors.toList());
-//                tAgentResp.setUsedCoupon(usedCoupon.size());
+                // 通过订单总量获取已完成订单的使用优惠券数量及优惠券金额
+                tAgentResp.setUsedCoupon(usedCoupon.size());
+                // 金额
+                Optional<BigDecimal> reduce = usedCoupon.stream().map(TOrder::getDiscountedPrice).reduce(BigDecimal::add);
+                reduce.ifPresent(tAgentResp::setCouponPriceSum);
+
+
                 // 已使用优惠券金额求和,已使用优惠券id
 //                List<Integer> usedCouponId = usedCoupon.stream().map(TOrder::getCouponId).collect(Collectors.toList());
 //                if(CollectionUtils.isEmpty(usedCouponId)){
@@ -208,24 +214,24 @@
 //                }
             }
 
-            if(!CollectionUtils.isEmpty(tUserToCoupons)){
-                // 过滤代理商发放的优惠券
-                List<TUserToCoupon> userToCoupons = tUserToCoupons.stream().filter(coupon -> tAgent.getId().equals(coupon.getObjectId()) && coupon.getRoleType() == 3).collect(Collectors.toList());
-                int sum = userToCoupons.stream().mapToInt(TUserToCoupon::getCouponTotal).sum();
-                tAgentResp.setIssuedCoupon(sum);
-                // 总量减去有效数量和过期数量为使用数量
-                int validCount = userToCoupons.stream().mapToInt(TUserToCoupon::getValidCount).sum();//有效数量
-                int expireCount = userToCoupons.stream().mapToInt(TUserToCoupon::getExpireCount).sum();//过期数量
-                tAgentResp.setUsedCoupon(sum-validCount-expireCount);
-                BigDecimal couponPriceSum = BigDecimal.ZERO;
-                for (TUserToCoupon userToCoupon : userToCoupons) {
-                    TCoupon tCoupons1 = tCouponMapper.selectById(userToCoupon.getCouponId());
-                    if(Objects.nonNull(tCoupons1)){
-                        couponPriceSum = couponPriceSum.add(tCoupons1.getCouponPreferentialAmount().multiply(new BigDecimal(userToCoupon.getCouponTotal())));
-                    }
-                }
-                tAgentResp.setCouponPriceSum(couponPriceSum);
-            }
+//            if(!CollectionUtils.isEmpty(tUserToCoupons)){
+//                // 过滤代理商发放的优惠券
+//                List<TUserToCoupon> userToCoupons = tUserToCoupons.stream().filter(coupon -> tAgent.getId().equals(coupon.getObjectId()) && coupon.getRoleType() == 3).collect(Collectors.toList());
+//                int sum = userToCoupons.stream().mapToInt(TUserToCoupon::getCouponTotal).sum();
+//                tAgentResp.setIssuedCoupon(sum);
+//                // 总量减去有效数量和过期数量为使用数量
+//                int validCount = userToCoupons.stream().mapToInt(TUserToCoupon::getValidCount).sum();//有效数量
+//                int expireCount = userToCoupons.stream().mapToInt(TUserToCoupon::getExpireCount).sum();//过期数量
+//                tAgentResp.setUsedCoupon(sum-validCount-expireCount);
+//                BigDecimal couponPriceSum = BigDecimal.ZERO;
+//                for (TUserToCoupon userToCoupon : userToCoupons) {
+//                    TCoupon tCoupons1 = tCouponMapper.selectById(userToCoupon.getCouponId());
+//                    if(Objects.nonNull(tCoupons1)){
+//                        couponPriceSum = couponPriceSum.add(tCoupons1.getCouponPreferentialAmount().multiply(new BigDecimal(userToCoupon.getCouponTotal())));
+//                    }
+//                }
+//                tAgentResp.setCouponPriceSum(couponPriceSum);
+//            }
 
             if(!CollectionUtils.isEmpty(tDrivers)){
                 // 司机数
diff --git a/management/guns-admin/src/main/webapp/WEB-INF/view/system/tOrder/tOrder.html b/management/guns-admin/src/main/webapp/WEB-INF/view/system/tOrder/tOrder.html
index 10132af..21d040c 100644
--- a/management/guns-admin/src/main/webapp/WEB-INF/view/system/tOrder/tOrder.html
+++ b/management/guns-admin/src/main/webapp/WEB-INF/view/system/tOrder/tOrder.html
@@ -63,6 +63,9 @@
                             @if(shiro.hasPermission("/tOrder/export")){
                             <#button name="导出" icon="" clickFun="TOrder.export()"/>
                             @}
+                            @if(shiro.hasPermission("/tOrder/cancelOrderUpdate")){
+                            <#button name="关闭订单" icon="" clickFun="TOrder.cancelOrderUpdate()"/>
+                            @}
                         </div>
                         <div class="hidden-xs" id="TOrderTableToolbar" role="group">
                             @if(shiro.hasPermission("/tOrder/add")){
diff --git a/management/guns-admin/src/main/webapp/static/modular/system/tAgent/tAgent.js b/management/guns-admin/src/main/webapp/static/modular/system/tAgent/tAgent.js
index c2b5a05..8a1b912 100644
--- a/management/guns-admin/src/main/webapp/static/modular/system/tAgent/tAgent.js
+++ b/management/guns-admin/src/main/webapp/static/modular/system/tAgent/tAgent.js
@@ -22,7 +22,7 @@
             {title: '客服电话', field: 'serviceCalls', visible: true, align: 'center', valign: 'middle'},
             {title: '订单数量', field: 'orderSum', visible: true, align: 'center', valign: 'middle'},
             {title: '有效订单', field: 'validOrder', visible: true, align: 'center', valign: 'middle'},
-            {title: '已发放优惠券', field: 'issuedCoupon', visible: true, align: 'center', valign: 'middle'},
+            // {title: '已发放优惠券', field: 'issuedCoupon', visible: true, align: 'center', valign: 'middle'},
             {title: '已使用优惠券', field: 'usedCoupon', visible: true, align: 'center', valign: 'middle'},
         {title: '累计优惠券金额', field: 'couponPriceSum', visible: true, align: 'center', valign: 'middle'},
         {title: '司机充值', field: 'driverRecharge', visible: true, align: 'center', valign: 'middle'},
diff --git a/management/guns-admin/src/main/webapp/static/modular/system/tOrder/tOrder.js b/management/guns-admin/src/main/webapp/static/modular/system/tOrder/tOrder.js
index 165e28f..b0656c8 100644
--- a/management/guns-admin/src/main/webapp/static/modular/system/tOrder/tOrder.js
+++ b/management/guns-admin/src/main/webapp/static/modular/system/tOrder/tOrder.js
@@ -163,6 +163,34 @@
         ajax.start();
     }
 };
+/**
+ * 后台取消订单
+ */
+TOrder.cancelOrderUpdate = function () {
+    if (this.check()) {
+
+        var selected = $('#' + this.id).bootstrapTable('getSelections');
+
+        var id = selected[0].id
+        var state = selected[0].state
+
+        console.log(id)
+        console.log(state)
+
+        if (state != 101 && state != 102 && state != 103 && state != 104 && state != 105 && state != 106 && state != 107) {
+            Feng.error("该订单当前状态不可取消!")
+            return;
+        }
+        var ajax = new $ax(Feng.ctxPath + "/tOrder/cancelOrderUpdate", function (data) {
+            Feng.success("取消订单成功!");
+            TOrder.table.refresh();
+        }, function (data) {
+            Feng.error("取消订单失败!" + data.responseJSON.message + "!");
+        });
+        ajax.set("tOrderId", id);
+        ajax.start();
+    }
+};
 
 /**
  * 订单信息导出

--
Gitblit v1.7.1