SparePartController.java
4.02 KB
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
package vion.controller;
import cn.dev33.satoken.annotation.SaCheckPermission;
import cn.dev33.satoken.stp.StpUtil;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.lang.Assert;
import cn.hutool.core.util.ArrayUtil;
import cn.hutool.core.util.StrUtil;
import com.github.liaochong.myexcel.core.DefaultStreamExcelBuilder;
import com.github.liaochong.myexcel.core.watermark.Watermark;
import com.github.liaochong.myexcel.utils.AttachmentExportUtil;
import com.github.liaochong.myexcel.utils.WatermarkUtil;
import io.github.linpeilie.Converter;
import lombok.RequiredArgsConstructor;
import org.apache.poi.ss.usermodel.Workbook;
import org.springframework.web.bind.annotation.*;
import vion.dto.SparePartDTO;
import vion.service.ISparePartService;
import vion.vo.SparePartVO;
import vion.vo.UserVO;
import javax.servlet.http.HttpServletResponse;
import java.awt.*;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
/**
* 备件申请
*/
@RestController
@RequiredArgsConstructor
@RequestMapping("/api/sparePart")
public class SparePartController {
private final ISparePartService sparePartService;
private final Converter converter;
@PostMapping("/frontSubmit")
public Object frontSubmit(SparePartDTO dto) {
return sparePartService.frontSubmit(dto);
}
@GetMapping
@SaCheckPermission(value = "sparePart:list", orRole = "admin")
public List<SparePartVO> list(SparePartDTO dto) {
Assert.isTrue(ArrayUtil.isAllNotNull(dto.getCreateTimeStart(), dto.getCreateTimeEnd()), "查询时间范围不能为空");
return sparePartService.list(dto);
}
@GetMapping("/{id}")
@SaCheckPermission(value = "sparePart:query", orRole = "admin")
public SparePartVO getById(@PathVariable Long id) {
return sparePartService.getSparePartDetail(id, null);
}
@GetMapping("/get/{uuid}")
public SparePartVO getByUuid(@PathVariable String uuid) {
return sparePartService.getSparePartDetail(null, uuid);
}
@PostMapping("/{id}")
@SaCheckPermission(value = "sparePart:edit", orRole = "admin")
public String updById(@PathVariable Long id, @RequestBody SparePartDTO dto) {
return sparePartService.updById(id, dto);
}
@DeleteMapping("/{id}")
@SaCheckPermission(value = "sparePart:remove", orRole = "admin")
public String delById(@PathVariable Long id) {
return sparePartService.removeById(id) ? "删除成功" : "删除失败";
}
@GetMapping("/export")
@SaCheckPermission(value = "sparePart:export", orRole = "admin")
public void sparePartExport(SparePartDTO dto, HttpServletResponse response) {
UserVO user = (UserVO) StpUtil.getTokenSession().get("curLoginUser");
dto.setPageSize(30000);
List<SparePartVO> voPage = sparePartService.list(dto);
try (DefaultStreamExcelBuilder<SparePartVO> defaultStreamExcelBuilder = DefaultStreamExcelBuilder.of(SparePartVO.class).start()) {
List<SparePartVO> res = new ArrayList<>();
voPage.forEach(v -> v.getRepairDeviceList().forEach(r -> {
SparePartVO convert = new SparePartVO();
BeanUtil.copyProperties(v, convert);
convert.setRRepairDevice(r);
res.add(convert);
}));
defaultStreamExcelBuilder.append(res);
Workbook workbook = defaultStreamExcelBuilder.autoMerge().build();
// 水印添加指定字体,并在服务器上安装 SimSun 字体,解决中文字体变成方块的问题
Watermark watermark = new Watermark();
watermark.setText(user.getUsername() + "-" + user.getPhone());
watermark.setFont(new Font("SimSun", Font.PLAIN, 16));
WatermarkUtil.addWatermark(workbook, watermark);
AttachmentExportUtil.export(workbook, StrUtil.format("备件申请列表_{}", DateUtil.formatDateTime(new Date())), response);
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}