From ba421d977e745d18a6264353c739bcaaf44c40d6 Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期一, 08 四月 2024 18:39:41 +0800
Subject: [PATCH] 历史数据模块接口

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbBasicDataConfigServiceImpl.java |   59 ++++++++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 40 insertions(+), 19 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbBasicDataConfigServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbBasicDataConfigServiceImpl.java
index 6049eeb..c47c155 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbBasicDataConfigServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbBasicDataConfigServiceImpl.java
@@ -6,7 +6,9 @@
 import com.ruoyi.common.basic.PageDTO;
 import com.ruoyi.common.enums.CalculateTypeEnum;
 import com.ruoyi.common.enums.ShowStatusEnum;
+import com.ruoyi.common.exception.ServiceException;
 import com.ruoyi.common.utils.BeanUtils;
+import com.ruoyi.common.utils.Checker;
 import com.ruoyi.common.utils.CollUtils;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.system.domain.TbBasicDataConfig;
@@ -19,11 +21,13 @@
 import com.ruoyi.system.mapper.TbBasicDataConfigMapper;
 import com.ruoyi.system.mapper.TbFieldMapper;
 import com.ruoyi.system.query.BasicDataConfigQuery;
+import com.ruoyi.system.query.ScoreCalculateQuery;
 import com.ruoyi.system.service.TbBasicDataConfigDetailService;
 import com.ruoyi.system.service.TbBasicDataConfigService;
 import com.ruoyi.system.vo.BasicDataConfigDetailVO;
 import com.ruoyi.system.vo.BasicDataConfigVO;
 import com.ruoyi.system.vo.CalculateVO;
+import com.ruoyi.system.vo.ScoreCalculateVO;
 import lombok.RequiredArgsConstructor;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -53,17 +57,29 @@
     public void add(BasicDataConfigDTO dto) {
         TbBasicDataConfig tbBasicDataConfig = BeanUtils.copyBean(dto, TbBasicDataConfig.class);
         //参数校验
-        Integer calculateType = tbBasicDataConfig.getCalculateType().getCode();
+        CalculateTypeEnum calculateType = tbBasicDataConfig.getCalculateType();
         List<CalculateDTO> dtoList = dto.getDtoList();
-        if (CalculateTypeEnum.NUMBER.getCode().equals(calculateType) && StringUtils.isBlank(dto.getNumberCalculateFormula())) {
-            throw new RuntimeException("计算公式不能为空");
+        if (CalculateTypeEnum.NUMBER.equals(calculateType) && StringUtils.isBlank(dto.getNumberCalculateFormula())) {
+            throw new ServiceException("计算公式不能为空");
         }
-        if ((CalculateTypeEnum.TEXT.getCode().equals(calculateType) || CalculateTypeEnum.PERCENTAGE.getCode().equals(calculateType))
-                && CollUtils.isEmpty(dtoList)) {
-            throw new RuntimeException("计算公式不能为空");
+        boolean verify = (CalculateTypeEnum.TEXT.equals(calculateType) || CalculateTypeEnum.PERCENTAGE.equals(calculateType)) && CollUtils.isNotEmpty(dtoList);
+        if (verify) {
+            CollUtils.check(dto.getDtoList(), new Checker<CalculateDTO>() {
+                @Override
+                public void check(CalculateDTO data) {
+                    if (StringUtils.isBlank(data.getKey())) {
+                        throw new ServiceException("基础数据配置key不能为空");
+                    }
+                    if (StringUtils.isBlank(data.getValue())) {
+                        throw new ServiceException("基础数据配置value不能为空");
+                    }
+                }
+            });
+        } else {
+            throw new ServiceException("计算公式不能为空");
         }
         this.save(tbBasicDataConfig);
-        if ((CalculateTypeEnum.TEXT.getCode().equals(calculateType) || CalculateTypeEnum.PERCENTAGE.getCode().equals(calculateType))) {
+        if (verify) {
             List<TbBasicDataConfigDetail> details = BeanUtils.copyList(dtoList, TbBasicDataConfigDetail.class);
             List<TbBasicDataConfigDetail> collect = details.stream().peek(item -> item.setBasicDataConfigId(tbBasicDataConfig.getId())).collect(Collectors.toList());
             tbBasicDataConfigDetailService.saveBatch(collect);
@@ -75,17 +91,17 @@
     public void edit(BasicDataConfigUpdateDTO dto) {
         TbBasicDataConfig tbBasicDataConfig = BeanUtils.copyBean(dto, TbBasicDataConfig.class);
         //参数校验
-        Integer calculateType = tbBasicDataConfig.getCalculateType().getCode();
+        CalculateTypeEnum calculateType = tbBasicDataConfig.getCalculateType();
         List<CalculateDTO> dtoList = dto.getDtoList();
-        if (CalculateTypeEnum.NUMBER.getCode().equals(calculateType) && StringUtils.isBlank(dto.getNumberCalculateFormula())) {
-            throw new RuntimeException("计算公式不能为空");
+        if (CalculateTypeEnum.NUMBER.equals(calculateType) && StringUtils.isBlank(dto.getNumberCalculateFormula())) {
+            throw new ServiceException("计算公式不能为空");
         }
-        if ((CalculateTypeEnum.TEXT.getCode().equals(calculateType) || CalculateTypeEnum.PERCENTAGE.getCode().equals(calculateType))
-                && CollUtils.isEmpty(dtoList)) {
-            throw new RuntimeException("计算公式不能为空");
+        boolean verify = CalculateTypeEnum.TEXT.equals(calculateType) || CalculateTypeEnum.PERCENTAGE.equals(calculateType);
+        if (verify && CollUtils.isEmpty(dtoList)) {
+            throw new ServiceException("计算公式不能为空");
         }
         this.updateById(tbBasicDataConfig);
-        if ((CalculateTypeEnum.TEXT.getCode().equals(calculateType) || CalculateTypeEnum.PERCENTAGE.getCode().equals(calculateType))) {
+        if (verify) {
             //删除原来的配置信息,重新添加新的
             tbBasicDataConfigDetailService.lambdaUpdate().eq(TbBasicDataConfigDetail::getBasicDataConfigId, tbBasicDataConfig.getId()).remove();
             List<TbBasicDataConfigDetail> details = BeanUtils.copyList(dtoList, TbBasicDataConfigDetail.class);
@@ -98,7 +114,7 @@
     public BasicDataConfigDetailVO getDetails(Integer id) {
         TbBasicDataConfig config = this.getById(id);
         if (Objects.isNull(config)) {
-            throw new RuntimeException("非法参数");
+            throw new ServiceException("非法参数");
         }
         BasicDataConfigDetailVO vo = BeanUtils.copyBean(config, BasicDataConfigDetailVO.class);
         Integer code = vo.getCalculateType().getCode();
@@ -114,7 +130,7 @@
     public void delete(Integer id) {
         TbBasicDataConfig config = this.getById(id);
         if (Objects.isNull(config)) {
-            throw new RuntimeException("非法参数");
+            throw new ServiceException("非法参数");
         }
         this.removeById(id);
     }
@@ -132,7 +148,7 @@
     public void showHide(ShowHideDTO dto) {
         TbBasicDataConfig config = this.getById(dto.getId());
         if (Objects.isNull(config)) {
-            throw new RuntimeException("非法参数");
+            throw new ServiceException("非法参数");
         }
         if (ShowStatusEnum.SHOW.equals(dto.getStatus())) {
             //查询改配置所使用字段状态
@@ -141,9 +157,14 @@
             List<TbField> list = fieldMapper.selectList(Wrappers.<TbField>lambdaQuery().in(TbField::getId, Arrays.asList(split)).eq(TbField::getStatus, ShowStatusEnum.HIDE));
             if (CollUtils.isNotEmpty(list)) {
                 String fieldNames = list.stream().map(TbField::getFieldName).collect(Collectors.joining(","));
-                throw new RuntimeException(String.format("字段“%s”已被隐藏,请重新配置后再次操作!", fieldNames));
+                throw new ServiceException(String.format("字段“%s”已被隐藏,请重新配置后再次操作!", fieldNames));
             }
         }
-        this.lambdaUpdate().set( TbBasicDataConfig::getStatus, dto.getStatus()).eq(TbBasicDataConfig::getId, dto.getId()).update();
+        this.lambdaUpdate().set(TbBasicDataConfig::getStatus, dto.getStatus()).eq(TbBasicDataConfig::getId, dto.getId()).update();
+    }
+
+    @Override
+    public Page<ScoreCalculateVO> scoreCalculatePage(ScoreCalculateQuery query, Page<ScoreCalculateVO> page) {
+        return baseMapper.scoreCalculatePage(query, page);
     }
 }

--
Gitblit v1.7.1