From e23c8975e6bb0934cb5db46a94d0f83c9739d9ab Mon Sep 17 00:00:00 2001 From: 935090232@qq.com <ak473600000> Date: Sun, 20 Mar 2022 16:33:17 +0800 Subject: [PATCH] 重构:套餐项目 --- zq-erp/src/main/java/com/matrix/system/hive/service/imp/SysProjUseServiceImpl.java | 160 ++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 139 insertions(+), 21 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 a464c3d..e9416e8 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 @@ -7,16 +7,19 @@ import com.matrix.core.pojo.PaginationVO; import com.matrix.core.tools.DateUtil; import com.matrix.core.tools.WebUtil; +import com.matrix.system.app.mapper.SysProjUseMapper; 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.common.dao.SysUsersDao; +import com.matrix.system.common.validate.GroupValidateStatusCheckUtil; 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.hievEnum.OrderOperationEnum; import com.matrix.system.hive.plugin.util.MoneyUtil; import com.matrix.system.hive.service.ShoppingGoodsService; +import com.matrix.system.hive.service.SysBeauticianStateService; import com.matrix.system.hive.service.SysProjServicesService; import com.matrix.system.hive.service.SysProjUseService; import com.matrix.system.hive.validation.ProjUseGroup; @@ -24,10 +27,7 @@ import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; -import java.util.ArrayList; -import java.util.Date; -import java.util.List; -import java.util.Map; +import java.util.*; import java.util.function.Function; import java.util.stream.Collectors; @@ -41,6 +41,9 @@ private SysProjUseDao sysProjUseDao; @Autowired SysProjServicesService projServicesService; + + @Autowired + SysBeauticianStateService sysBeauticianStateService; @Autowired private SysProjuseFreezeDao sysProjuseFreezeDao; @@ -66,6 +69,9 @@ @Autowired BusParameterSettingsDao busParameterSettingsDao; + + @Autowired + SysUsersDao sysUsersDao; @Override public int add(SysProjUse sysProjUse) { @@ -355,11 +361,9 @@ if (Dictionary.TAOCAN_SOURCE_QY.equals(projuse.getSource())) { return; } - if (projuse.getPlatformFlag().contains(Dictionary.SHOPPING_GOODS_SALE_PLATFORM_XX)) { - SysOrderItem orderItem = orderItemDao.selectById(projuse.getOrderItemId()); - if (!Dictionary.ORDER_STATU_YFK.equals(orderItem.getStatus())) { - throw new GlobleException("该商品存在欠款!"); - } + String orderStatus = orderItemDao.selectOrderStatusByItemId(projuse.getOrderItemId()); + if (!Dictionary.ORDER_STATU_YFK.equals(orderStatus)) { + throw new GlobleException(projuse.getProjName()+"的购买订单存在欠款!"); } } @@ -603,6 +607,108 @@ /** + * 项目套餐退款 + * @param projUseDtoList + */ + @Override + public void projectTk(List<ProjUseOperationDto> 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())); + + + projUseDtoList.forEach(projUseOperationDto -> { + //校验参数 + GroupValidateStatusCheckUtil.check(projUseOperationDto, ProjUseGroup.projectTk.class); + + ShoppingGoods shoppingGoods = shoppingGoodsMap.get(projUseOperationDto.getGoodsId()); + if (Dictionary.SHOPPING_GOODS_TYPE_XM.equals(shoppingGoods.getGoodType())) { + + doProjectTk(projUseOperationDto); + + } else if (Dictionary.SHOPPING_GOODS_TYPE_TC.equals(shoppingGoods.getGoodType())) { + + taocanTk(projUseOperationDto); + } + + + + }); + } + + /** + * 套餐退款 + * @param projUseOperationDto + */ + private void taocanTk(ProjUseOperationDto projUseOperationDto) { + + List<SysProjUse> projUseList = sysProjUseDao.selectByOrderItemId(projUseOperationDto.getOrderItemId()); + + List<SysProjUse> tcList = projUseList.stream().filter(item -> Objects.isNull(item.getTaocanId()) && item.getStatus().equals(Dictionary.TAOCAN_STATUS_YX) ).collect(Collectors.toList()); + + if (tcList.size() < projUseOperationDto.getCount()) { + throw new GlobleException("套餐余次不足"); + } + projUseOperationDto.setOrderOperationType(OrderOperationEnum.RETURN); + for (int i = 0; i < projUseOperationDto.getCount(); i++) { + SysProjUse sysProjUse = tcList.get(i); + setTaocanTk(sysProjUse,projUseOperationDto); + //设置套餐下的项目无效 + projUseList.stream().filter(item->Objects.equals(sysProjUse.getId(),item.getTaocanId())).collect(Collectors.toList()) + .forEach(item-> setTaocanTk(item,projUseOperationDto)); + } + + } + + private void setTaocanTk(SysProjUse sysProjUse, ProjUseOperationDto projUseOperationDto) { + sysProjUse.setIsOver(Dictionary.FLAG_YES_Y); + sysProjUse.setStatus(Dictionary.TAOCAN_STATUS_TK); + sysProjUse.setSurplusCount(0); + sysProjUseDao.update(sysProjUse); + saveProjUseFlow(projUseOperationDto,sysProjUse); + } + + /** + * 项目退款 + * @param projUseOperationDto + */ + private void doProjectTk(ProjUseOperationDto projUseOperationDto) { + + List<SysProjUse> projUseList = sysProjUseDao.selectByOrderItemId(projUseOperationDto.getOrderItemId()); + if(projUseList.size()==1){ + SysProjUse sysProjUse = projUseList.get(0); + int sub = sysProjUse.getSurplusCount() - projUseOperationDto.getCount(); + if (sub < 0) { + throw new GlobleException("项目余次不足"); + } else if (sub == 0) { + sysProjUse.setIsOver(Dictionary.FLAG_YES_Y); + sysProjUse.setStatus(Dictionary.TAOCAN_STATUS_TK); + } + sysProjUse.setSurplusCount(sub); + sysProjUseDao.update(sysProjUse); + projUseOperationDto.setOrderOperationType(OrderOperationEnum.RETURN); + //保存操作流水 + saveProjUseFlow(projUseOperationDto,sysProjUse); + }else{ + throw new GlobleException("查询项目余次异常"); + } + } + + /** + * 保存项目操作流水 + * @param projUseOperationDto + * @param sysProjUse + */ + private void saveProjUseFlow(ProjUseOperationDto projUseOperationDto, SysProjUse sysProjUse) { + SysProjUseFlow sysProjUseFlow = SysProjUseMapper.INSTANCE.projUseToFlow(sysProjUse); + sysProjUseFlow.setOptionType(projUseOperationDto.getOrderOperationType().getDisplayName()); + SysUsers user = sysUsersDao.selectById(projUseOperationDto.getUpdateUserId()); + sysProjUseFlow.setUpdateBy(user.getSuName()); + sysProjUseFlow.setCreateBy(user.getSuName()); + sysProjUseDao.insertFlow(sysProjUseFlow); + } + + /** * 添加用户套餐 * * @param projUseDtoList @@ -619,6 +725,7 @@ 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); @@ -635,19 +742,15 @@ private void createTaocanProjUse(ProjUseOperationDto projUseOperationDto, ShoppingGoods shoppingGoods) { - ParameterValidate.ValidResult baseIdResult = ParameterValidate.validateBean(projUseOperationDto, ProjUseGroup.addTc.class); - if (baseIdResult.hasErrors()) { - throw new GlobleException(baseIdResult.getErrors()); - } + + GroupValidateStatusCheckUtil.check(projUseOperationDto,ProjUseGroup.addTc.class); //新建套餐 SysProjUse taocanProjUse = new SysProjUse(); ShoppingGoods taocanShoppingGoods = shoppingGoods; - Long projId = shoppingGoods.getId(); - taocanProjUse.setProjId(projId); taocanProjUse.setIsOver(Dictionary.DELETED_N); @@ -684,6 +787,7 @@ projUseDto.setOrderItemId(projUseOperationDto.getOrderItemId()); projUseDto.setVipId(projUseOperationDto.getVipId()); projUseDto.setTcId(taocanProjUse.getId()); + projUseDto.setUpdateUserId(projUseOperationDto.getUpdateUserId()); SysProjUse tempUse = createProjectUse(projUseDto, assemble.getShoppingGoods()); sumBanance += tempUse.getBalance(); surplusCount += tempUse.getSurplusCount(); @@ -704,10 +808,7 @@ private SysProjUse createProjectUse(ProjUseOperationDto projUseOperationDto, ShoppingGoods shoppingGoods) { - ParameterValidate.ValidResult baseIdResult = ParameterValidate.validateBean(projUseOperationDto, ProjUseGroup.addProject.class); - if (baseIdResult.hasErrors()) { - throw new GlobleException(baseIdResult.getErrors()); - } + GroupValidateStatusCheckUtil.check(projUseOperationDto,ProjUseGroup.addProject.class); SysProjUse puse = new SysProjUse(); puse.setIsOver(Dictionary.DELETED_N); @@ -770,4 +871,21 @@ public int findTaocanCountForCourseAndInfinite(Long taocanId, Long vipId) { return sysProjUseDao.selectTaocanCountForCourseAndInfinite(taocanId, vipId); } + + @Override + public void deleteByOrderItemId(Long id) { + int count=sysProjUseDao.selectUseCountByOrderItemId(id); + if(count>0){ + SysProjUse query=new SysProjUse(); + query.setOrderItemId(id); + List<SysProjUse> sysProjUses = sysProjUseDao.selectByModel(query); + if(sysProjUses.size()>1){ + throw new GlobleException(sysProjUses.get(0).getProjName()+"套餐已经被使用无法删除"); + }else { + throw new GlobleException(sysProjUses.get(0).getProjName()+"项目已经被使用无法删除"); + } + }else { + sysProjUseDao.deleteByOrderItemId(id); + } + } } \ No newline at end of file -- Gitblit v1.9.1