From e53db31914bdbc49aa491e1613986e14fe211445 Mon Sep 17 00:00:00 2001
From: futian.liu <liufutianyoo@163.com>
Date: 星期五, 08 十二月 2023 11:06:43 +0800
Subject: [PATCH] 使用记录保存一次

---
 consum-base/src/main/java/com/consum/base/service/impl/LWhFormTransferServiceImpl.java |  112 ++++++++++++++++++++++++++++----------------------------
 1 files changed, 56 insertions(+), 56 deletions(-)

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 473f57a..74c16f6 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
@@ -1,12 +1,10 @@
 package com.consum.base.service.impl;
 
-import com.consum.base.pojo.response.GoodsTemplateInfoVO;
 import java.util.ArrayList;
 import java.util.HashMap;
 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;
@@ -19,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;
@@ -32,6 +31,7 @@
 import com.consum.base.pojo.request.LWhFormTransferParam;
 import com.consum.base.pojo.response.DepartGoodsUseInfo;
 import com.consum.base.pojo.response.GoodsModelVO;
+import com.consum.base.pojo.response.GoodsTemplateInfoVO;
 import com.consum.base.pojo.response.LWHFromTransferExtendVO;
 import com.consum.base.service.BaseWarehouseManagerService;
 import com.consum.base.service.BaseWarehouseService;
@@ -50,6 +50,7 @@
 import com.consum.model.po.LWhProcureModelUser;
 import com.consum.model.po.LWhProcureModelUserRecord;
 import com.walker.db.page.GenericPager;
+import com.walker.infrastructure.utils.DateUtils;
 import com.walker.infrastructure.utils.StringUtils;
 import com.walker.jdbc.service.BaseServiceImpl;
 
@@ -80,10 +81,10 @@
     @Autowired
     private BaseWarehouseManagerService baseWarehouseManagerService;
 
-    private static final String QUERY_FORM_TRANSFER_LIST =
-        "SELECT DISTINCT ft.* FROM l_wh_form_transfer ft " + "left join L_WH_PROCURE_MODEL pm on pm.BUSINESS_ID = ft.id "
-            + "LEFT JOIN BASE_GOODS_MODELS bgm ON pm.BASE_GOODS_MODELS_ID=bgm.ID "
-            + "LEFT JOIN BASE_GOODS_TEMPLATE bgt ON bgm.GOODS_TEMPLATES_ID=bgt.id WHERE 1 = 1 ";
+    private static final String QUERY_FORM_TRANSFER_LIST = "SELECT DISTINCT ft.* FROM l_wh_form_transfer ft "
+        + "left join L_WH_PROCURE_MODEL pm on pm.BUSINESS_ID = ft.id "
+        + "LEFT JOIN BASE_GOODS_MODELS bgm ON pm.BASE_GOODS_MODELS_ID=bgm.ID "
+        + "LEFT JOIN BASE_GOODS_TEMPLATE bgt ON bgm.GOODS_TEMPLATES_ID=bgt.id WHERE 1 = 1 ";
 
     /**
      * @Description 鏂板
@@ -98,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();
@@ -129,7 +127,7 @@
             lWhFormTransfer.setInAgencyName(tenantName);
         }
         // 褰撲笟鍔$被鍨嬩负閮ㄩ棬鍒嗗彂鏃� 娣诲姞閮ㄩ棬鍒嗗彂璁板綍鍜屼娇鐢ㄤ汉
-        if (businessType == 1) {
+        if (businessType == TransferBusinessType.DEPARTMENT_PROCURE.getValue()) {
             // 閮ㄩ棬鍒嗗彂绫诲瀷 鍑哄簱浠撳簱绫诲瀷0鏈烘瀯1閮ㄩ棬
             // 浠庡綋鍓嶇櫥褰曞簱绠′汉浠庡簱涓嚭搴擄紝鍏ュ埌鎵�閫夐儴闂ㄧ殑涓�
 
@@ -137,34 +135,32 @@
             Long id = sysInfo.getId();
             BaseWarehouseManager manager = new BaseWarehouseManager();
             manager.setManagerId(id);
-            List<BaseWarehouseManager> managerList = baseWarehouseManagerService.selectAll(manager);
+            List<BaseWarehouseManager> managerList = baseWarehouseManagerService.select(manager);
             if (CollectionUtils.isEmpty(managerList)) {
                 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鏌ヨ璋冩嫧鏈烘瀯
@@ -189,6 +185,23 @@
         // 2.鏂板鐗╁搧鍨嬪彿璁板綍
         List<LWhFormTransferGoodsInfoParam> transferGoods = param.getTransferGoods();
         List<LWhProcureModel> modelList = new ArrayList<>();
+
+        // 鍒ゆ柇娣诲姞涓�娆′娇鐢ㄤ汉璁板綍
+        List<LWhFormTransferGoodsInfoParam> recordType = 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(recordType)) {
+            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();
@@ -196,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());
@@ -222,14 +235,8 @@
                 // 3.褰撲笟鍔$被鍨嬩负閮ㄩ棬鍒嗗彂鏃� 娣诲姞閮ㄩ棬鍒嗗彂璁板綍鍜屼娇鐢ㄤ汉
                 // 鍗曟嵁绫诲瀷 1 閲囪喘2 璋冩嫧 3鍑哄簱4閮ㄩ棬鍒嗗彂
                 // 閮ㄩ棬鍒嗗彂绫诲瀷
-                if (businessType == 1 && "A".equals(baseModelMap.get("type"))) {
-                    LWhProcureModelUserRecord lWhProcureModelUserRecord = new LWhProcureModelUserRecord();
-                    lWhProcureModelUserRecord.setId(IdUtil.generateId());
-                    lWhProcureModelUserRecord.setTransBusinessId(lWhFormTransferId);
-                    lWhProcureModelUserRecord.setOperatorId(sysInfo.getId());
-                    lWhProcureModelUserRecord.setOperatorName(sysInfo.getUserName());
-                    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();
@@ -249,7 +256,6 @@
                         log.error("鏂板鐗╁搧浣跨敤淇℃伅澶辫触");
                         TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
                     }
-
                 }
 
                 modelList.add(lWhProcureModel);
@@ -356,13 +362,6 @@
         if (CollectionUtils.isEmpty(goodsModelInfo)) {
             return result;
         }
-        // 鏌ヨ閮ㄩ棬鐗╁搧浣跨敤淇℃伅
-        Map<String, Object> paramMap = new HashMap<>();
-        paramMap.put("id", result.getId());
-        String queryRecord =
-            "SELECT * FROM l_wh_procure_model_user_record where TRANS_BUSINESS_ID = :id order by DEAL_TIME desc limit 1";
-        LWhProcureModelUserRecord lWhProcureModelUserRecord =
-            lWhProcureModelUserRecordService.get(queryRecord, paramMap, new LWhProcureModelUserRecord());
 
         Map<Long, List<GoodModelInfoDTO>> collect =
             goodsModelInfo.stream().filter(Objects::nonNull).filter(dto -> dto.getBaseGoodsTemplateId() != null)
@@ -390,14 +389,15 @@
                 // 閮ㄩ棬鍒嗗彂闇�瑕佹煡璇娇鐢ㄤ俊鎭�
                 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();
                     lWhProcureModelUser.setWhProcureModelId(procureModelId);
-
-                    lWhProcureModelUser.setProcureModelUserRecordId(lWhProcureModelUserRecord.getId());
                     List<LWhProcureModelUser> procureModelUserList =
                         this.lWhProcureModelUserService.select(lWhProcureModelUser);
+
                     if (!CollectionUtils.isEmpty(procureModelUserList)) {
                         List<DepartGoodsUseInfo> departGoodsUseInfoList = Lists.newArrayList();
                         procureModelUserList.forEach(useInfo -> {

--
Gitblit v1.9.1