From 508f3e225df87e0da974424981e7782fc5ce875c Mon Sep 17 00:00:00 2001 From: xuhy <3313886187@qq.com> Date: 星期一, 19 五月 2025 14:21:39 +0800 Subject: [PATCH] 修改 --- ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TFoundationPersonServiceImpl.java | 137 ++++++++++++++++++++++++++++++++------------- 1 files changed, 96 insertions(+), 41 deletions(-) diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TFoundationPersonServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TFoundationPersonServiceImpl.java index c5fbbd1..02355a7 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TFoundationPersonServiceImpl.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TFoundationPersonServiceImpl.java @@ -6,6 +6,7 @@ import com.ruoyi.common.exception.ServiceException; import com.ruoyi.system.domain.TFoundationConfig; import com.ruoyi.system.domain.TFoundationPerson; +import com.ruoyi.system.dto.TFoundationPersonBatchDTO; import com.ruoyi.system.dto.TFoundationPersonDTO; import com.ruoyi.system.mapper.TFoundationPersonMapper; import com.ruoyi.system.query.TFoundationPersonQuery; @@ -15,9 +16,12 @@ import com.ruoyi.system.vo.TFoundationPersonVO; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; +import java.util.ArrayList; import java.util.Comparator; +import java.util.HashSet; import java.util.List; import java.util.stream.Collectors; @@ -36,54 +40,56 @@ private TFoundationConfigService foundationConfigService; @Override - public void add(TFoundationPersonDTO dto) { - - long count1 = this.count(Wrappers.lambdaQuery(TFoundationPerson.class) - .eq(TFoundationPerson::getShopId, dto.getShopId()) - .eq(TFoundationPerson::getMealCount, dto.getMealCount())); - if(count1>0){ - throw new ServiceException("该店铺已存在该用餐人数设置"); + @Transactional(rollbackFor = Exception.class) + public void add(TFoundationPersonBatchDTO dto) { + List<TFoundationPersonDTO> foundationPersonDTOS = dto.getFoundationPersonDTOS(); + boolean b = hasDuplicateId(foundationPersonDTOS); + if(b){ + throw new ServiceException("设置存在重复用餐人数"); } - - List<TFoundationConfig> foundationConfigs = dto.getFoundationConfigs(); - long count = foundationConfigs.stream().map(TFoundationConfig::getTypeId).distinct().count(); - if(foundationConfigs.size()!=count){ - throw new ServiceException("菜品重复设置"); + for (TFoundationPersonDTO tFoundationPersonDTO : foundationPersonDTOS) { + List<TFoundationConfig> foundationConfigs = tFoundationPersonDTO.getFoundationConfigs(); + long count = foundationConfigs.stream().map(TFoundationConfig::getTypeId).distinct().count(); + if(foundationConfigs.size()!=count){ + throw new ServiceException("菜品重复设置"); + } + this.save(tFoundationPersonDTO); + // 添加菜品 + foundationConfigs.forEach(item -> { + item.setPersonId(tFoundationPersonDTO.getId()); + }); + foundationConfigService.saveBatch(foundationConfigs); } - // 添加人数 - this.save(dto); - // 添加菜品 - foundationConfigs.forEach(item -> { - item.setPersonId(dto.getId()); - }); - foundationConfigService.saveBatch(foundationConfigs); } @Override - public void edit(TFoundationPersonDTO dto) { - long count1 = this.count(Wrappers.lambdaQuery(TFoundationPerson.class) - .eq(TFoundationPerson::getShopId, dto.getShopId()) - .eq(TFoundationPerson::getMealCount, dto.getMealCount()) - .ne(TFoundationPerson::getId,dto.getId())); - if(count1>0){ - throw new ServiceException("该店铺已存在该用餐人数设置"); + @Transactional(rollbackFor = Exception.class) + public void edit(TFoundationPersonBatchDTO dto) { + List<TFoundationPersonDTO> foundationPersonDTOS = dto.getFoundationPersonDTOS(); + boolean b = hasDuplicateId(foundationPersonDTOS); + if(b){ + throw new ServiceException("设置存在重复用餐人数"); + } + this.remove(Wrappers.lambdaQuery(TFoundationPerson.class) + .eq(TFoundationPerson::getMealType,dto.getMealType())); + for (TFoundationPersonDTO tFoundationPersonDTO : foundationPersonDTOS) { + List<TFoundationConfig> foundationConfigs = tFoundationPersonDTO.getFoundationConfigs(); + long count = foundationConfigs.stream().map(TFoundationConfig::getTypeId).distinct().count(); + if(foundationConfigs.size()!=count){ + throw new ServiceException("菜品重复设置"); + } + // 添加人数 + this.saveOrUpdate(tFoundationPersonDTO); + // 删除菜品 + foundationConfigService.remove(Wrappers.lambdaQuery(TFoundationConfig.class) + .eq(TFoundationConfig::getPersonId,tFoundationPersonDTO.getId())); + // 添加菜品 + foundationConfigs.forEach(item -> { + item.setPersonId(tFoundationPersonDTO.getId()); + }); + foundationConfigService.saveBatch(foundationConfigs); } - List<TFoundationConfig> foundationConfigs = dto.getFoundationConfigs(); - long count = foundationConfigs.stream().map(TFoundationConfig::getTypeId).distinct().count(); - if(foundationConfigs.size()!=count){ - throw new ServiceException("菜品重复设置"); - } - // 添加人数 - this.updateById(dto); - // 删除菜品 - foundationConfigService.remove(Wrappers.lambdaQuery(TFoundationConfig.class) - .eq(TFoundationConfig::getPersonId,dto.getId())); - // 添加菜品 - foundationConfigs.forEach(item -> { - item.setPersonId(dto.getId()); - }); - foundationConfigService.saveBatch(foundationConfigs); } @Override @@ -106,4 +112,53 @@ pageInfo.setRecords(list); return pageInfo; } + + @Override + public boolean hasDuplicateId(List<TFoundationPersonDTO> list) { + HashSet<Integer> countSet = new HashSet<>(); + for (TFoundationPersonDTO dto : list) { + if (!countSet.add(dto.getMealCount())) { + return true; // 发现重复的人数 + } + } + return false; // 没有发现重复的人数 + } + + @Override + public List<TFoundationPersonVO> getSetList() { + List<TFoundationPersonVO> list = new ArrayList<>(); + List<TFoundationPersonVO> setList = this.baseMapper.getSetList(); + for (int i = 1; i <= 2; i++) { + TFoundationPersonVO foundationPersonVO = new TFoundationPersonVO(); + foundationPersonVO.setMealType(i); + int finalI = i; + List<TFoundationPersonVO> collect = setList.stream().filter(e -> e.getMealType() == finalI).collect(Collectors.toList()); + if(!CollectionUtils.isEmpty(collect)){ + Integer minPerson = collect.stream().sorted(Comparator.comparingInt(TFoundationPerson::getMealCount)).findFirst().get().getMealCount(); + foundationPersonVO.setMinPerson(minPerson); + Integer maxPerson = collect.stream().sorted(Comparator.comparingInt(TFoundationPerson::getMealCount).reversed()).findFirst().get().getMealCount(); + foundationPersonVO.setMaxPerson(maxPerson); + } + List<Long> ids = collect.stream().map(TFoundationPersonVO::getId).collect(Collectors.toList()); + if(!CollectionUtils.isEmpty(ids)){ + List<TFoundationConfig> list1 = foundationConfigService.list(Wrappers.lambdaQuery(TFoundationConfig.class) + .in(TFoundationConfig::getPersonId, ids)); + list.forEach(item -> { + List<TFoundationConfig> collect1 = list1.stream().filter(item1 -> item1.getPersonId().equals(item.getId())).collect(Collectors.toList()); + if(!CollectionUtils.isEmpty(collect1)){ + item.setMinDish(collect1.stream().sorted(Comparator.comparingInt(TFoundationConfig::getMinCount)).findFirst().get().getMinCount()); + item.setMaxDish(collect1.stream().sorted(Comparator.comparingInt(TFoundationConfig::getMaxCount).reversed()).findFirst().get().getMaxCount()); + item.setFoundationConfigs(collect1); + } + }); + } + list.add(foundationPersonVO); + } + return list; + } + + @Override + public List<TFoundationPersonVO> getPersonList() { + return this.baseMapper.getSetList(); + } } -- Gitblit v1.7.1