From 0e7e7b7935a47f17622500b76c24ac185e491486 Mon Sep 17 00:00:00 2001 From: zc <zc@123> Date: 星期四, 24 四月 2025 10:48:38 +0800 Subject: [PATCH] 初步完成调试 --- src/main/java/com/zy/asrs/controller/ManLocDetlController.java | 182 ++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 161 insertions(+), 21 deletions(-) diff --git a/src/main/java/com/zy/asrs/controller/ManLocDetlController.java b/src/main/java/com/zy/asrs/controller/ManLocDetlController.java index 8b6ae48..612634e 100644 --- a/src/main/java/com/zy/asrs/controller/ManLocDetlController.java +++ b/src/main/java/com/zy/asrs/controller/ManLocDetlController.java @@ -1,17 +1,32 @@ package com.zy.asrs.controller; +import com.alibaba.excel.EasyExcel; +import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy; +import com.alibaba.fastjson.JSONObject; +import com.baomidou.mybatisplus.mapper.EntityWrapper; +import com.baomidou.mybatisplus.plugins.Page; import com.core.annotations.ManagerAuth; import com.core.common.Cools; import com.core.common.DateUtils; import com.core.common.R; +import com.zy.asrs.entity.LocDetl; import com.zy.asrs.entity.ManLocDetl; +import com.zy.asrs.entity.Mat; +import com.zy.asrs.entity.param.LocDetlAdjustParam; import com.zy.asrs.service.ManLocDetlService; +import com.zy.asrs.service.MatService; +import com.zy.common.utils.RoleUtils; import com.zy.common.web.BaseController; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; +import javax.servlet.http.HttpServletResponse; +import java.io.IOException; +import java.net.URLEncoder; +import java.util.List; import java.util.Map; @RestController @@ -19,6 +34,93 @@ @Autowired private ManLocDetlService manLocDetlService; + @Autowired + private MatService matService; + + @RequestMapping("/manLocDetl/matnr/count") + public R getCount(@RequestBody Map<String, String> param){ + String matnr = param.get("matnr"); + Double sum = 0.0; + if (Cools.isEmpty(matnr)){ + sum = manLocDetlService.sum(); + }else { + sum = manLocDetlService.getSumAnfme(matnr); + } + + return R.ok(sum); + } + + @RequestMapping(value = "/manLocDetl/export/auth") + @ManagerAuth(memo = "搴撲綅鏄庣粏瀵煎嚭") + public R export(@RequestBody JSONObject param){ + List<String> fields = JSONObject.parseArray(param.getJSONArray("fields").toJSONString(), String.class); + EntityWrapper<ManLocDetl> wrapper = new EntityWrapper<>(); + Map<String, Object> map = excludeTrash(param.getJSONObject("locDetl")); + String row = ""; + if (map.get("row") != null) { + String chooseRow = (String) map.get("row"); + if (chooseRow.length() == 1) { + row = "0" + chooseRow; + map.remove("row"); + }else { + row = chooseRow; + map.remove("row"); + } + } + convert(map, wrapper); + if (!row.equals("")){ + wrapper.and() + .where("loc_no like '" +row +"%'"); + } + List<ManLocDetl> list = manLocDetlService.selectList(wrapper); + return R.ok(exportSupport(list, fields)); + } + + @RequestMapping(value = "/manLocDetl/statis/export") +// @ManagerAuth + public void statisExport(HttpServletResponse response) throws IOException { + List<ManLocDetl> excel = manLocDetlService.getStockStatisExcel(); + for (ManLocDetl locDetl : excel) { + Mat mat = matService.selectByMatnr(locDetl.getMatnr()); + if (mat != null) { + locDetl.sync(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("琛�1") + .doWrite(excel); + } + + /** + * 鑾峰彇搴撳瓨鎬绘暟 + * @return + */ + @RequestMapping("/manLocDetl/count") + public R getAllCount(){ + Double sum = manLocDetlService.sum(); + return R.ok(sum); + } + + + @RequestMapping(value = "/manLocDetl/statis/auth") + @ManagerAuth + public R statis(@RequestParam(defaultValue = "1")Integer curr, + @RequestParam(defaultValue = "10")Integer limit, + @RequestParam Map<String, Object> param) { + Page<ManLocDetl> stockStatis = manLocDetlService.getStockStatis(toPage(curr, limit, param, ManLocDetl.class)); + for (ManLocDetl locDetl : stockStatis.getRecords()) { + Mat mat = matService.selectByMatnr(locDetl.getMatnr()); + if (mat != null) { + locDetl.sync(mat); + } + } + return R.ok().add(stockStatis); + } @RequestMapping(value = "/manLocDetl/list/auth") @ManagerAuth @@ -26,30 +128,68 @@ @RequestParam(defaultValue = "10")Integer limit, @RequestParam(required = false)String orderByField, @RequestParam(required = false)String orderByType, + @RequestParam(required = false)String condition, @RequestParam Map<String, Object> param){ - Long hostId = getHostId(); - if (hostId != null) { - param.put("host_id", hostId); - } - Object nodeId = param.get("node_id"); - if (Cools.isEmpty(nodeId)) { - nodeId = getOriginNode().getId(); - param.put("node_id", String.valueOf(nodeId)); - } - Object tagId = param.get("tag_id"); - if (Cools.isEmpty(tagId)) { - tagId = getOriginTag().getId(); - param.put("tag_id", String.valueOf(tagId)); - } - if (!Cools.isEmpty(param.get("update_time"))){ - String val = String.valueOf(param.get("update_time")); - if (val.contains(RANGE_TIME_LINK)) { + + EntityWrapper<ManLocDetl> wrapper = new EntityWrapper<>(); + excludeTrash(param); + convert(param, wrapper); + allLike(ManLocDetl.class, param.keySet(), wrapper, condition); + if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));} + + return R.ok(manLocDetlService.selectPage(new Page<>(curr, limit), wrapper)); + } + + + @RequestMapping("/manLocDetl/list") + public R outList(@RequestParam(defaultValue = "1")Integer curr, + @RequestParam(defaultValue = "10")Integer limit, + @RequestParam(required = false)String orderByField, + @RequestParam(required = false)String orderByType, + @RequestParam Map<String, Object> param){ + + Page<ManLocDetl> manLocDetlPage = toPage(curr, limit, param, ManLocDetl.class); + Page<ManLocDetl> outPage = manLocDetlService.getOutPage(manLocDetlPage); +// Page<ManLocDetl> page = manLocDetlService.getPage(manLocDetlPage); + return R.ok(outPage); + } + + @RequestMapping("/manLocDetl/adjust/start") + @ManagerAuth(memo = "搴撳瓨璋冩暣") + public R locDetlAdjustStart(@RequestBody LocDetlAdjustParam param) { + manLocDetlService.adjustLocDetl(param, getUserId()); + return R.ok("搴撳瓨璋冩暣鎴愬姛"); + } + +// @RequestMapping(value = "/manLocDetl/asrsAndSaas/list") +// @ManagerAuth +// public R list(@RequestParam(defaultValue = "1")Integer curr, +// @RequestParam(defaultValue = "10")Integer limit, +// @RequestParam(required = false)String orderByField, +// @RequestParam(required = false)String orderByType, +// @RequestParam(required = false)String condition, +// @RequestParam Map<String, Object> param){ +// +// Page<ManLocDetl> manLocDetlPage = toPage(curr, limit, param, ManLocDetl.class); +// Page<ManLocDetl> all = manLocDetlService.selectAllPage(manLocDetlPage); +// return R.ok().add(all); +// } + private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){ + for (Map.Entry<String, Object> entry : map.entrySet()){ + String val = String.valueOf(entry.getValue()); + if (val.contains(RANGE_TIME_LINK)){ String[] dates = val.split(RANGE_TIME_LINK); - param.put("startTime", DateUtils.convert(dates[0])); - param.put("endTime", DateUtils.convert(dates[1])); - param.remove("update_time"); + wrapper.ge(entry.getKey(), DateUtils.convert(dates[0])); + wrapper.le(entry.getKey(), DateUtils.convert(dates[1])); + } else { + if (entry.getKey().equals("locNo")) { + wrapper.eq("loc_no", String.valueOf(entry.getValue())); + } else { + wrapper.like(entry.getKey(), String.valueOf(entry.getValue())); + } } } - return R.ok(manLocDetlService.getPage(toPage(curr, limit, param, ManLocDetl.class))); } + + } -- Gitblit v1.9.1