Junjie
2024-09-13 a1a7c03eae40f4b0344fce652e1a240cf5283624
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
112
113
114
package com.zy.asrs.wms.asrs.controller;
 
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.zy.asrs.framework.common.DateUtils;
import com.zy.asrs.framework.common.R;
import com.zy.asrs.wms.asrs.entity.Loc;
import com.zy.asrs.wms.asrs.entity.TaskLog;
import com.zy.asrs.wms.asrs.entity.echart.EChartLineBean;
import com.zy.asrs.wms.asrs.entity.echart.EChartPieBean;
import com.zy.asrs.wms.asrs.entity.enums.LocStsType;
import com.zy.asrs.wms.asrs.service.LocService;
import com.zy.asrs.wms.asrs.service.TaskLogService;
import com.zy.asrs.wms.system.controller.BaseController;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
import java.text.SimpleDateFormat;
import java.util.*;
 
@RestController
@RequestMapping("/api")
public class EChartController extends BaseController {
 
    @Autowired
    private LocService locService;
    @Autowired
    private TaskLogService taskLogService;
 
    @PostMapping("/charts/loc/use")
    public R locUse(){
        List<EChartPieBean> list = new ArrayList<>();
 
        long fqty = locService.count(new LambdaQueryWrapper<Loc>().in(Loc::getLocStsId, LocStsType.F.val(), LocStsType.D.val()));
        long oqty = locService.count(new LambdaQueryWrapper<Loc>().in(Loc::getLocStsId, LocStsType.O.val()));
        long uqty = locService.count(new LambdaQueryWrapper<Loc>().in(Loc::getLocStsId, LocStsType.S.val(), LocStsType.R.val()));
        long xqty = locService.count(new LambdaQueryWrapper<Loc>().in(Loc::getLocStsId, LocStsType.X.val()));
 
        EChartPieBean fbean = new EChartPieBean();
        fbean.setName("在库库位");
        fbean.setValue(fqty);
        list.add(fbean);
 
        EChartPieBean obean = new EChartPieBean();
        obean.setName("空库位");
        obean.setValue(oqty);
        list.add(obean);
 
        EChartPieBean ubean = new EChartPieBean();
        ubean.setName("使用库位");
        ubean.setValue(uqty);
        list.add(ubean);
 
        EChartPieBean xbean = new EChartPieBean();
        xbean.setName("禁用库位");
        xbean.setValue(xqty);
        list.add(xbean);
        return R.ok(list);
    }
 
    @PostMapping("/charts/loc/line")
    public R locIoLineCharts(){
        SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd");
        Calendar calendar = Calendar.getInstance();
        calendar.add(Calendar.DATE, -12);
 
        ArrayList<String> days = new ArrayList<>();
        ArrayList<Long> inData = new ArrayList<>();
        ArrayList<Long> outData = new ArrayList<>();
        for (int i = 0; i < 12; i++) {
            calendar.add(Calendar.DATE, 1);
            Date time = calendar.getTime();
            days.add(sf.format(time));
 
            Date startOfDay = DateUtils.getStartOfDay(time);
            Date endOfDay = DateUtils.getEndOfDay(time);
 
            LambdaQueryWrapper<TaskLog> inWrapper = new LambdaQueryWrapper<TaskLog>()
                    .ge(TaskLog::getCreateTime, startOfDay)
                    .le(TaskLog::getCreateTime, endOfDay)
                    .eq(TaskLog::getTaskSts, 100)
                    .in(TaskLog::getTaskType, 1, 53, 57);
 
            LambdaQueryWrapper<TaskLog> outWrapper = new LambdaQueryWrapper<TaskLog>()
                    .ge(TaskLog::getCreateTime, startOfDay)
                    .le(TaskLog::getCreateTime, endOfDay)
                    .eq(TaskLog::getTaskSts, 200)
                    .in(TaskLog::getTaskType, 101, 103, 107);
 
            long inCount = taskLogService.count(inWrapper);
            long outCount = taskLogService.count(outWrapper);
 
            inData.add(inCount);
            outData.add(outCount);
        }
 
        EChartLineBean inBean = new EChartLineBean();
        inBean.setName("入库数量");
        inBean.setValue(inData);
 
        EChartLineBean outBean = new EChartLineBean();
        outBean.setName("出库数量");
        outBean.setValue(outData);
 
        HashMap<String, Object> map = new HashMap<>();
        map.put("in", inBean);
        map.put("out", outBean);
        map.put("days", days);
 
        return R.ok().add(map);
    }
 
}