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 | 229 +++++++++++++++++++++++--------------------------------- 1 files changed, 95 insertions(+), 134 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 5c038cb..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,24 +2,31 @@ 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.pojo.*; -import com.consum.base.util.IdUtil; -import com.consum.model.po.*; +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.LWhFormOutputParam; +import com.consum.base.pojo.query.LWhFormOutputQry; +import com.consum.model.po.BaseGoodsModels; +import com.consum.model.po.BaseWarehouse; +import com.consum.model.po.FinSysTenantUser; +import com.consum.model.po.LWhFormOutput; +import com.consum.model.po.LWhProcureModel; import com.iplatform.model.po.S_user_core; import com.walker.db.page.GenericPager; -import com.walker.infrastructure.utils.DateUtils; import com.walker.infrastructure.utils.StringUtils; import com.walker.jdbc.service.BaseServiceImpl; +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; import org.springframework.transaction.interceptor.TransactionAspectSupport; -import org.springframework.util.CollectionUtils; - -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; /** * @Description 鍑哄簱鍗� @@ -46,108 +53,12 @@ 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 @@ -171,17 +82,18 @@ lWhFormOutput.setOperatorName(sysInfo.getUserName()); lWhFormOutput.setDealTime(param.getDealTime()); lWhFormOutput.setStates(1); + lWhFormOutput.setOutputDoc(param.getProcureDoc()); int flag1 = this.insert(lWhFormOutput); if (flag1 == 0) { log.error("鏂板鍑哄簱鍗曡褰�"); return 0; } //2.鏂板鐗╁搧鍨嬪彿璁板綍 - List<LWhFormOutputGoodsParams> goodsList = param.getGoods(); - for (LWhFormOutputGoodsParams goods : goodsList) { - List<LWhProcureModelParams> models = goods.getModels(); - List<LWhProcureModel> modelList = new ArrayList<>(); - for (LWhProcureModelParams model : models) { + List<LWFormsOutputGoodsInfoParam> goodsList = param.getGoods(); + List<LWhProcureModel> modelList = new ArrayList<>(); + for (LWFormsOutputGoodsInfoParam goods : goodsList) { + List<LWFormsOutputGoodsModelParam> models = goods.getModels(); + for (LWFormsOutputGoodsModelParam model : models) { LWhProcureModel lWhProcureModel = new LWhProcureModel(); lWhProcureModel.setId(IdUtil.generateId()); lWhProcureModel.setBusinessType(3); @@ -194,20 +106,20 @@ } 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); } - 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("鏂板鐗╁搧鍨嬪彿澶辫触"); + TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); + return 0; } //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(); @@ -218,32 +130,33 @@ } /** - * @Description 鍒楄〃鏌ヨ + * @Description 鍒楄〃鏌ヨ * @Author 鍗㈠簡闃� * @Date 2023/10/30 */ - public GenericPager queryFormOutputList(LWhFormOutputParam param) { + public GenericPager queryFormOutputList(LWhFormOutputQry param) { HashMap<String, Object> paramts = new HashMap<>(); StringBuilder sql = new StringBuilder(QUERY_FORM_OUTPUT_LIST); //鍑哄簱鍗曞彿 if (!StringUtils.isEmpty(param.getBusinessFormCode())) { - sql.append(" and BUSINESS_FORM_CODE like :businessFormCode "); - paramts.put("businessFormCode", StringUtils.CHAR_PERCENT + param.getBusinessFormCode() + StringUtils.CHAR_PERCENT); + sql.append(" and BUSINESS_FORM_CODE = :businessFormCode "); + paramts.put("businessFormCode", param.getBusinessFormCode()); } //鐗╁搧鍚嶇О - if (!StringUtils.isEmpty(param.getGoodsTemplateName())) { - 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); + 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=3 AND baseTemp.GOODS_NAME LIKE :goodsTemplateName)"); + paramts.put("goodsTemplateName", StringUtils.CHAR_PERCENT + param.getGoodsName() + StringUtils.CHAR_PERCENT); } //鏈烘瀯 - if (param.getAgencyId() != null){ + if (param.getAgencyId() != null) { sql.append(" and AGENCY_ID like :agencyId "); - paramts.put("agencyId", param.getAgencyId() + StringUtils.CHAR_PERCENT); + paramts.put("agencyId", param.getAgencyId() + StringUtils.CHAR_PERCENT); } //鍒涘缓浜� - if (!StringUtils.isEmpty(param.getOperatorName())) { + if (!StringUtils.isEmpty(param.getCreateName())) { sql.append(" and operator_name =:operator_name "); - paramts.put("operator_name", param.getOperatorName()); + paramts.put("operator_name", param.getCreateName()); } //鐘舵�� if (param.getStates() != null) { @@ -251,17 +164,65 @@ paramts.put("states", param.getStates()); } //鍑哄簱鏃堕棿 - if (param.getOutputTimeStart() != null) { + if (param.getStartTime() != null) { sql.append(" and DEAL_TIME >=:outputTimeStart "); - paramts.put("outputTimeStart", param.getOutputTimeStart() * 1000000); + paramts.put("outputTimeStart", param.getStartTime() * 1000000); } - if (param.getOutputTimeEnd() != null) { + if (param.getEndTime() != null) { sql.append(" and DEAL_TIME <:outputTimeEnd "); - paramts.put("outputTimeEnd", param.getOutputTimeEnd() * 1000000 + 240000); + paramts.put("outputTimeEnd", param.getEndTime() * 1000000 + 240000); } sql.append(" ORDER BY DEAL_TIME DESC"); 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