huang
2025-05-20 2c2413760b6467bf62402dba7338bd3bbcbd7341
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
package com.mes.utilization.controller;
 
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.mes.utils.Result;
import com.mes.utilization.entity.Utilization;
import com.mes.utilization.service.UtilizationService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.*;
 
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.Map;
 
@Api(tags = "生产线利用率接口")
@RestController
@RequestMapping("/utilization")
public class UtilizationController {
 
    @Autowired
    private UtilizationService utilizationService;
 
    @ApiOperation("获取生产线利用率数据列表")
    @PostMapping("/listUtilization")
    @ResponseBody
    public Result listUtilization(@RequestBody Map<String, Object> params) {
        Integer page = params.get("page") == null ? 1 : (Integer) params.get("page");
        Integer pageSize = params.get("pageSize") == null ? 10 : (Integer) params.get("pageSize");
        String lineNo = (String) params.get("lineNo");
        
        QueryWrapper<Utilization> queryWrapper = new QueryWrapper<Utilization>().orderByDesc("record_time");
        if (StringUtils.hasText(lineNo)) {
            queryWrapper.eq("line_no", lineNo);
        }
        
        Page<Utilization> pageData = utilizationService.page(
            new Page<>(page, pageSize),
            queryWrapper
        );
        
        return Result.build(200, "查询成功", pageData);
    }
 
    @ApiOperation("添加生产线利用率记录")
    @PostMapping("/addUtilization")
    @ResponseBody
    public Result addUtilization(@RequestBody Utilization utilization) {
        utilization.setCreateTime(new Date());
        utilization.setUpdateTime(new Date());
        boolean success = utilizationService.save(utilization);
        int count = success ? 1 : 0;
        String message = count > 0 ? "添加成功:" + count : "添加失败!";
        return Result.build(200, message, count);
    }
 
    @ApiOperation("修改生产线利用率记录")
    @PostMapping("/updateUtilization")
    @ResponseBody
    public Result updateUtilization(@RequestBody Utilization utilization) {
        utilization.setUpdateTime(new Date());
        boolean success = utilizationService.updateById(utilization);
        int count = success ? 1 : 0;
        String message = count > 0 ? "修改成功:" + count : "修改失败!";
        return Result.build(200, message, count);
    }
 
    @ApiOperation("删除生产线利用率记录")
    @PostMapping("/deleteUtilization")
    @ResponseBody
    public Result deleteUtilization(@RequestBody Utilization utilization) {
        boolean success = utilizationService.removeById(utilization.getId());
        int count = success ? 1 : 0;
        String message = count > 0 ? "删除成功:" + count : "删除失败!";
        return Result.build(200, message, count);
    }
 
    @ApiOperation("获取图表数据")
    @PostMapping("/chartUtilization")
    @ResponseBody
    public Result getChartData(@RequestBody(required = false) Map<String, Object> params) {
        String lineNo = params != null ? (String) params.get("lineNo") : null;
        Integer dayCount = params != null && params.get("dayCount") != null ? (Integer) params.get("dayCount") : null;
        
        QueryWrapper<Utilization> queryWrapper = new QueryWrapper<Utilization>().orderByAsc("record_time");
        if (StringUtils.hasText(lineNo)) {
            queryWrapper.eq("line_no", lineNo);
        }
        
        if (dayCount != null && dayCount > 0) {
            Calendar calendar = Calendar.getInstance();
            calendar.add(Calendar.DAY_OF_MONTH, -dayCount);
            Date startDate = calendar.getTime();
            queryWrapper.ge("record_time", startDate);
        }
        
        List<Utilization> data = utilizationService.list(queryWrapper);
        
        return Result.build(200, "查询成功", data);
    }