whycxzp
2025-04-14 36160f9cc609f465b5d4f3433e3c0105beaba393
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
package com.whyc.service;
 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.whyc.dto.Response;
import com.whyc.mapper.MonPlanMapper;
import com.whyc.pojo.db_batt.MonPlan;
import com.whyc.pojo.db_user.UserInf;
import com.whyc.util.ActionUtil;
import org.springframework.stereotype.Service;
 
import javax.annotation.Resource;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
 
@Service
public class MonPlanService {
    @Resource
    private MonPlanMapper mapper;
 
    //统计计划
    public Response staticPlan() {
        QueryWrapper wrapper=new QueryWrapper();
        wrapper.orderByAsc("num");
        List<MonPlan> list=mapper.selectList(wrapper);
        //按照状态统计
        Map<Integer, List<MonPlan>> stateMonMap=list.stream().collect(Collectors.groupingBy(MonPlan::getPlanState));
        //按照类型统计
        Map<Integer, List<MonPlan>> typeMonMap=list.stream().collect(Collectors.groupingBy(MonPlan::getPlanType));
 
        Map<Integer, Object> stateMap = new HashMap<>();
        stateMap.put(0,0);
        stateMap.put(1,0);
        stateMap.put(2,0);
        stateMap.put(3,0);
        Map<Integer, Object> typeMap = new HashMap<>();
        typeMap.put(0,0);
        typeMap.put(1,0);
        typeMap.put(2,0);
        typeMap.put(3,0);
        for (Integer state : stateMonMap.keySet()) {
            stateMap.put(state, stateMonMap.get(state).size());
        }
        for (Integer type : typeMonMap.keySet()) {
            typeMap.put(type, typeMonMap.get(type).size());
        }
        Map<String,Object> map=new HashMap<>();
        map.put("state",stateMap);
        map.put("type",typeMap);
        return new Response().setII(1,true,map,"统计计划");
    }
 
    //查询计划
    public Response getPlan(Integer type, Integer state, int pageNum, int pageSize) {
        PageHelper.startPage(pageNum,pageSize);
        QueryWrapper wrapper=new QueryWrapper();
        if(type!=null){
            wrapper.eq("plan_type",type);
        }
        if(state!=null){
            wrapper.eq("plan_state",state);
        }
        wrapper.orderByAsc("num");
        List<MonPlan> list=mapper.selectList(wrapper);
        PageInfo pageInfo=new PageInfo(list);
        return new Response().setII(1,list!=null,pageInfo,"查询计划");
    }
    //查询正在进行的计划
    public Response getStartingPlan() {
        QueryWrapper wrapper=new QueryWrapper();
        wrapper.eq("plan_state",1);
        wrapper.orderByAsc("num");
        List<MonPlan> list=mapper.selectList(wrapper);
        return new Response().setII(1,list!=null,list,"查询计划");
    }
    //添加计划
    public Response addPlan(MonPlan monPlan) {
        UserInf uinf= ActionUtil.getUser();
        monPlan.setCreateUserId(uinf.getUid());
        monPlan.setCreateUserName(uinf.getUname());
        monPlan.setCreateTime(new Date());
        monPlan.setPlanState(0);
        int flag=mapper.insert(monPlan);
        return new Response().set(1,flag>0);
    }
}