From 76ed413ae6fd573996207760904304b4951df5d5 Mon Sep 17 00:00:00 2001 From: 935090232@qq.com <ak473600000> Date: Sun, 13 Mar 2022 18:43:34 +0800 Subject: [PATCH] 重构:套餐项目 --- zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java | 185 ++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 171 insertions(+), 14 deletions(-) diff --git a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java index b30f76c..a464c3d 100644 --- a/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java +++ b/zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java @@ -1,5 +1,6 @@ package com.matrix.system.hive.service.imp; +import cn.hutool.core.collection.CollUtil; import com.matrix.core.constance.MatrixConstance; import com.matrix.core.exception.GlobleException; import com.matrix.core.pojo.AjaxResult; @@ -7,11 +8,18 @@ import com.matrix.core.tools.DateUtil; import com.matrix.core.tools.WebUtil; import com.matrix.system.common.bean.SysUsers; +import com.matrix.system.common.dao.BusParameterSettingsDao; +import com.matrix.system.common.validate.ParameterValidate; +import com.matrix.system.common.validate.group.Group; import com.matrix.system.constance.Dictionary; import com.matrix.system.hive.bean.*; import com.matrix.system.hive.dao.*; +import com.matrix.system.hive.dto.ProjUseOperationDto; import com.matrix.system.hive.plugin.util.MoneyUtil; +import com.matrix.system.hive.service.ShoppingGoodsService; +import com.matrix.system.hive.service.SysProjServicesService; import com.matrix.system.hive.service.SysProjUseService; +import com.matrix.system.hive.validation.ProjUseGroup; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -19,6 +27,9 @@ import java.util.ArrayList; import java.util.Date; import java.util.List; +import java.util.Map; +import java.util.function.Function; +import java.util.stream.Collectors; /** * @date 2016-07-03 20:53 @@ -28,7 +39,8 @@ @Autowired private SysProjUseDao sysProjUseDao; - + @Autowired + SysProjServicesService projServicesService; @Autowired private SysProjuseFreezeDao sysProjuseFreezeDao; @@ -49,6 +61,11 @@ @Autowired SysVipInfoDao sysVipInfoDao; + @Autowired + ShoppingGoodsService shoppingGoodsService; + + @Autowired + BusParameterSettingsDao busParameterSettingsDao; @Override public int add(SysProjUse sysProjUse) { @@ -60,7 +77,6 @@ @Override public int modify(SysProjUse sysProjUse) { //插入套餐项目操作记录 - return sysProjUseDao.update(sysProjUse); @@ -221,7 +237,7 @@ freeze.setVipId(taocan.getVipId()); SysProjuseFreeze freezeProj = sysProjuseFreezeDao.selectByOrderItemId(freeze); // todo 因为目前没有在冻结的时候插入冻结记录,所以这里暂时这样处理 - if(freezeProj!=null){ + if (freezeProj != null) { Date dateAfter = DateUtil.nextNDate(taocan.getFailTime(), freezeProj.getGapDays()); taocan.setFailTime(dateAfter); } @@ -232,7 +248,7 @@ taocan.setStatus(Dictionary.TAOCAN_STATUS_YX); sysProjUseDao.updateProjStatus(taocan); SysUsers sysUsers = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); - SysProjUseFlow useFlow=new SysProjUseFlow(); + SysProjUseFlow useFlow = new SysProjUseFlow(); useFlow.setProjName(taocan.getProjName()); useFlow.setProjUseId(taocan.getId()); useFlow.setOptionType("人工修改"); @@ -273,7 +289,7 @@ } SysUsers sysUsers = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); - SysProjUseFlow useFlow=new SysProjUseFlow(); + SysProjUseFlow useFlow = new SysProjUseFlow(); useFlow.setProjName(taocan.getProjName()); useFlow.setProjUseId(taocan.getId()); useFlow.setOptionType("人工修改"); @@ -364,7 +380,7 @@ int i = sysProjUseDao.updateTcStatus(sysProjUse.getId(), "无效"); SysUsers sysUsers = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); - SysProjUseFlow useFlow=new SysProjUseFlow(); + SysProjUseFlow useFlow = new SysProjUseFlow(); useFlow.setProjName(taocan.getProjName()); useFlow.setProjUseId(taocan.getId()); useFlow.setOptionType("人工修改"); @@ -378,8 +394,6 @@ return i; } - - /*********************以下为项目使用情况操作***********************/ @@ -468,7 +482,7 @@ SysProjuseFreeze freeze = new SysProjuseFreeze(); freeze.setFreezeTime(new Date()); freeze.setVipId(sysProjUse.getVipId()); - freeze.setOrderItemId(sysProjUse.getId()+""); + freeze.setOrderItemId(sysProjUse.getId() + ""); SysProjuseFreeze getfreeze = sysProjuseFreezeDao.selectByOrderItemId(freeze); int i = 0; if (getfreeze != null) { @@ -478,7 +492,7 @@ i = sysProjuseFreezeDao.insert(freeze); } SysUsers sysUsers = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); - SysProjUseFlow useFlow=new SysProjUseFlow(); + SysProjUseFlow useFlow = new SysProjUseFlow(); useFlow.setProjName(sysProjUse.getProjName()); useFlow.setProjUseId(sysProjUse.getId()); useFlow.setOptionType("人工修改"); @@ -515,7 +529,7 @@ sysProjUse.setStatus(Dictionary.TAOCAN_STATUS_WX); SysUsers sysUsers = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); - SysProjUseFlow useFlow=new SysProjUseFlow(); + SysProjUseFlow useFlow = new SysProjUseFlow(); useFlow.setProjName(sysProjUse.getProjName()); useFlow.setProjUseId(sysProjUse.getId()); useFlow.setOptionType("人工修改"); @@ -528,8 +542,6 @@ sysProjUseDao.insertFlow(useFlow); return sysProjUseDao.update(sysProjUse); } - - /** @@ -574,7 +586,7 @@ sysProjUseDao.update(proj); SysUsers sysUsers = WebUtil.getSessionAttribute(MatrixConstance.LOGIN_KEY); - SysProjUseFlow useFlow=new SysProjUseFlow(); + SysProjUseFlow useFlow = new SysProjUseFlow(); useFlow.setProjName(proj.getProjName()); useFlow.setProjUseId(proj.getId()); useFlow.setOptionType("人工修改"); @@ -590,6 +602,151 @@ } + /** + * 添加用户套餐 + * + * @param projUseDtoList + * @return + */ + @Override + public void addUserProjUse(List<ProjUseOperationDto> projUseDtoList) { + + if(CollUtil.isEmpty(projUseDtoList)){ + throw new GlobleException("projUseDtoList 不能为空"); + } + + List<ShoppingGoods> shoppingGoodsList = shoppingGoodsDao.selectByIds(projUseDtoList.stream().map(ProjUseOperationDto::getGoodsId).collect(Collectors.toList())); + Map<Long, ShoppingGoods> shoppingGoodsMap = shoppingGoodsList.stream().collect(Collectors.toMap(ShoppingGoods::getId, Function.identity())); + + for (ProjUseOperationDto projUseOperationDto : projUseDtoList) { + ShoppingGoods shoppingGoods = shoppingGoodsMap.get(projUseOperationDto.getGoodsId()); + if (Dictionary.SHOPPING_GOODS_TYPE_XM.equals(shoppingGoods.getGoodType())) { + createProjectUse(projUseOperationDto, shoppingGoods); + } else if (Dictionary.SHOPPING_GOODS_TYPE_TC.equals(shoppingGoods.getGoodType())) { + //每个套餐独立生成一个明细 + int orderCount = projUseOperationDto.getCount(); + while (orderCount > 0) { + createTaocanProjUse(projUseOperationDto, shoppingGoods); + orderCount--; + } + } + } + } + + + private void createTaocanProjUse(ProjUseOperationDto projUseOperationDto, ShoppingGoods shoppingGoods) { + ParameterValidate.ValidResult baseIdResult = ParameterValidate.validateBean(projUseOperationDto, ProjUseGroup.addTc.class); + if (baseIdResult.hasErrors()) { + throw new GlobleException(baseIdResult.getErrors()); + } + + //新建套餐 + SysProjUse taocanProjUse = new SysProjUse(); + + ShoppingGoods taocanShoppingGoods = shoppingGoods; + + + Long projId = shoppingGoods.getId(); + + + taocanProjUse.setProjId(projId); + taocanProjUse.setIsOver(Dictionary.DELETED_N); + taocanProjUse.setOrderItemId(projUseOperationDto.getOrderItemId()); + + taocanProjUse.setProjName(taocanShoppingGoods.getName()); + taocanProjUse.setVipId(projUseOperationDto.getVipId()); + taocanProjUse.setStatus(Dictionary.TAOCAN_STATUS_YX); + taocanProjUse.setType(Dictionary.SHOPPING_GOODS_TYPE_TC); + taocanProjUse.setIsCourse(taocanShoppingGoods.getIsCourse()); + taocanProjUse.setIsInfinite(taocanShoppingGoods.getIsInfinite()); + // 赠送和打折后金额为0的都视为赠送项目 + if (projUseOperationDto.isFree()) { + taocanProjUse.setSource(Dictionary.TAOCAN_SOURCE_ZS); + } else { + taocanProjUse.setSource(Dictionary.TAOCAN_SOURCE_GM); + } + // 失效时间 + Date invalidTime = shoppingGoodsService.calInvalidTime(taocanShoppingGoods, 1, null); + taocanProjUse.setFailTime(invalidTime); + sysProjUseDao.insert(taocanProjUse); + //计划次数 + int surplusCount = 0; + //总余额 + Double sumBanance = 0D; + //创建套餐绑定的项目 + List<ShoppingGoodsAssemble> assembleList = shoppingGoodsAssembleDao.selectGoodsByShoppingGoodsIdAndType(projId, ShoppingGoods.SHOPPING_GOODS_TYPE_XM); + for (ShoppingGoodsAssemble assemble : assembleList) { + ProjUseOperationDto projUseDto = new ProjUseOperationDto(); + projUseDto.setCount(assemble.getTotal()); + projUseDto.setGoodsId(assemble.getShoppingGoodsId()); + projUseDto.setFree(projUseOperationDto.isFree()); + projUseDto.setPayMoney(MoneyUtil.mul(assemble.getPrice(), projUseOperationDto.getTcZk())); + projUseDto.setOrderItemId(projUseOperationDto.getOrderItemId()); + projUseDto.setVipId(projUseOperationDto.getVipId()); + projUseDto.setTcId(taocanProjUse.getId()); + SysProjUse tempUse = createProjectUse(projUseDto, assemble.getShoppingGoods()); + sumBanance += tempUse.getBalance(); + surplusCount += tempUse.getSurplusCount(); + } + if (Dictionary.FLAG_NO_N.equals(taocanShoppingGoods.getIsCourse())) { + //固定套餐,剩余次数等于绑定项目的次数 + taocanProjUse.setSurplusCount(surplusCount); + //合计套餐余额 + taocanProjUse.setBalance(sumBanance); + } else { + //任选套餐剩余次数等于最大使用次数 + taocanProjUse.setSurplusCount(taocanShoppingGoods.getCarUseCount()); + taocanProjUse.setBalance(projUseOperationDto.getPayMoney()); + } + + sysProjUseDao.update(taocanProjUse); + } + + private SysProjUse createProjectUse(ProjUseOperationDto projUseOperationDto, ShoppingGoods shoppingGoods) { + + ParameterValidate.ValidResult baseIdResult = ParameterValidate.validateBean(projUseOperationDto, ProjUseGroup.addProject.class); + if (baseIdResult.hasErrors()) { + throw new GlobleException(baseIdResult.getErrors()); + } + + SysProjUse puse = new SysProjUse(); + puse.setIsOver(Dictionary.DELETED_N); + puse.setOrderItemId(projUseOperationDto.getOrderItemId()); + puse.setProjId(projUseOperationDto.getGoodsId()); + puse.setSurplusCount(projUseOperationDto.getCount()); + puse.setVipId(projUseOperationDto.getVipId()); + puse.setStatus(Dictionary.TAOCAN_STATUS_YX); + puse.setType(Dictionary.SHOPPING_GOODS_TYPE_XM); + puse.setProjName(shoppingGoods.getName()); + puse.setTaocanId(projUseOperationDto.getTcId()); + // 赠送和打折后金额为0的都视为赠送项目 + if (!projUseOperationDto.isFree()) { + puse.setSource(Dictionary.TAOCAN_SOURCE_GM); + puse.setPrice(projUseOperationDto.getPayMoney()); + } else { + puse.setSource(Dictionary.TAOCAN_SOURCE_ZS); + //赠送项目是否计算消耗业绩否则 赠送产品按原价计算消耗 + boolean zsConsumeAchieve = projServicesService.skipServiceOrderStep(Dictionary.ZS_CONSUME_ACHIEVE); + if (zsConsumeAchieve) { + //赠送情况下,如果收款金额大于0,就是赠送金额划扣的情况,金额即为划扣的折扣金额 + if (projUseOperationDto.getPayMoney() > 0) { + puse.setPrice(projUseOperationDto.getPayMoney()); + } else { + puse.setPrice(shoppingGoods.getSealPice()); + } + } else { + puse.setPrice(0D); + } + } + + // 设置失效时间 + Date invalidTime = shoppingGoodsService.calInvalidTime(shoppingGoods, 1, null); + puse.setFailTime(invalidTime); + puse.setBalance(puse.getPrice() * puse.getSurplusCount()); + sysProjUseDao.insert(puse); + return puse; + } + @Override public int updateProjUseTck(SysProjUse projUse) { -- Gitblit v1.9.1