From 74e50376959e8f1a8da425288fa94075611721c3 Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期三, 31 三月 2021 09:10:06 +0800
Subject: [PATCH] 优化合同 人

---
 service-store/src/main/java/com/java110/store/smo/impl/ContractChangePlanInnerServiceSMOImpl.java |   48 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 48 insertions(+), 0 deletions(-)

diff --git a/service-store/src/main/java/com/java110/store/smo/impl/ContractChangePlanInnerServiceSMOImpl.java b/service-store/src/main/java/com/java110/store/smo/impl/ContractChangePlanInnerServiceSMOImpl.java
index 9fea188..f08b59b 100644
--- a/service-store/src/main/java/com/java110/store/smo/impl/ContractChangePlanInnerServiceSMOImpl.java
+++ b/service-store/src/main/java/com/java110/store/smo/impl/ContractChangePlanInnerServiceSMOImpl.java
@@ -4,7 +4,9 @@
 import com.java110.core.base.smo.BaseServiceSMO;
 import com.java110.dto.PageDto;
 import com.java110.dto.contractChangePlan.ContractChangePlanDto;
+import com.java110.dto.user.UserDto;
 import com.java110.intf.store.IContractChangePlanInnerServiceSMO;
+import com.java110.intf.user.IUserInnerServiceSMO;
 import com.java110.po.contractChangePlan.ContractChangePlanPo;
 import com.java110.store.dao.IContractChangePlanServiceDao;
 import com.java110.utils.util.BeanConvertUtil;
@@ -12,6 +14,7 @@
 import org.springframework.web.bind.annotation.RequestBody;
 import org.springframework.web.bind.annotation.RestController;
 
+import java.util.ArrayList;
 import java.util.List;
 
 /**
@@ -27,6 +30,9 @@
 
     @Autowired
     private IContractChangePlanServiceDao contractChangePlanServiceDaoImpl;
+
+    @Autowired
+    private IUserInnerServiceSMO userInnerServiceSMOImpl;
 
 
     @Override
@@ -64,10 +70,52 @@
 
         List<ContractChangePlanDto> contractChangePlans = BeanConvertUtil.covertBeanList(contractChangePlanServiceDaoImpl.getContractChangePlanInfo(BeanConvertUtil.beanCovertMap(contractChangePlanDto)), ContractChangePlanDto.class);
 
+        if (contractChangePlans == null || contractChangePlans.size() < 1) {
+            return contractChangePlans;
+        }
+        String[] userIds = getUserIds(contractChangePlans);
+
+        //鏍规嵁 userId 鏌ヨ鐢ㄦ埛淇℃伅
+        List<UserDto> users = userInnerServiceSMOImpl.getUserInfo(userIds);
+
+        for (ContractChangePlanDto contractChangePlanDto1 : contractChangePlans) {
+            refreshContractChangePlan(contractChangePlanDto1, users);
+        }
         return contractChangePlans;
     }
 
 
+    /**
+     * 浠庣敤鎴峰垪琛ㄤ腑鏌ヨ鐢ㄦ埛锛屽皢鐢ㄦ埛涓殑淇℃伅 鍒锋柊鍒� floor瀵硅薄涓�
+     *
+     * @param users 鐢ㄦ埛鍒楄〃
+     */
+    private void refreshContractChangePlan(ContractChangePlanDto contractChangePlanDto, List<UserDto> users) {
+        for (UserDto user : users) {
+            if (contractChangePlanDto.getChangePerson().equals(user.getUserId())) {
+                contractChangePlanDto.setChangePersonName(user.getUserName());
+            }
+        }
+    }
+
+    /**
+     * 鑾峰彇鎵归噺userId
+     *
+     * @return 鎵归噺userIds 淇℃伅
+     */
+    private String[] getUserIds(List<ContractChangePlanDto> contractChangePlans) {
+        if (contractChangePlans == null || contractChangePlans.size() < 1) {
+            return null;
+        }
+        List<String> userIds = new ArrayList<String>();
+        for (ContractChangePlanDto contractChangePlanDto : contractChangePlans) {
+            userIds.add(contractChangePlanDto.getChangePerson());
+        }
+
+        return userIds.toArray(new String[userIds.size()]);
+    }
+
+
     @Override
     public int queryContractChangePlansCount(@RequestBody ContractChangePlanDto contractChangePlanDto) {
         return contractChangePlanServiceDaoImpl.queryContractChangePlansCount(BeanConvertUtil.beanCovertMap(contractChangePlanDto));

--
Gitblit v1.8.0