From 742a9841c1bdd2e87740a9709dec2ea485d60778 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 10 Aug 2022 17:41:53 +0800
Subject: [PATCH] 20220810

---
 src/main/java/cc/mrbird/febs/mall/dto/ApiLeaderOrderConfirmDto.java              |    6 +-
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallTeamLeaderServiceImpl.java |    9 +-
 src/main/java/cc/mrbird/febs/mall/controller/AdminMallOrderController.java       |   87 +++++++++++++++++++++++++++++
 src/main/java/cc/mrbird/febs/mall/entity/MallOrderInfo.java                      |    5 +
 src/main/resources/templates/febs/views/modules/order/orderList.html             |   23 +++++++
 src/main/java/cc/mrbird/febs/pay/util/WechatConfigure.java                       |    2 
 6 files changed, 120 insertions(+), 12 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallOrderController.java b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallOrderController.java
index af091f8..45b7724 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallOrderController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallOrderController.java
@@ -14,18 +14,25 @@
 import cc.mrbird.febs.common.utils.excl.ResponseHeadUtil;
 import cc.mrbird.febs.mall.dto.*;
 import cc.mrbird.febs.mall.entity.*;
+import cc.mrbird.febs.mall.mapper.MallMemberMapper;
 import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
 import cc.mrbird.febs.mall.mapper.MallOrderRefundOperationMapper;
+import cc.mrbird.febs.mall.mapper.MallTeamLeaderMapper;
 import cc.mrbird.febs.mall.service.IAdminMallGoodsService;
 import cc.mrbird.febs.mall.service.IAdminMallOrderService;
 import cc.mrbird.febs.mall.vo.AdminAddAddressTreeVo;
 import cc.mrbird.febs.mall.vo.AdminMallOrderRefundAddressVo;
+import cc.mrbird.febs.pay.model.OrderStateDto;
+import cc.mrbird.febs.pay.service.IXcxPayService;
+import cc.mrbird.febs.pay.util.WechatConfigure;
 import cc.mrbird.febs.system.entity.Dept;
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.date.DateUtil;
+import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections.CollectionUtils;
 import org.springframework.validation.annotation.Validated;
 import org.springframework.web.bind.annotation.*;
 import org.springframework.web.multipart.MultipartFile;
@@ -285,6 +292,86 @@
         return null;
     }
 
+    private final IXcxPayService iXcxPayService;
+    private final MallTeamLeaderMapper mallTeamLeaderMapper;
+    private final MallMemberMapper mallMemberMapper;
+
+    @GetMapping("confirmOrder")
+    @ControllerEndpoint(operation = "确认货到达自提点", exceptionMessage = "确认货到达自提点")
+    public FebsResponse confirmOrder(MallOrderInfo mallOrderInfoDto){
+        String orderIds = mallOrderInfoDto.getOrderIds();
+        List<String> ids = StrUtil.splitTrim(orderIds, ",");
+        for(String id : ids){
+            long orderId = Long.parseLong(id);
+            MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(orderId);
+            if(ObjectUtil.isEmpty(mallOrderInfo)){
+                continue;
+//                return new FebsResponse().fail().message("订单不存在");
+            }
+            Integer status = mallOrderInfo.getStatus();
+            if(OrderStatusEnum.WAIT_FINISH.getValue() != status){
+                continue;
+//                return new FebsResponse().fail().message("订单不是待确认到货状态");
+            }
+            mallOrderInfo.setDeliveryState(OrderDeliveryStateEnum.DELIVERY_FINISH.getValue());
+            mallOrderInfoMapper.updateById(mallOrderInfo);
+
+            OrderStateDto orderStateDto = new OrderStateDto();
+            orderStateDto.setOrderNo(mallOrderInfo.getOrderNo());
+            orderStateDto.setGoodsName(getProductNames(mallOrderInfo.getMemberId(),mallOrderInfo.getId()));
+            if(2 == mallOrderInfo.getIsHome()){
+                orderStateDto.setOrderState("已送达自提点");
+            }else{
+                orderStateDto.setOrderState("已送达自提点");
+            }
+            String takeUniqueCode = mallOrderInfo.getTakeUniqueCode();
+            MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(takeUniqueCode);
+            orderStateDto.setAddressArea(mallTeamLeader.getAddressArea());
+            orderStateDto.setOpenId(mallMemberMapper.selectById(mallOrderInfo.getMemberId()).getOpenId());
+            orderStateDto.setTemplateId(WechatConfigure.WX_ORDER_STATEMSG_TEMPLATE_ID);
+            iXcxPayService.pushOrderToAddress(orderStateDto);
+        }
+        return new FebsResponse().success().message("确认成功");
+    }
+
+    /**
+     * 根据用户ID和订单ID获取所购买商品名称
+     * @return 所含商品名称(多个以","隔开)
+     */
+    public String getProductNames(Long memberId, Long orderId) {
+        MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectOrderByMemberIdAndId(memberId, orderId);
+        List<MallOrderItem> details = mallOrderInfo.getItems();
+        if (CollectionUtils.isEmpty(details)) {
+            return "";
+        }
+        StringBuffer productNameBuffer = new StringBuffer();
+        Integer maxLength = 30;
+        for (int i = 0; i< details.size(); i++) {
+            MallOrderItem mallOrderItem = details.get(i);
+            String goodsName = mallOrderItem.getGoodsName();
+            if (goodsName == null) {
+                continue;
+            }
+            if (i == 0 && goodsName.length() > maxLength) {
+                productNameBuffer.append(goodsName.substring(0, maxLength) + "...");
+                break;
+            }
+            if ((productNameBuffer.length() + goodsName.length()) > maxLength) {
+                productNameBuffer.append("等");
+                break;
+            }
+            productNameBuffer.append(goodsName + ",");
+        }
+        String productNames = productNameBuffer.toString();
+        if (productNames.endsWith(",")) {
+            productNames = productNames.substring(0, productNames.length() - 1);
+        }
+        if (productNames.endsWith(",等")) {
+            productNames = productNames.substring(0, productNames.length() - 2) + "等";
+        }
+        return productNames;
+    }
+
     @GetMapping("exportOrderListOne")
     @ControllerEndpoint(operation = "订单列表", exceptionMessage = "导出失败")
     public FebsResponse exportOrderListOne(MallOrderInfo mallOrderInfo, HttpServletResponse response) throws IOException {
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/ApiLeaderOrderConfirmDto.java b/src/main/java/cc/mrbird/febs/mall/dto/ApiLeaderOrderConfirmDto.java
index 6b33115..56e9d17 100644
--- a/src/main/java/cc/mrbird/febs/mall/dto/ApiLeaderOrderConfirmDto.java
+++ b/src/main/java/cc/mrbird/febs/mall/dto/ApiLeaderOrderConfirmDto.java
@@ -4,12 +4,12 @@
 import lombok.Data;
 
 import javax.validation.constraints.NotBlank;
+import java.util.List;
 
 @Data
 @ApiModel(value = "ApiLeaderOrderConfirmDto", description = "参数接收类")
 public class ApiLeaderOrderConfirmDto {
-//    @NotBlank(message = "订单编号不能为空")
-//    private String orderNo;
-    private String ids;
+
+    private List<Long> ids;
 
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/entity/MallOrderInfo.java b/src/main/java/cc/mrbird/febs/mall/entity/MallOrderInfo.java
index 1aff7ac..97ff0aa 100644
--- a/src/main/java/cc/mrbird/febs/mall/entity/MallOrderInfo.java
+++ b/src/main/java/cc/mrbird/febs/mall/entity/MallOrderInfo.java
@@ -115,8 +115,6 @@
     private String addressArea;
     @TableField(exist = false)
     private String detailAddress;
-
-
     /**
      * 微信订单编号
      */
@@ -129,4 +127,7 @@
      * 是否送货上门  1:是 2:否
      */
     private Integer isHome;
+
+    @TableField(exist = false)
+    private String orderIds;
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallTeamLeaderServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallTeamLeaderServiceImpl.java
index d5f1fe2..638bca5 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallTeamLeaderServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallTeamLeaderServiceImpl.java
@@ -126,13 +126,12 @@
     @Override
     @Transactional
     public FebsResponse leaderOrderConfirm(ApiLeaderOrderConfirmDto apiLeaderOrderConfirmDto) {
-        String ids = apiLeaderOrderConfirmDto.getIds();
-        if(StrUtil.isEmpty(ids)){
+        log.info("确认到达",apiLeaderOrderConfirmDto.getIds());
+        List<Long> ids = apiLeaderOrderConfirmDto.getIds();
+        if(CollUtil.isEmpty(ids)){
             return new FebsResponse().fail().message("请选择订单");
         }
-        List<String> orderIds = StrUtil.splitTrim(ids, ",");
-        for(String id : orderIds){
-            long orderId = Long.parseLong(id);
+        for(Long orderId : ids){
             MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(orderId);
             if(ObjectUtil.isEmpty(mallOrderInfo)){
                 continue;
diff --git a/src/main/java/cc/mrbird/febs/pay/util/WechatConfigure.java b/src/main/java/cc/mrbird/febs/pay/util/WechatConfigure.java
index f8a8bfc..d59fc37 100644
--- a/src/main/java/cc/mrbird/febs/pay/util/WechatConfigure.java
+++ b/src/main/java/cc/mrbird/febs/pay/util/WechatConfigure.java
@@ -8,8 +8,6 @@
 
     public static final String WX_ACCESS_TOKEN_REDIS_KEY = "access_token";
 
-    public static final String WX_ACCESS_TOKEN = "https://api.weixin.qq.com/cgi-bin/token?grant_type={grant_type}&appid={appid}&secret={secret}";
-
     public static final String UNIFIEDORDER = "https://api.mch.weixin.qq.com/pay/unifiedorder";
 
     /**
diff --git a/src/main/resources/templates/febs/views/modules/order/orderList.html b/src/main/resources/templates/febs/views/modules/order/orderList.html
index 565bdba..dd32e2f 100644
--- a/src/main/resources/templates/febs/views/modules/order/orderList.html
+++ b/src/main/resources/templates/febs/views/modules/order/orderList.html
@@ -100,6 +100,7 @@
 <script type="text/html" id="tableToolBar">
     <div class="layui-btn-container">
         <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="exportDeliverOne">导出待发货订单,系统自动发货</button>
+        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="confirmOrder">确认到货</button>
 <!--        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="exportDeliverTwo">导出未发货订单(快递)</button>-->
 <!--        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" id="importDeliver" lay-event="importDeliver">导入发货</button>-->
     </div>
@@ -142,6 +143,27 @@
 
         table.on('toolbar(orderTable)', function(obj){
             var event = obj.event;
+            var id = obj.config.id;
+            var checkStatus = table.checkStatus(id);
+            if(event === 'confirmOrder'){
+                var data = checkStatus.data;
+                let ids = "";
+                for(let i = 0;i < data.length;i++){
+                    ids = ids + data[i].id+","
+                }
+                // layer.alert(layui.util.escape(JSON.stringify(data)));
+                console.log(ids);
+                if(ids == null || ids == ""){
+                    febs.alert.warn('请选择确认到货的订单');
+                    return;
+                }
+                let uniqueCodeValue = $searchForm.find("select[name='uniqueCode']").val();
+                if(uniqueCodeValue == '' || uniqueCodeValue == null){
+                    febs.alert.warn('请选择团长');
+                    return;
+                }
+                window.location.href = ctx + "admin/order/confirmOrder?takeUniqueCode="+uniqueCodeValue+"&orderIds="+ids;
+            }
             if (event == 'exportDeliverOne') {
                 let uniqueCodeValue = $searchForm.find("select[name='uniqueCode']").val();
                 if(uniqueCodeValue == '' || uniqueCodeValue == null){
@@ -250,6 +272,7 @@
                 defaultToolbar: [],
                 toolbar: '#tableToolBar',
                 cols: [[
+                        {type: 'checkbox', fixed: 'left'},
                         {field: 'orderNo', title: '订单编号', minWidth: 200,align:'left'},
                         {field: 'memberName', title: '购买人', minWidth: 120,align:'left'},
                         {field: 'memberPhone', title: '联系方式', minWidth: 120,align:'left'},

--
Gitblit v1.9.1