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