package zy.cloud.wms.manager.controller;
|
|
import com.alibaba.excel.EasyExcel;
|
import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy;
|
import com.baomidou.mybatisplus.plugins.Page;
|
import com.core.annotations.ManagerAuth;
|
import com.core.common.R;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RequestParam;
|
import org.springframework.web.bind.annotation.RestController;
|
import zy.cloud.wms.common.utils.VersionUtils;
|
import zy.cloud.wms.common.web.BaseController;
|
import zy.cloud.wms.manager.entity.LocDetl;
|
import zy.cloud.wms.manager.entity.Mat;
|
import zy.cloud.wms.manager.service.LocDetlService;
|
import zy.cloud.wms.manager.service.MatService;
|
|
import javax.servlet.http.HttpServletResponse;
|
import java.io.IOException;
|
import java.net.URLEncoder;
|
import java.util.List;
|
import java.util.Map;
|
|
/**
|
* Created by vincent on 2021/4/2
|
*/
|
@RestController
|
public class StatisController extends BaseController {
|
|
@Autowired
|
private MatService matService;
|
@Autowired
|
private LocDetlService locDetlService;
|
|
@RequestMapping(value = "/stock/statis/auth")
|
@ManagerAuth
|
public R stockStatis(@RequestParam(defaultValue = "1")Integer curr,
|
@RequestParam(defaultValue = "10")Integer limit,
|
@RequestParam Map<String, Object> param) {
|
Page<LocDetl> stockStatis = locDetlService.getStockStatis(toPage(curr, limit, param, LocDetl.class));
|
for (LocDetl locDetl : stockStatis.getRecords()) {
|
Mat mat = matService.selectByMatnr(locDetl.getMatnr());
|
if (mat != null) {
|
VersionUtils.setLocDetl(locDetl, mat);
|
}
|
}
|
return R.ok().add(stockStatis);
|
}
|
|
@RequestMapping(value = "/stock/statis/export")
|
public void stockStatisExport(HttpServletResponse response) throws IOException {
|
List<LocDetl> excel = locDetlService.getStockStatisExcel();
|
for (LocDetl locDetl : excel) {
|
Mat mat = matService.selectByMatnr(locDetl.getMatnr());
|
if (mat != null) {
|
VersionUtils.setLocDetl(locDetl, mat);
|
}
|
}
|
response.setContentType("application/vnd.ms-excel");
|
response.setCharacterEncoding("utf-8");
|
String fileName = URLEncoder.encode("库存明细统计报表", "UTF-8");
|
response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
|
EasyExcel.write(response.getOutputStream(), LocDetl.class)
|
.registerWriteHandler(new LongestMatchColumnWidthStyleStrategy())
|
.sheet("sheet1")
|
.doWrite(excel);
|
}
|
|
}
|