From 209d9c6f60d96fc29fad0bd2f9dad8fe8424f91f Mon Sep 17 00:00:00 2001
From: futian.liu <liufutianyoo@163.com>
Date: 星期五, 17 十一月 2023 18:10:47 +0800
Subject: [PATCH] 调拨管理

---
 consum-base/src/main/java/com/consum/base/service/LWhFormOutputServiceImpl.java |  168 ++++++++++++++++++++-----------------------------------
 1 files changed, 62 insertions(+), 106 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 038b6ec..aebbe2f 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
@@ -2,11 +2,13 @@
 
 import com.consum.base.core.CodeGeneratorEnum;
 import com.consum.base.core.CodeGeneratorService;
+import com.consum.base.core.WhBusinessEnum;
 import com.consum.base.core.param.BaseWarehouseParam1;
 import com.consum.base.core.utils.IdUtil;
+import com.consum.base.core.utils.MapperUtil;
+import com.consum.base.pojo.LWFormsOutputGoodsInfoParam;
 import com.consum.base.pojo.LWFormsOutputGoodsModelParam;
-import com.consum.base.pojo.LWFormsOutputGoodsParam;
-import com.consum.base.pojo.LWhFormOutputInsertParam;
+import com.consum.base.pojo.LWhFormOutputParam;
 import com.consum.base.pojo.query.LWhFormOutputQry;
 import com.consum.model.po.BaseGoodsModels;
 import com.consum.model.po.BaseWarehouse;
@@ -20,6 +22,7 @@
 import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.List;
+import java.util.Map;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
@@ -49,108 +52,13 @@
 
     private static String QUERY_FORM_OUTPUT_LIST = "SELECT * FROM l_wh_form_output WHERE 1 = 1";
 
-    //    /**
-//     * @Description 鏂板鍑哄簱鍗�
-//     * @Author 鍗㈠簡闃�
-//     * @Date 2023/10/27
-//     */
-//    public int add(LWhFormOutputParam param, S_user_core currentUser, FinSysTenantUser sysInfo) {
-//        //1.鏂板鍑哄簱鍗曡褰�
-//        LWhFormOutput lWhFormOutput = new LWhFormOutput();
-//        //鍑哄叆搴搃d
-//        long lWhFormOutputId = IdUtil.generateId();
-//        lWhFormOutput.setId(lWhFormOutputId);
-//        Long warehouseId = param.getWarehouseId();
-//        lWhFormOutput.setWarehouseId(warehouseId);
-//        //鏍规嵁浠撳簱id鏌ヨ浠撳簱
-//        BaseWarehouse warehouse = this.baseWarehouseService.getById(warehouseId);
-//        if (warehouse == null) {
-//            log.error("浠撳簱id涓嶅瓨鍦�");
-//            return 0;
-//        }
-//        lWhFormOutput.setWarehouseName(warehouse.getWarehouseName());
-//        lWhFormOutput.setOutputCode(BaseWarehouseParam1.In_OutPutTypeEnum.Fragmentary_Output.getValue()+"");
-//        lWhFormOutput.setOutputName("闆舵槦鍑哄簱");
-//        lWhFormOutput.setAgencyId(Long.valueOf(sysInfo.getTenantId()));
-//        lWhFormOutput.setAgencyName(sysInfo.getTenantName());
-//        lWhFormOutput.setOperatorId(sysInfo.getId());
-//        lWhFormOutput.setOperatorName(sysInfo.getUserName());
-//        long dateTimeNumber = DateUtils.getDateTimeNumber(System.currentTimeMillis());
-//        lWhFormOutput.setDealTime(dateTimeNumber);
-//        lWhFormOutput.setStates(1);
-//        int flag1 = this.insert(lWhFormOutput);
-//
-//        //2.鏍规嵁鍑哄簱鍗曞嚭搴�
-//        Long lWarehouseFlowId = this.lWhFormOutputCoreService.outFormByTransId(lWhFormOutput.getId(), currentUser, dateTimeNumber);
-//        //3.鍚戝嚭搴撳崟 鎻掑叆 杩涘嚭搴撴祦姘存�昏〃ID
-//        int flag3 = 0;
-//        if (flag1 > 0) {
-//            LWhFormOutput lWhFormOutput1 = new LWhFormOutput(lWhFormOutputId);
-//            lWhFormOutput1.setWarehouseFlowId(lWarehouseFlowId);
-//            flag3 = this.update(lWhFormOutput1);
-//        }
-//
-//        //4.鏂板l_wh_goods_record璁板綍
-//        List<LWhGoodsRecord> recordList = param.getList();
-//        if (CollectionUtils.isEmpty(recordList)) {
-//            log.error("瑙勬牸鍨嬪彿涓虹┖");
-//            return 0;
-//        }
-//        int flag5 = 0;
-//        int number = -1;  //鍑哄簱鍚庯紝鐗╁搧鍓╀綑鏁伴噺
-//        for (LWhGoodsRecord record : recordList) {
-//            //鐗╁搧id鍜岀墿鍝佸悕绉�
-//            record.setBaseGoodsTemplateId(param.getBaseGoodsTemplateId());
-//            record.setGoodsTemplateName(param.getGoodsTemplateName());
-//
-//            record.setId(IdUtil.generateId());
-//            record.setWarehouseId(warehouseId);
-//            //鏍规嵁鐗╁搧鍨嬪彿鏌ヨ鐗╁搧搴撳瓨
-//            int goodsNum = this.lWhGoodsService.queryGoodsModelNum(warehouseId, record.getBaseGoodsModelsId(), (short) 1, null);
-//            record.setInitialCount(goodsNum);
-//            record.setThisType(2);
-//
-//            //鍒ゆ柇鍑哄簱鏁伴噺鏄惁灏忎簬搴撳瓨
-//            number = goodsNum - record.getThisCount();
-//            if (number < 0) {
-//                log.error("搴撳瓨涓嶈冻");
-//                break;
-//            }
-//            record.setEndCount(number);
-//            record.setDealTime(dateTimeNumber);
-//            record.setWarehouseFlowId(lWarehouseFlowId);
-//
-//            //5.鏂板L_WH_PROCURE_MODEL璁板綍
-//            LWhProcureModel lWhProcureModel = new LWhProcureModel();
-//            lWhProcureModel.setId(IdUtil.generateId());
-//            lWhProcureModel.setBusinessType(3);
-//            lWhProcureModel.setBaseGoodsModelsId(record.getBaseGoodsModelsId());
-//            lWhProcureModel.setCounts(record.getThisCount());
-//            lWhProcureModel.setWorehouseCount(goodsNum);
-//            int res = this.lWhProcureModelService.insert(lWhProcureModel);
-//            flag5 += res;
-//        }
-//        //濡傛灉鍑哄簱鍚庯紝鍓╀綑搴撳瓨澶т簬0锛屾柊澧瀕_wh_goods_record璁板綍
-//        int flag4 = 0;
-//        if (number >= 0){
-//            flag4 = this.lWhGoodsService.insert(recordList);
-//        }
-//
-//        //濡傛灉鏈変竴鏉¤褰曟柊澧炲け璐ワ紝鍒欏洖婊�
-//        if (flag1 == 0 || flag3 == 0 || flag4 != recordList.size() || flag5 != recordList.size() || number < 0) {
-//            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
-//            return 0;
-//        }
-//
-//        return 1;
-//    }
 
     /**
      * @Description 鏂板鍑哄簱鍗�
      * @Author 鍗㈠簡闃�
      * @Date 2023/10/27
      */
-    public int add(LWhFormOutputInsertParam param, S_user_core currentUser, FinSysTenantUser sysInfo) {
+    public int add(LWhFormOutputParam param, S_user_core currentUser, FinSysTenantUser sysInfo) {
         //1.鏂板鍑哄簱鍗曡褰�
         LWhFormOutput lWhFormOutput = new LWhFormOutput();
         //鍑哄叆搴搃d
@@ -181,9 +89,9 @@
             return 0;
         }
         //2.鏂板鐗╁搧鍨嬪彿璁板綍
-        List<LWFormsOutputGoodsParam> goodsList = param.getGoods();
+        List<LWFormsOutputGoodsInfoParam> goodsList = param.getGoods();
         List<LWhProcureModel> modelList = new ArrayList<>();
-        for (LWFormsOutputGoodsParam goods : goodsList) {
+        for (LWFormsOutputGoodsInfoParam goods : goodsList) {
             List<LWFormsOutputGoodsModelParam> models = goods.getModels();
             for (LWFormsOutputGoodsModelParam model : models) {
                 LWhProcureModel lWhProcureModel = new LWhProcureModel();
@@ -198,7 +106,7 @@
                 }
                 lWhProcureModel.setCounts(model.getCounts());
                 //鏍规嵁鐗╁搧鍨嬪彿鏌ヨ鐗╁搧搴撳瓨
-                int goodsNum = this.lWhGoodsService.queryGoodsModelNum(0, warehouseId, model.getBaseGoodsModelsId(), (short) 1, null);
+                int goodsNum = this.lWhGoodsService.queryGoodsModelNum(0, warehouseId, model.getBaseGoodsModelsId(), 1, null);
                 lWhProcureModel.setWorehouseCount(goodsNum);
                 modelList.add(lWhProcureModel);
             }
@@ -211,7 +119,7 @@
         }
 
         //3.鏍规嵁鍑哄簱鍗曞嚭搴�
-        Long lWarehouseFlowId = this.lWhFormOutputCoreService.outFormByTransId(lWhFormOutputId, currentUser, param.getDealTime());
+        Long lWarehouseFlowId = this.lWhFormOutputCoreService.outFormByTransId(lWhFormOutputId, WhBusinessEnum.CHUKU, currentUser, param.getDealTime());
         if (lWarehouseFlowId == null) {
             log.error("鏍规嵁鍑哄簱鍗曞嚭搴撳け璐�");
             TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
@@ -232,13 +140,13 @@
         //鍑哄簱鍗曞彿
         if (!StringUtils.isEmpty(param.getBusinessFormCode())) {
             sql.append(" and BUSINESS_FORM_CODE = :businessFormCode ");
-            paramts.put("businessFormCode", StringUtils.CHAR_PERCENT + param.getBusinessFormCode() + StringUtils.CHAR_PERCENT);
+            paramts.put("businessFormCode", param.getBusinessFormCode());
         }
         //鐗╁搧鍚嶇О
-        if (!StringUtils.isEmpty(param.getGoodsTemplateName())) {
+        if (!StringUtils.isEmpty(param.getGoodsName())) {
             sql.append(
-                " AND id IN (SELECT BUSINESS_ID FROM L_WH_PROCURE_MODEL procureModel LEFT JOIN BASE_GOODS_MODELS baseModel ON procureModel.BASE_GOODS_MODELS_ID=baseModel.ID LEFT JOIN BASE_GOODS_TEMPLATE baseTemp ON baseModel.GOODS_TEMPLATES_ID=baseTemp.id WHERE procureModel.BUSINESS_TYPE=1 AND baseTemp.GOODS_NAME LIKE :goodsTemplateName)");
-            paramts.put("goodsTemplateName", StringUtils.CHAR_PERCENT + param.getGoodsTemplateName() + StringUtils.CHAR_PERCENT);
+                " AND id IN (SELECT BUSINESS_ID FROM L_WH_PROCURE_MODEL procureModel LEFT JOIN BASE_GOODS_MODELS baseModel ON procureModel.BASE_GOODS_MODELS_ID=baseModel.ID LEFT JOIN BASE_GOODS_TEMPLATE baseTemp ON baseModel.GOODS_TEMPLATES_ID=baseTemp.id WHERE procureModel.BUSINESS_TYPE=3 AND baseTemp.GOODS_NAME LIKE :goodsTemplateName)");
+            paramts.put("goodsTemplateName", StringUtils.CHAR_PERCENT + param.getGoodsName() + StringUtils.CHAR_PERCENT);
         }
         //鏈烘瀯
         if (param.getAgencyId() != null) {
@@ -269,4 +177,52 @@
         GenericPager genericPager = selectSplit(sql.toString(), paramts, new LWhFormOutput());
         return genericPager;
     }
+
+    public GenericPager<Map<String, Object>> queryFormOutputDetailList(LWhFormOutputQry param) {
+        HashMap<String, Object> paramts = new HashMap<>();
+        StringBuilder sql = new StringBuilder("SELECT pm.id,fp.BUSINESS_FORM_CODE,fpg.GOODS_TEMPLATE_NAME,pm.PRICE,pm.COUNTS, "
+            + "( pm.PRICE * pm.COUNTS ) amount,fp.AGENCY_NAME,fp.BUYER_NAME,fp.PROCURE_TIME,pm.BUSINESS_ID,pm.BASE_GOODS_MODELS_NAME FROM l_wh_procure_model pm "
+            + "LEFT JOIN l_wh_form_procure fp ON pm.BUSINESS_ID = fp.id "
+            + "LEFT JOIN l_wh_form_procure_goods fpg ON fp.id = fpg.WH_FORM_PROCURE_ID WHERE pm.BUSINESS_TYPE = 1 ");
+        //鍏ュ簱鍗曞彿
+        if (!StringUtils.isEmpty(param.getBusinessFormCode())) {
+            sql.append("and BUSINESS_FORM_CODE = :businessFormCode ");
+            paramts.put("businessFormCode", param.getBusinessFormCode());
+        }
+        //鐗╁搧鍚嶇О
+        if (!StringUtils.isEmpty(param.getGoodsName())) {
+            sql.append("and fpg.GOODS_TEMPLATE_NAME like :goodsTemplateName ");
+            paramts.put("goodsTemplateName", StringUtils.CHAR_PERCENT + param.getGoodsName() + StringUtils.CHAR_PERCENT);
+        }
+        if (param.getAgencyId() != null) {
+            sql.append("and AGENCY_ID like :agencyId ");
+            paramts.put("agencyId", param.getAgencyId() + StringUtils.CHAR_PERCENT);
+        }
+        //鍒涘缓浜�
+        if (!StringUtils.isEmpty(param.getCreateName())) {
+            sql.append("and buyer_Name =:buyerName ");
+            paramts.put("buyerName", param.getCreateName());
+        }
+        //鍏ュ簱寮�濮嬫椂闂�
+        if (param.getStartTime() != null) {
+            sql.append("and INCOME_TIME >=:incomeTimeStart ");
+            paramts.put("incomeTimeStart", param.getStartTime() * 1000000);
+        }
+        //鍏ュ簱缁撴潫鏃堕棿
+        if (param.getEndTime() != null) {
+            sql.append("and INCOME_TIME <:incomeTimeEnd ");
+            paramts.put("incomeTimeEnd", param.getEndTime() * 1000000 + 240000);
+        }
+        //瑙勬牸鍨嬪彿
+        if (param.getBaseGoodsModelsId() != null) {
+            sql.append("and pm.BASE_GOODS_MODELS_ID =:baseGoodsModelsId ");
+            paramts.put("baseGoodsModelsId", param.getBaseGoodsModelsId());
+        }
+
+        sql.append("ORDER BY PROCURE_TIME DESC");
+        GenericPager genericPager = selectSplit(sql.toString(), paramts, param.getPageNum(), param.getPageSize(), new MapperUtil());
+        return genericPager;
+
+    }
+
 }

--
Gitblit v1.9.1