From e69dec94fe9763d04425756370760698850f926f Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期五, 22 三月 2024 19:38:39 +0800
Subject: [PATCH] 部门端基础数据保存、基础数据导入模板下载、基础数据导入接口

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbFieldCategoryServiceImpl.java |   43 +++++++++++++++++++++++++++++++++++--------
 1 files changed, 35 insertions(+), 8 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbFieldCategoryServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbFieldCategoryServiceImpl.java
index 022e3b5..f4a26a8 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbFieldCategoryServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbFieldCategoryServiceImpl.java
@@ -6,6 +6,7 @@
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.common.basic.PageDTO;
 import com.ruoyi.common.enums.ShowStatusEnum;
+import com.ruoyi.common.exception.ServiceException;
 import com.ruoyi.common.utils.BeanUtils;
 import com.ruoyi.common.utils.CollUtils;
 import com.ruoyi.common.utils.StringUtils;
@@ -16,6 +17,7 @@
 import com.ruoyi.system.mapper.TbFieldCategoryMapper;
 import com.ruoyi.system.query.FieldCategoryQuery;
 import com.ruoyi.system.service.TbFieldCategoryService;
+import com.ruoyi.system.vo.FieldCategoryDetailVO;
 import com.ruoyi.system.vo.FieldCategoryVO;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -85,10 +87,7 @@
     }
 
     private void updateCategoryAndChildren(Integer id, ShowStatusEnum status) {
-        TbFieldCategory category = this.getById(id);
-        if (Objects.isNull(category)) {
-            throw new RuntimeException("非法id");
-        }
+        TbFieldCategory category = this.validateParam(id);
         this.lambdaUpdate()
                 .eq(TbFieldCategory::getId, id)
                 .set(TbFieldCategory::getStatus, status)
@@ -122,10 +121,7 @@
     @Transactional(rollbackFor = Exception.class)
     public void delete(Integer id) {
         //一级分类
-        TbFieldCategory category = this.getById(id);
-        if (Objects.isNull(category)) {
-            throw new RuntimeException("非法参数");
-        }
+        validateParam(id);
         //查询是否有二级分类
         List<TbFieldCategory> threeCategoryList = this.lambdaQuery().eq(TbFieldCategory::getParentId, id).list();
         if (CollectionUtils.isNotEmpty(threeCategoryList)) {
@@ -144,8 +140,17 @@
         this.removeById(id);
     }
 
+    private TbFieldCategory validateParam(Integer id) {
+        TbFieldCategory category = this.getById(id);
+        if (Objects.isNull(category)) {
+            throw new ServiceException("非法参数");
+        }
+        return category;
+    }
+
     @Override
     public void edit(FieldCategoryUpdateDTO dto) {
+        validateParam(dto.getId());
         //更新一级分类
         updateCategory(dto);
         List<FieldCategoryUpdateDTO> children = dto.getChildren();
@@ -180,4 +185,26 @@
                 .list();
         return BeanUtils.copyList(list, FieldCategoryVO.class);
     }
+
+    @Override
+    public FieldCategoryDetailVO getDetailsById(Integer id) {
+        TbFieldCategory oneCategory = this.getById(id);
+        if (Objects.isNull(oneCategory)) {
+            return new FieldCategoryDetailVO();
+        }
+        FieldCategoryDetailVO vo = BeanUtils.copyBean(oneCategory, FieldCategoryDetailVO.class);
+        //根据一级分类id,查询二级分类
+        List<TbFieldCategory> twoCategoryList = this.lambdaQuery().eq(TbFieldCategory::getParentId, oneCategory.getId()).list();
+        twoCategoryList.forEach(item->{
+            FieldCategoryDetailVO twoCategoryVO = BeanUtils.copyBean(item, FieldCategoryDetailVO.class);
+            vo.getChildren().add(twoCategoryVO);
+            //根据二级分类id,查询三级分类
+            List<TbFieldCategory> threeCategoryList = this.lambdaQuery().eq(TbFieldCategory::getParentId, item.getId()).list();
+            threeCategoryList.forEach(threeCategory->{
+                FieldCategoryDetailVO threeCategoryVO = BeanUtils.copyBean(threeCategory, FieldCategoryDetailVO.class);
+                twoCategoryVO.getChildren().add(threeCategoryVO);
+            });
+        });
+        return vo;
+    }
 }

--
Gitblit v1.7.1