From 5e6c61b8753870ef2f8cde60eef47e3eeefe89e6 Mon Sep 17 00:00:00 2001
From: luqingyang <lqy5492@163.com>
Date: 星期四, 02 十一月 2023 17:35:48 +0800
Subject: [PATCH] 报废单 相关代码

---
 consum-base/src/main/java/com/consum/base/service/LWhFormOutputServiceImpl.java |   60 ++++++++++++++++++++++++++++++++++++++----------------------
 1 files changed, 38 insertions(+), 22 deletions(-)

diff --git a/consum-base/src/main/java/com/consum/base/service/LWhFormOutputServiceImpl.java b/consum-base/src/main/java/com/consum/base/service/LWhFormOutputServiceImpl.java
index 7be440f..5c038cb 100644
--- a/consum-base/src/main/java/com/consum/base/service/LWhFormOutputServiceImpl.java
+++ b/consum-base/src/main/java/com/consum/base/service/LWhFormOutputServiceImpl.java
@@ -3,8 +3,7 @@
 import com.consum.base.core.CodeGeneratorEnum;
 import com.consum.base.core.CodeGeneratorService;
 import com.consum.base.core.param.BaseWarehouseParam1;
-import com.consum.base.pojo.LWhFormOutputParam;
-import com.consum.base.pojo.LWhProcureModelParams;
+import com.consum.base.pojo.*;
 import com.consum.base.util.IdUtil;
 import com.consum.model.po.*;
 import com.iplatform.model.po.S_user_core;
@@ -41,6 +40,8 @@
     private LWhProcureModelService lWhProcureModelService;
     @Autowired
     private LWhFormOutputCoreService lWhFormOutputCoreService;
+    @Autowired
+    private BaseGoodsModelsServiceImpl baseGoodsModelsService;
 
     private static String QUERY_FORM_OUTPUT_LIST = "SELECT * FROM l_wh_form_output WHERE 1 = 1";
 
@@ -146,7 +147,7 @@
      * @Author 鍗㈠簡闃�
      * @Date 2023/10/27
      */
-    public int add(LWhFormOutputParam param, S_user_core currentUser, FinSysTenantUser sysInfo) {
+    public int add(LWhFormOutputInsertParam param, S_user_core currentUser, FinSysTenantUser sysInfo) {
         //1.鏂板鍑哄簱鍗曡褰�
         LWhFormOutput lWhFormOutput = new LWhFormOutput();
         //鍑哄叆搴搃d
@@ -168,8 +169,7 @@
         lWhFormOutput.setAgencyName(sysInfo.getTenantName());
         lWhFormOutput.setOperatorId(sysInfo.getId());
         lWhFormOutput.setOperatorName(sysInfo.getUserName());
-        long dateTimeNumber = DateUtils.getDateTimeNumber(System.currentTimeMillis());
-        lWhFormOutput.setDealTime(dateTimeNumber);
+        lWhFormOutput.setDealTime(param.getDealTime());
         lWhFormOutput.setStates(1);
         int flag1 = this.insert(lWhFormOutput);
         if (flag1 == 0) {
@@ -177,27 +177,43 @@
             return 0;
         }
         //2.鏂板鐗╁搧鍨嬪彿璁板綍
-        List<LWhProcureModelParams> models = param.getModels();
-        List<LWhProcureModel> modelList = new ArrayList<>();
-        for (LWhProcureModelParams model : models) {
-            LWhProcureModel lWhProcureModel = new LWhProcureModel();
-            lWhProcureModel.setId(IdUtil.generateId());
-            lWhProcureModel.setBusinessType(3);
-            lWhProcureModel.setBusinessId(lWhFormOutputId);
-            lWhProcureModel.setBaseGoodsModelsId(model.getBaseGoodsModelsId());
-            //lWhProcureModel.se
-            lWhProcureModel.setCounts(model.getCounts());
-            //鏍规嵁鐗╁搧鍨嬪彿鏌ヨ鐗╁搧搴撳瓨
-            int goodsNum = this.lWhGoodsService.queryGoodsModelNum(0,warehouseId, model.getBaseGoodsModelsId(), (short) 1, null);
-            lWhProcureModel.setWorehouseCount(goodsNum);
-            modelList.add(lWhProcureModel);
+        List<LWhFormOutputGoodsParams> goodsList = param.getGoods();
+        for (LWhFormOutputGoodsParams goods : goodsList) {
+            List<LWhProcureModelParams> models = goods.getModels();
+            List<LWhProcureModel> modelList = new ArrayList<>();
+            for (LWhProcureModelParams model : models) {
+                LWhProcureModel lWhProcureModel = new LWhProcureModel();
+                lWhProcureModel.setId(IdUtil.generateId());
+                lWhProcureModel.setBusinessType(3);
+                lWhProcureModel.setBusinessId(lWhFormOutputId);
+                lWhProcureModel.setBaseGoodsModelsId(model.getBaseGoodsModelsId());
+                //鏍规嵁鍨嬪彿id鏌ヨ鍨嬪彿
+                BaseGoodsModels baseGoodsModels = this.baseGoodsModelsService.get(new BaseGoodsModels(model.getBaseGoodsModelsId()));
+                if (baseGoodsModels != null) {
+                    lWhProcureModel.setBaseGoodsModelsName(baseGoodsModels.getModelName());
+                }
+                lWhProcureModel.setCounts(model.getCounts());
+                //鏍规嵁鐗╁搧鍨嬪彿鏌ヨ鐗╁搧搴撳瓨
+                int goodsNum = this.lWhGoodsService.queryGoodsModelNum(0,warehouseId, model.getBaseGoodsModelsId(), (short) 1, null);
+                lWhProcureModel.setWorehouseCount(goodsNum);
+                modelList.add(lWhProcureModel);
+            }
+            int flag2 = this.lWhProcureModelService.insert(modelList);
+            if (flag2 != modelList.size()) {
+                log.error("鏂板鐗╁搧鍨嬪彿澶辫触");
+                TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
+                return 0;
+            }
         }
-        int flag2 = this.lWhProcureModelService.insert(modelList);
-        if (flag2 != modelList.size()) {
-            log.error("鏂板鐗╁搧鍨嬪彿澶辫触");
+
+        //3.鏍规嵁鍑哄簱鍗曞嚭搴�
+        Long lWarehouseFlowId = this.lWhFormOutputCoreService.outFormByTransId(lWhFormOutputId, currentUser, param.getDealTime());
+        if (lWarehouseFlowId == null) {
+            log.error("鏍规嵁鍑哄簱鍗曞嚭搴撳け璐�");
             TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
             return 0;
         }
+
         return 1;
     }
 

--
Gitblit v1.9.1