郑永安
2023-09-19 69185134fcfaf913ea45f1255677225a2cc311a4
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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
package com.gk.hotwork.Controller;
 
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.gk.hotwork.Controller.Base.BaseController;
import com.gk.hotwork.Domain.Enum.ErrorCode;
import com.gk.hotwork.Domain.Exception.BusinessException;
import com.gk.hotwork.Domain.RiskAnaUnit;
import com.gk.hotwork.Domain.Utils.FileOptUtils;
import com.gk.hotwork.Domain.Utils.FilterObject;
import com.gk.hotwork.Domain.Utils.Msg;
import com.gk.hotwork.Domain.Vo.RiskAnaUintExoprtVo;
import com.gk.hotwork.Service.ExcelExportService;
import com.gk.hotwork.Service.RiskAnaUnitService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
 
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.Map;
import java.util.List;
 
import static com.gk.hotwork.Domain.Utils.Properties.filePath;
 
/**
 * @author celin
 * @date 2022/3/16 14:39
 */
@Api(tags = "风险分析单元")
@RestController
@RequestMapping("/riskAnaUnit")
public class RiskAnaUintController extends BaseController {
 
    @Autowired
    private RiskAnaUnitService riskAnaUnitService;
    @Autowired
    private ExcelExportService excelExportService;
 
    @ApiOperation("分页")
    @PostMapping("/page")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "pageIndex", value = "当前页码"),
            @ApiImplicitParam(name = "pageSize", value = "每页行数"),
            @ApiImplicitParam(name = "filter.riskUnitName", value = "{}"),
            @ApiImplicitParam(name = "filter.hazardDep", value = "{}"),
            @ApiImplicitParam(name = "filter.riskUnitName", value = "{}"),
    })
    public Msg selectPage(@RequestBody FilterObject filterObject) {
        Integer pageIndex = filterObject.getPageIndex();
        Integer pageSize = filterObject.getPageSize();
        IPage<RiskAnaUnit> page = riskAnaUnitService.selectPage(new Page<>(pageIndex, pageSize), filterObject.getFilter(), getUser());
        return success(page);
    }
 
    @ApiOperation("新增")
    @PostMapping("/add")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "hazardDepId", value = "部门id"),
            @ApiImplicitParam(name = "hazardLiablePersonId", value = "负责人"),
            @ApiImplicitParam(name = "riskUnitName", value = "风险单元名称"),
    })
    public Msg add(@RequestBody RiskAnaUnit riskAnaUnitVo) {
        riskAnaUnitService.addOne(riskAnaUnitVo, getUser());
        return success();
    }
 
 
    @ApiOperation("修改")
    @PostMapping("/mod")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "id", value = "id"),
            @ApiImplicitParam(name = "hazardDepId", value = "部门id"),
            @ApiImplicitParam(name = "hazardLiablePerson", value = "负责人"),
            @ApiImplicitParam(name = "hazardLiablePersonId", value = "负责人"),
            @ApiImplicitParam(name = "riskUnitName", value = "风险单元名称"),
    })
    public Msg mod(@RequestBody RiskAnaUnit riskAnaUnit) {
        riskAnaUnitService.modOne(riskAnaUnit, getUser());
        return success();
    }
 
    @ApiOperation("删除")
    @PostMapping("/del")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "id", value = "id"),
    })
    public Msg del(@RequestBody JSONObject jsonObj) {
        Long id = jsonObj.getLong("id");
        riskAnaUnitService.delOne(id, getUser());
        return success();
    }
 
 
    @ApiOperation("风险分析个数部门分布")
    @PostMapping("/department-analysis")
    public Msg analysis(){
        List<Map> list = riskAnaUnitService.selectDepartmentAnalysis();
        return success(list);
    }
 
    @ApiOperation("风险分析单元数据导出")
    @GetMapping("/export")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "filter.riskUnitName", value = "{}"),
            @ApiImplicitParam(name = "filter.hazardDep", value = "{}"),
            @ApiImplicitParam(name = "filter.riskUnitName", value = "{}"),
    })
    public Msg infoExport(HttpServletRequest request, HttpServletResponse response) throws Exception {
 
        Msg msg = new Msg();
        msg.setCode("200");
        msg.setMessage("success");
 
        List<RiskAnaUintExoprtVo> listVo = riskAnaUnitService.getInfo(request, response);
        msg.setResult(listVo);
        return msg;
    }
 
    @ApiOperation("风险分析单元数据导入")
    @PostMapping("/import")
    public Msg infoImport(MultipartFile file) {
        Msg msg = new Msg();
        msg.setCode("200");
        msg.setMessage("success");
 
        String filesave ="";
        try {
            if (file == null)
            {
                msg.setCode("404");
                msg.setMessage("上传文件未找到");
                return msg;
            }
 
            long size = file.getSize();
            if(0 == size)
            {
                msg.setCode("404");
                msg.setMessage("上传文件大小为空");
                return msg;
            }
 
            if (!FileOptUtils.isDirExists(filePath)) {
                msg.setCode(ErrorCode.ERROR_10004.getCode());
                msg.setMessage("发生错误或不为目录");
                return msg;
            }
 
            if (!FileOptUtils.isDirExists(filePath)) {
                msg.setCode(ErrorCode.ERROR_10004.getCode());
                msg.setMessage("发生错误或不为目录");
                return msg;
            }
 
            filesave = filePath + getUser().getRealname() + "_"  + ".xlsx";
 
            file.transferTo(new File(filesave));
            InputStream in = new FileInputStream(filesave);
            String name = file.getOriginalFilename();
            Boolean isExcel2007 = name.substring(name.lastIndexOf(".") + 1).endsWith("xlsx") ? true : false;
            //riskEventService.importRiskEventData(param, getUser());
            excelExportService.importRiskAnaUnitExcel(in, getUser().getRealname(), isExcel2007);
 
        } catch (BusinessException e) {
            e.printStackTrace();
            msg.setCode(ErrorCode.ERROR_10004.getCode());
            msg.setMessage(e.getMessage());
        } catch (Exception e) {
            e.printStackTrace();
            msg.setCode(ErrorCode.ERROR_10004.getCode());
            msg.setMessage("导入发生错误");
        }
 
        return msg;
    }
}