From 583f0b0df83876e68e8729d9872f83af08b8ae27 Mon Sep 17 00:00:00 2001
From: futian.liu <liufutianyoo@163.com>
Date: 星期五, 08 十二月 2023 10:35:06 +0800
Subject: [PATCH] 部门使用人重复显示修改

---
 consum-base/src/main/java/com/consum/base/controller/LWhFormTransferController.java    |  110 ++++++++++++---------
 consum-base/src/main/java/com/consum/base/service/impl/LWhFormTransferServiceImpl.java |   89 +++++++++--------
 consum-base/src/main/java/com/consum/base/core/type/TransferBusinessType.java          |   44 ++++++++
 3 files changed, 154 insertions(+), 89 deletions(-)

diff --git a/consum-base/src/main/java/com/consum/base/controller/LWhFormTransferController.java b/consum-base/src/main/java/com/consum/base/controller/LWhFormTransferController.java
index c5bc418..160179e 100644
--- a/consum-base/src/main/java/com/consum/base/controller/LWhFormTransferController.java
+++ b/consum-base/src/main/java/com/consum/base/controller/LWhFormTransferController.java
@@ -1,8 +1,26 @@
 package com.consum.base.controller;
 
-import cn.afterturn.easypoi.excel.ExcelExportUtil;
-import cn.afterturn.easypoi.excel.entity.TemplateExportParams;
-import cn.hutool.core.util.ReflectUtil;
+import java.lang.reflect.Field;
+import java.util.ArrayList;
+import java.util.Comparator;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Map.Entry;
+import java.util.Optional;
+import java.util.stream.Collectors;
+
+import javax.servlet.http.HttpServletResponse;
+
+import org.apache.commons.compress.utils.Lists;
+import org.apache.poi.ss.usermodel.Workbook;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
 import com.consum.base.BaseController;
 import com.consum.base.core.utils.CommonUtil;
 import com.consum.base.core.utils.IdUtil;
@@ -20,31 +38,31 @@
 import com.consum.base.pojo.response.GoodsTemplateCountVO;
 import com.consum.base.pojo.response.LWHFromTransferExtendVO;
 import com.consum.base.pojo.response.TransferInfoVO;
-import com.consum.base.service.*;
+import com.consum.base.service.BaseWarehouseService;
+import com.consum.base.service.LGoodsUserRecordCoreService;
+import com.consum.base.service.LWhFormTransferService;
+import com.consum.base.service.LWhProcureModelService;
+import com.consum.base.service.LWhProcureModelUserRecordService;
+import com.consum.base.service.LWhProcureModelUserService;
 import com.consum.base.service.impl.LWhFormTransferCoreService;
-import com.consum.model.po.*;
+import com.consum.model.po.BaseWarehouse;
+import com.consum.model.po.FinSysTenantUser;
+import com.consum.model.po.LWhFormTransfer;
+import com.consum.model.po.LWhProcureModelUser;
+import com.consum.model.po.LWhProcureModelUserRecord;
 import com.iplatform.model.po.S_user_core;
 import com.walker.db.page.GenericPager;
 import com.walker.infrastructure.utils.CollectionUtils;
 import com.walker.infrastructure.utils.DateUtils;
 import com.walker.web.ResponseValue;
+
+import cn.afterturn.easypoi.excel.ExcelExportUtil;
+import cn.afterturn.easypoi.excel.entity.TemplateExportParams;
+import cn.hutool.core.util.ReflectUtil;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
-import org.apache.commons.compress.utils.Lists;
-import org.apache.poi.ss.usermodel.Workbook;
-import org.springframework.beans.BeanUtils;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
-
-import javax.servlet.http.HttpServletResponse;
-import java.lang.reflect.Field;
-import java.util.*;
-import java.util.stream.Collectors;
 
 /**
  * @Description 璋冩嫧绠$悊
@@ -413,41 +431,39 @@
         }
         List<GoodsUseRecordVO> goodsUseRecordList = Lists.newArrayList();
         // 鍒嗙粍
-        Map<Long, Map<Long, List<UseRecordDTO>>> collect = useRecordDTOList.stream().collect(
-            Collectors.groupingBy(UseRecordDTO::getId, Collectors.groupingBy(UseRecordDTO::getBaseGoodsModelsId)));
-        // 寮�濮嬪惊鐜痗ollect
-        for (Map.Entry<Long, Map<Long, List<UseRecordDTO>>> entry : collect.entrySet()) {
+        Map<Long, List<UseRecordDTO>> groupedRecords =
+            useRecordDTOList.stream().collect(Collectors.groupingBy(UseRecordDTO::getId));
+        for (Entry<Long, List<UseRecordDTO>> entry : groupedRecords.entrySet()) {
             Long id = entry.getKey();
-            Map<Long, List<UseRecordDTO>> value = entry.getValue();
+            List<UseRecordDTO> useRecordList = entry.getValue();
+            UseRecordDTO useRecordDto = useRecordList.get(0);
             // 寮�濮嬪惊鐜痸alue
+            GoodsUseRecordVO goodsUseRecordVO = new GoodsUseRecordVO();
+            goodsUseRecordVO.setId(id);
+            goodsUseRecordVO.setUpdateUserName(useRecordDto.getUpdateUserName());
+            goodsUseRecordVO.setUpdateTime(useRecordDto.getUpdateTime());
             List<UseRecordSkuVO> useRecordSkuList = Lists.newArrayList();
-            for (Map.Entry<Long, List<UseRecordDTO>> item : value.entrySet()) {
-                List<UseRecordDTO> list = item.getValue();
-                List<RecordUserInfoVO> recordUserInfoList = Lists.newArrayList();
-                for (UseRecordDTO useRecordDto : list) {
-
-                    GoodsUseRecordVO goodsUseRecordVO = new GoodsUseRecordVO();
-                    goodsUseRecordVO.setId(id);
-                    goodsUseRecordVO.setUpdateUserName(useRecordDto.getUpdateUserName());
-                    goodsUseRecordVO.setUpdateTime(useRecordDto.getUpdateTime());
-
+            useRecordList.stream().collect(Collectors.groupingBy(UseRecordDTO::getProcureModelId))
+                .forEach((key, recordList) -> {
+                    UseRecordDTO useRecordDTO = recordList.get(0);
                     UseRecordSkuVO useRecordSkuVO = new UseRecordSkuVO();
-                    useRecordSkuVO.setBaseGoodModelId(useRecordDto.getBaseGoodsModelsId());
-                    useRecordSkuVO.setBaseGoodModelName(useRecordDto.getBaseGoodsModelsName());
-                    useRecordSkuVO.setUnit(useRecordDto.getUnit());
-                    useRecordSkuVO.setProcureModelId(useRecordDto.getProcureModelId());
-
-                    RecordUserInfoVO recordUserInfoVO = new RecordUserInfoVO();
-                    recordUserInfoVO.setUseName(useRecordDto.getUseName());
-                    recordUserInfoVO.setPhone(useRecordDto.getPhone());
-                    recordUserInfoVO.setNum(useRecordDto.getNum());
-                    recordUserInfoList.add(recordUserInfoVO);
+                    useRecordSkuVO.setBaseGoodModelId(useRecordDTO.getBaseGoodsModelsId());
+                    useRecordSkuVO.setBaseGoodModelName(useRecordDTO.getBaseGoodsModelsName());
+                    useRecordSkuVO.setUnit(useRecordDTO.getUnit());
+                    useRecordSkuVO.setProcureModelId(useRecordDTO.getProcureModelId());
+                    List<RecordUserInfoVO> recordUserInfoList = Lists.newArrayList();
+                    for (UseRecordDTO userInfo : recordList) {
+                        RecordUserInfoVO recordUserInfoVO = new RecordUserInfoVO();
+                        recordUserInfoVO.setUseName(userInfo.getUseName());
+                        recordUserInfoVO.setPhone(userInfo.getPhone());
+                        recordUserInfoVO.setNum(userInfo.getNum());
+                        recordUserInfoList.add(recordUserInfoVO);
+                    }
                     useRecordSkuVO.setRecordUserInfos(recordUserInfoList);
                     useRecordSkuList.add(useRecordSkuVO);
-                    goodsUseRecordVO.setRecordSkuDtoList(useRecordSkuList);
-                    goodsUseRecordList.add(goodsUseRecordVO);
-                }
-            }
+                });
+            goodsUseRecordVO.setRecordSkuDtoList(useRecordSkuList);
+            goodsUseRecordList.add(goodsUseRecordVO);
         }
         // 鍒嗙粍涔嬪悗閲嶆柊鎺掑簭
         List<GoodsUseRecordVO> result = goodsUseRecordList
diff --git a/consum-base/src/main/java/com/consum/base/core/type/TransferBusinessType.java b/consum-base/src/main/java/com/consum/base/core/type/TransferBusinessType.java
new file mode 100644
index 0000000..529468b
--- /dev/null
+++ b/consum-base/src/main/java/com/consum/base/core/type/TransferBusinessType.java
@@ -0,0 +1,44 @@
+package com.consum.base.core.type;
+
+/**
+ * 璋冩嫧涓氬姟绫诲瀷
+ *
+ * @author asus
+ * @version 2023/12/08 09:50
+ **/
+public enum TransferBusinessType {
+
+    /**
+     * 浠撳簱璋冩嫧
+     */
+    STOCK_TRANSFER(0, "浠撳簱璋冩嫧"),
+    /**
+     * 閮ㄩ棬鍒嗗彂
+     */
+    DEPARTMENT_PROCURE(1, "閮ㄩ棬鍒嗗彂");
+
+    private Integer value;
+
+    private String desc;
+
+    TransferBusinessType(Integer value, String desc) {
+        this.value = value;
+        this.desc = desc;
+    }
+
+    public Integer getValue() {
+        return value;
+    }
+
+    public void setValue(Integer value) {
+        this.value = value;
+    }
+
+    public String getDesc() {
+        return desc;
+    }
+
+    public void setDesc(String desc) {
+        this.desc = desc;
+    }
+}
diff --git a/consum-base/src/main/java/com/consum/base/service/impl/LWhFormTransferServiceImpl.java b/consum-base/src/main/java/com/consum/base/service/impl/LWhFormTransferServiceImpl.java
index 8bd2708..dd21c13 100644
--- a/consum-base/src/main/java/com/consum/base/service/impl/LWhFormTransferServiceImpl.java
+++ b/consum-base/src/main/java/com/consum/base/service/impl/LWhFormTransferServiceImpl.java
@@ -5,7 +5,6 @@
 import java.util.List;
 import java.util.Map;
 import java.util.Objects;
-import java.util.Optional;
 import java.util.stream.Collectors;
 
 import org.apache.commons.compress.utils.Lists;
@@ -18,6 +17,7 @@
 import com.consum.base.core.CodeGeneratorEnum;
 import com.consum.base.core.CodeGeneratorService;
 import com.consum.base.core.type.CategoryType;
+import com.consum.base.core.type.TransferBusinessType;
 import com.consum.base.core.utils.CurrencyUtil;
 import com.consum.base.core.utils.IdUtil;
 import com.consum.base.core.utils.MapUtils;
@@ -99,23 +99,20 @@
         lWhFormTransfer.setId(lWhFormTransferId);
 
         Integer businessType = param.getTransferBusinessType();
-        // 鍗曟嵁绫诲瀷銆�0浠撳簱璋冩嫧锛�1閮ㄩ棬鍒嗗彂锛�2閮ㄩ棬鐗╁搧鍥為��
-        // TODO 鏋氫妇瀛楀吀
+        // 鍗曟嵁绫诲瀷銆�0浠撳簱璋冩嫧锛�1閮ㄩ棬鍒嗗彂
         lWhFormTransfer.setBusinessType(businessType);
         CodeGeneratorEnum codeGeneratorEnum = null;
-        if (businessType == 0) {
+        if (businessType == TransferBusinessType.STOCK_TRANSFER.getValue()) {
             codeGeneratorEnum = CodeGeneratorEnum.Transfer;
-        } else if (businessType == 1) {
+        } else if (businessType == TransferBusinessType.DEPARTMENT_PROCURE.getValue()) {
             codeGeneratorEnum = CodeGeneratorEnum.Distribute;
-        } else if (businessType == 2) {
-            codeGeneratorEnum = CodeGeneratorEnum.GOBACK;
         }
 
         lWhFormTransfer.setBusinessFormCode(codeGeneratorService.createBusinessFormCode(codeGeneratorEnum));
 
         Long warehouseId = param.getInWarehouseId();
         // 璋冩嫧绫诲瀷鍗曟嵁
-        if (businessType == 0) {
+        if (businessType == TransferBusinessType.STOCK_TRANSFER.getValue()) {
             // 鍏ュ簱浠撳簱涓哄綋鍓嶇敤鎴风殑榛樿浠撳簱
             String tenantId = sysInfo.getTenantId();
             String tenantName = sysInfo.getTenantName();
@@ -130,7 +127,7 @@
             lWhFormTransfer.setInAgencyName(tenantName);
         }
         // 褰撲笟鍔$被鍨嬩负閮ㄩ棬鍒嗗彂鏃� 娣诲姞閮ㄩ棬鍒嗗彂璁板綍鍜屼娇鐢ㄤ汉
-        if (businessType == 1) {
+        if (businessType == TransferBusinessType.DEPARTMENT_PROCURE.getValue()) {
             // 閮ㄩ棬鍒嗗彂绫诲瀷 鍑哄簱浠撳簱绫诲瀷0鏈烘瀯1閮ㄩ棬
             // 浠庡綋鍓嶇櫥褰曞簱绠′汉浠庡簱涓嚭搴擄紝鍏ュ埌鎵�閫夐儴闂ㄧ殑涓�
 
@@ -143,29 +140,27 @@
                 log.error("璇ョ敤鎴蜂笉鏄簱绠″憳");
                 throw new Exception("璇ョ敤鎴蜂笉鏄簱绠″憳");
             }
-            Optional<BaseWarehouseManager> first = managerList.stream().findFirst();
-            if (first.isPresent()) {
-                BaseWarehouseManager baseWarehouseManager = first.get();
-                Long baseWarehouseId = baseWarehouseManager.getBaseWarehouseId();
-                BaseWarehouse baseWarehouse = new BaseWarehouse();
-                baseWarehouse.setId(baseWarehouseId);
-                BaseWarehouse warehouse = baseWarehouseService.get(baseWarehouse);
+            BaseWarehouseManager baseWarehouseManager = managerList.stream().findFirst().orElse(null);
+            Long baseWarehouseId = baseWarehouseManager.getBaseWarehouseId();
+            BaseWarehouse baseWarehouse = new BaseWarehouse();
+            baseWarehouse.setId(baseWarehouseId);
+            BaseWarehouse warehouse = baseWarehouseService.get(baseWarehouse);
 
-                lWhFormTransfer.setInWarehouseType(1);
-                lWhFormTransfer.setInWarehouseId(param.getDepartmentId());
-                lWhFormTransfer.setInWarehouseName(param.getDepartmentName());
-                lWhFormTransfer.setInOperatorName(param.getOperatorName());
-                lWhFormTransfer.setInTime(param.getCreateTime());
+            lWhFormTransfer.setInWarehouseType(1);
+            lWhFormTransfer.setInWarehouseId(param.getDepartmentId());
+            lWhFormTransfer.setInWarehouseName(param.getDepartmentName());
+            lWhFormTransfer.setInOperatorName(param.getOperatorName());
+            lWhFormTransfer.setInTime(param.getCreateTime());
 
-                lWhFormTransfer.setOutWarehouseType(0);
-                lWhFormTransfer.setOutWarehouseId(warehouse.getId());
-                lWhFormTransfer.setOutWarehouseName(warehouse.getWarehouseName());
+            lWhFormTransfer.setOutWarehouseType(0);
+            lWhFormTransfer.setOutWarehouseId(warehouse.getId());
+            lWhFormTransfer.setOutWarehouseName(warehouse.getWarehouseName());
 
-                lWhFormTransfer.setOutOperatorId(sysInfo.getId());
-                lWhFormTransfer.setOutOperatorName(sysInfo.getUserName());
-                lWhFormTransfer.setOutputTime(param.getCreateTime());
-                lWhFormTransfer.setTel(param.getTel());
-            }
+            lWhFormTransfer.setOutOperatorId(sysInfo.getId());
+            lWhFormTransfer.setOutOperatorName(sysInfo.getUserName());
+            lWhFormTransfer.setOutputTime(param.getCreateTime());
+            lWhFormTransfer.setTel(param.getTel());
+
         }
 
         // 鏍规嵁鏈烘瀯id鏌ヨ璋冩嫧鏈烘瀯
@@ -190,6 +185,23 @@
         // 2.鏂板鐗╁搧鍨嬪彿璁板綍
         List<LWhFormTransferGoodsInfoParam> transferGoods = param.getTransferGoods();
         List<LWhProcureModel> modelList = new ArrayList<>();
+
+        // 鍒ゆ柇娣诲姞涓�娆′娇鐢ㄤ汉璁板綍
+        List<LWhFormTransferGoodsInfoParam> type = transferGoods.stream()
+            .filter(
+                item -> businessType == TransferBusinessType.DEPARTMENT_PROCURE.getValue() && item.getModels().stream()
+                    .anyMatch(model -> baseGoodsModelsService.queryGoodsModelInfo(model.getBaseGoodsModelsId()).stream()
+                        .findFirst().orElse(null).get("type").equals(CategoryType.TYPE_A.getValue())))
+            .collect(Collectors.toList());
+        LWhProcureModelUserRecord lWhProcureModelUserRecord = new LWhProcureModelUserRecord();
+        if (CollectionUtils.isEmpty(type)) {
+            lWhProcureModelUserRecord.setId(IdUtil.generateId());
+            lWhProcureModelUserRecord.setTransBusinessId(lWhFormTransferId);
+            lWhProcureModelUserRecord.setOperatorId(sysInfo.getId());
+            lWhProcureModelUserRecord.setOperatorName(sysInfo.getUserName());
+            lWhProcureModelUserRecord.setDealTime(DateUtils.getDateTimeNumber(System.currentTimeMillis()));
+            lWhProcureModelUserRecordService.insert(lWhProcureModelUserRecord);
+        }
         for (LWhFormTransferGoodsInfoParam transferGoodsInfo : transferGoods) {
             for (LWhTransferModelParam model : transferGoodsInfo.getModels()) {
                 LWhProcureModel lWhProcureModel = new LWhProcureModel();
@@ -197,13 +209,13 @@
                 // 璋冩嫧涓氬姟绫诲瀷杞崲鍒扮墿鍝佺被鍨�
                 // 鐗╁搧绫诲瀷 1 閲囪喘2 璋冩嫧 3鍑哄簱4閮ㄩ棬鍒嗗彂
                 Long baseGoodsModelsId = model.getBaseGoodsModelsId();
-                if (businessType == 0) {
+                if (businessType == TransferBusinessType.STOCK_TRANSFER.getValue()) {
                     lWhProcureModel.setBusinessType(2);
                     // 鏍规嵁鐗╁搧鍨嬪彿鏌ヨ鐗╁搧搴撳瓨
                     int goodsNum = lWhGoodsService.queryGoodsModelNum(0, warehouseId, baseGoodsModelsId, 1, null);
                     lWhProcureModel.setWorehouseCount(goodsNum);
                 }
-                if (businessType == 1) {
+                if (businessType == TransferBusinessType.DEPARTMENT_PROCURE.getValue()) {
                     lWhProcureModel.setBusinessType(4);
                 }
                 lWhProcureModel.setCounts(model.getCounts());
@@ -223,16 +235,8 @@
                 // 3.褰撲笟鍔$被鍨嬩负閮ㄩ棬鍒嗗彂鏃� 娣诲姞閮ㄩ棬鍒嗗彂璁板綍鍜屼娇鐢ㄤ汉
                 // 鍗曟嵁绫诲瀷 1 閲囪喘2 璋冩嫧 3鍑哄簱4閮ㄩ棬鍒嗗彂
                 // 閮ㄩ棬鍒嗗彂绫诲瀷
-                if (businessType == 1 && CategoryType.TYPE_A.getValue().equals(baseModelMap.get("type"))) {
-                    // TODO 閲嶅淇濆瓨
-                    LWhProcureModelUserRecord lWhProcureModelUserRecord = new LWhProcureModelUserRecord();
-                    lWhProcureModelUserRecord.setId(IdUtil.generateId());
-                    lWhProcureModelUserRecord.setTransBusinessId(lWhFormTransferId);
-                    lWhProcureModelUserRecord.setOperatorId(sysInfo.getId());
-                    lWhProcureModelUserRecord.setOperatorName(sysInfo.getUserName());
-                    lWhProcureModelUserRecord.setDealTime(DateUtils.getDateTimeNumber(System.currentTimeMillis()));
-                    lWhProcureModelUserRecordService.insert(lWhProcureModelUserRecord);
-
+                if (businessType == TransferBusinessType.DEPARTMENT_PROCURE.getValue()
+                    && CategoryType.TYPE_A.getValue().equals(baseModelMap.get("type"))) {
                     List<LWhProcureModelUser> procureModelUserList = Lists.newArrayList();
                     for (LWhProcureModelUserParam lWhProcureModelUserParam : model.getProcureModelUserList()) {
                         LWhProcureModelUser lWhProcureModelUser = new LWhProcureModelUser();
@@ -385,7 +389,8 @@
                 // 閮ㄩ棬鍒嗗彂闇�瑕佹煡璇娇鐢ㄤ俊鎭�
                 Integer businessType = result.getBusinessType();
                 String type = goodsTemplateInfoVO.getType();
-                if (businessType == 1 && CategoryType.TYPE_A.getValue().equals(type)) {
+                if (businessType == TransferBusinessType.DEPARTMENT_PROCURE.getValue()
+                    && CategoryType.TYPE_A.getValue().equals(type)) {
                     Long procureModelId = goodsModelVO.getId();
 
                     LWhProcureModelUser lWhProcureModelUser = new LWhProcureModelUser();

--
Gitblit v1.9.1