From eab74d698bb5c840146cc7bd54be2462f3ca4074 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Mon, 29 Aug 2022 15:42:44 +0800
Subject: [PATCH] 20220822

---
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallTeamLeaderServiceImpl.java |   72 ++++++++++++++++++++++++++----------
 1 files changed, 52 insertions(+), 20 deletions(-)

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 edcce8a..9f9a6e4 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
@@ -1,14 +1,17 @@
 package cc.mrbird.febs.mall.service.impl;
 
 import cc.mrbird.febs.common.entity.FebsResponse;
+import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
 import cc.mrbird.febs.common.enumerates.OrderDeliveryStateEnum;
 import cc.mrbird.febs.common.enumerates.OrderStatusEnum;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
 import cc.mrbird.febs.common.utils.ShareCodeUtil;
+import cc.mrbird.febs.common.utils.SpringContextHolder;
 import cc.mrbird.febs.mall.conversion.MallOrderInfoConversion;
 import cc.mrbird.febs.mall.conversion.MallTeamLeaderConversion;
 import cc.mrbird.febs.mall.dto.*;
 import cc.mrbird.febs.mall.entity.*;
+import cc.mrbird.febs.mall.mapper.DataDictionaryCustomMapper;
 import cc.mrbird.febs.mall.mapper.MallMemberMapper;
 import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper;
 import cc.mrbird.febs.mall.mapper.MallTeamLeaderMapper;
@@ -34,12 +37,22 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import java.util.Arrays;
+import java.util.HashMap;
 import java.util.List;
+import java.util.Map;
 
 @Slf4j
 @Service
 @RequiredArgsConstructor
 public class ApiMallTeamLeaderServiceImpl extends ServiceImpl<MallTeamLeaderMapper, MallTeamLeader> implements IApiMallTeamLeaderService {
+
+
+    private final MallOrderInfoMapper mallOrderInfoMapper;
+    private final MallTeamLeaderMapper mallTeamLeaderMapper;
+    private final MallMemberMapper mallMemberMapper;
+    private final IXcxPayService iXcxPayService;
+    private final SpringContextHolder springContextHolder;
+    private final DataDictionaryCustomMapper dataDictionaryCustomMapper;
 
     @Override
     @Transactional
@@ -116,28 +129,24 @@
         return MallOrderInfoConversion.INSTANCE.entitysToVos(mallOrderInfos.getRecords());
     }
 
-    private final MallOrderInfoMapper mallOrderInfoMapper;
-    private final MallTeamLeaderMapper mallTeamLeaderMapper;
-    private final MallMemberMapper mallMemberMapper;
-    private final IXcxPayService iXcxPayService;
-
     @Override
     @Transactional
     public FebsResponse leaderOrderConfirm(ApiLeaderOrderConfirmDto apiLeaderOrderConfirmDto) {
-        String ids = apiLeaderOrderConfirmDto.getIds();
-        if(StrUtil.isEmpty(ids)){
+        log.info("确认到达"+apiLeaderOrderConfirmDto.getIds());
+        List<String> idsStr = StrUtil.splitTrim(apiLeaderOrderConfirmDto.getIds(),",");
+        if(CollUtil.isEmpty(idsStr)){
             return new FebsResponse().fail().message("请选择订单");
         }
-        List<String> orderIds = StrUtil.splitTrim(ids, ",");
-        for(String id : orderIds){
-            long orderId = Long.parseLong(id);
+        for(String orderIdStr : idsStr){
+            long orderId = Long.parseLong(orderIdStr);
             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){
+            Integer status = mallOrderInfo.getStatus() == null ? 0 : mallOrderInfo.getStatus();
+            Integer deliveryState = mallOrderInfo.getDeliveryState() == null ? 0 : mallOrderInfo.getDeliveryState();
+            if(OrderStatusEnum.WAIT_FINISH.getValue() != status || 2 != deliveryState){
                 continue;
 //                return new FebsResponse().fail().message("订单不是待确认到货状态");
             }
@@ -146,17 +155,16 @@
 
             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 productNames = getProductNames(mallOrderInfo.getMemberId(), mallOrderInfo.getId());
+            orderStateDto.setGoodsName(StrUtil.sub(productNames,0,10)+"...");
+            orderStateDto.setOrderState("已送达");
+            orderStateDto.setTakeCode(mallOrderInfo.getTakeCode());
             String takeUniqueCode = mallOrderInfo.getTakeUniqueCode();
             MallTeamLeader mallTeamLeader = mallTeamLeaderMapper.selectLeaderByUniqueCode(takeUniqueCode);
-            orderStateDto.setAddressArea(mallTeamLeader.getAddressArea());
+            orderStateDto.setAddressArea(StrUtil.sub(mallTeamLeader.getAddressArea(),0,10)+"...");
             orderStateDto.setOpenId(mallMemberMapper.selectById(mallOrderInfo.getMemberId()).getOpenId());
-            orderStateDto.setTemplateId(WechatConfigure.WX_ORDER_STATEMSG_TEMPLATE_ID);
+            DataDictionaryCustom dataDictionaryCustom = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.WX_TEMPLATE_ID_ONE.getType(), DataDictionaryEnum.WX_TEMPLATE_ID_ONE.getCode());
+            orderStateDto.setTemplateId(dataDictionaryCustom.getValue());
             iXcxPayService.pushOrderToAddress(orderStateDto);
         }
         return new FebsResponse().success().message("确认成功");
@@ -237,4 +245,28 @@
         return new FebsResponse().success().data(apiLeaderInfoVo);
     }
 
+    @Override
+    public FebsResponse findTeamOrderMarkCnt() {
+        MallMember loginUser = LoginUserUtil.getLoginUser();
+        Long memberId = loginUser.getId();
+        MallMember mallMember = mallMemberMapper.selectById(memberId);
+
+        log.info(mallMember.getInviteId());
+        MallTeamLeader mallTeamLeader = this.baseMapper.selectLeaderByUniqueCode(mallMember.getInviteId());
+        if(ObjectUtil.isEmpty(mallTeamLeader)){
+            return new FebsResponse().success();
+        }
+        String uniqueCode = mallTeamLeader.getUniqueCode();
+        List<Map<String, Integer>> maps = mallOrderInfoMapper.selectMemberOrderStatusCntByUniquecode(uniqueCode);
+        Map<Integer, Integer> orderCnt = new HashMap<>();
+        if (CollUtil.isNotEmpty(maps)) {
+            for (Map<String, Integer> map : maps) {
+                orderCnt.put(map.get("status"), map.get("cnt"));
+            }
+        }
+        Map<String, Object> result = new HashMap<>();
+        result.put("order", orderCnt);
+        return new FebsResponse().success().data(result);
+    }
+
 }

--
Gitblit v1.9.1