Lius
2025-06-17 d0f024586f38a11662787c42b84e037a1c1be6cd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
package org.jeecg.modules.mdc.service.impl;
 
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.apache.commons.lang3.StringUtils;
import org.jeecg.modules.mdc.dto.MdcUtilizationRateDto;
import org.jeecg.modules.mdc.entity.MdcUtilizationRate;
import org.jeecg.modules.mdc.mapper.MdcUtilizationRateMapper;
import org.jeecg.modules.mdc.service.IMdcUtilizationRateService;
import org.springframework.stereotype.Service;
 
import javax.servlet.http.HttpServletRequest;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
 
/**
 * @Description: 率参数设置
 * @Author: Sake
 * @Date: 2023-03-31 15:03
 */
@Service
public class MdcUtilizationRateServiceImpl extends ServiceImpl<MdcUtilizationRateMapper, MdcUtilizationRate> implements IMdcUtilizationRateService {
    @Override
    public IPage<MdcUtilizationRate> queryPageList(Page page, HttpServletRequest req) {
        //创建查询器
        QueryWrapper<MdcUtilizationRate> queryWrapper = new QueryWrapper();
        //检查HTTP请求体中是否存在名为驱动类型的参数,存在则true,获取第一个数据使用模糊查询添加到到查询器中
        if (req.getParameterMap().containsKey("rateParameterCategory")) {
            String rateParameterCategory = req.getParameterMap().get("rateParameterCategory")[0];
            queryWrapper.like(StringUtils.isNotBlank(rateParameterCategory), "rate_parameter_category", rateParameterCategory);
        }
 
        //根据参数类别排序
        //创建一个返回对象 值为根据分页后查询所得数据
        IPage<MdcUtilizationRate> pageList = this.page(page, queryWrapper);
        return pageList;
    }
 
    @Override
    public Boolean addUtilization(MdcUtilizationRate mdcUtilizationRate) {
        return this.save(mdcUtilizationRate);
    }
 
    @Override
    public Boolean editUtilization(MdcUtilizationRate mdcUtilizationRate) {
        return this.updateById(mdcUtilizationRate);
    }
 
    @Override
    public Boolean deleteUtilization(String id) {
        return this.removeById(id);
    }
 
    @Override
    public Boolean deleteBatchUtilization(String ids) {
        return this.removeByIds(Arrays.asList(ids.split(",")));
    }
 
    /**
     * 根据类型查询利用率层级
     *
     * @param type
     * @return
     */
    @Override
    public List<MdcUtilizationRate> listByType(String type) {
        return this.baseMapper.selectList(new LambdaQueryWrapper<MdcUtilizationRate>().eq(MdcUtilizationRate::getRateParameterType, type));
    }
 
    /**
     * 根据类型获取颜色标签
     *
     * @param type
     * @return
     */
    @Override
    public List<MdcUtilizationRateDto> getByType(String type) {
        List<MdcUtilizationRateDto> result = new ArrayList<>();
        List<MdcUtilizationRate> list = this.list(new LambdaQueryWrapper<MdcUtilizationRate>().eq(MdcUtilizationRate::getRateParameterType, type).orderByAsc(MdcUtilizationRate::getRateParameterLevel));
        for (MdcUtilizationRate mdcUtilizationRate : list) {
            MdcUtilizationRateDto mdcUtilizationRateDto = new MdcUtilizationRateDto();
            mdcUtilizationRateDto.setColor(mdcUtilizationRate.getRateParameterColor());
            String title;
            if (mdcUtilizationRate.getMinimumRange() == 0) {
                title = mdcUtilizationRate.getRateParameterCategory() + " < " + mdcUtilizationRate.getMaximumRange() + "%";
            } else if (mdcUtilizationRate.getMaximumRange() == 100) {
                title = mdcUtilizationRate.getRateParameterCategory() + ">= " + mdcUtilizationRate.getMinimumRange() + "%";
            } else {
                title = mdcUtilizationRate.getMinimumRange() + "% <= " + mdcUtilizationRate.getRateParameterCategory() + " < " + mdcUtilizationRate.getMaximumRange() + "%";
            }
            mdcUtilizationRateDto.setTitle(title);
            result.add(mdcUtilizationRateDto);
        }
        return result;
    }
 
    /**
     * 据类型获取数据区间和颜色
     *
     * @param type
     * @return
     */
    @Override
    public List<MdcUtilizationRate> getSectionByType(String type) {
        return this.list(new LambdaQueryWrapper<MdcUtilizationRate>().eq(MdcUtilizationRate::getRateParameterType, type).orderByAsc(MdcUtilizationRate::getRateParameterLevel));
    }
}