From c29f5c8371f2b08cdfdd635f9723d90675c6c2cb Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期五, 19 九月 2025 09:41:04 +0800 Subject: [PATCH] 缓冲区库存调整 --- src/main/java/com/zy/asrs/controller/LocMastController.java | 143 +++++++++++++++++++++++++++++++---------------- 1 files changed, 93 insertions(+), 50 deletions(-) diff --git a/src/main/java/com/zy/asrs/controller/LocMastController.java b/src/main/java/com/zy/asrs/controller/LocMastController.java index 757a36f..723e3f6 100644 --- a/src/main/java/com/zy/asrs/controller/LocMastController.java +++ b/src/main/java/com/zy/asrs/controller/LocMastController.java @@ -17,6 +17,7 @@ import com.zy.asrs.service.*; import com.zy.common.entity.Parameter; import com.zy.common.model.Shelves; +import com.zy.common.service.CommonService; import com.zy.common.web.BaseController; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; @@ -32,16 +33,19 @@ @Autowired private LocDetlService locDetlService; @Autowired - private BasWhsService basWhsService; - + private BasWhsTypeService basWhsTypeService; @Resource private WrkMastService wrkMastService; - @Resource private AdjDetlService adjDetlService; - @Resource private LocDetlMapper locDetlMapper; + @Resource + private CommonService commonService; + @Resource + private WrkMastLogService wrkMastLogService; + @Resource + private WrkDetlLogService wrkDetlLogService; @RequestMapping(value = "/locMast/init/pwd") public R locMastInitPwd(@RequestParam(required = false) String pwd) { @@ -65,37 +69,39 @@ @RequestMapping(value = "/locMast/list/auth") @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 Map<String, Object> param){ + public R list(@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) { excludeTrash(param); EntityWrapper<LocMast> wrapper = new EntityWrapper<>(); convert(param, wrapper); - if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));} + if (!Cools.isEmpty(orderByField)) { + wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType)); + } return R.ok(locMastService.selectPage(new Page<>(curr, limit), wrapper)); } - private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){ + private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper) { boolean sign = false; - for (Map.Entry<String, Object> entry : map.entrySet()){ + for (Map.Entry<String, Object> entry : map.entrySet()) { String val = String.valueOf(entry.getValue()); - if (val.contains(RANGE_TIME_LINK)){ + if (val.contains(RANGE_TIME_LINK)) { String[] dates = val.split(RANGE_TIME_LINK); wrapper.ge(entry.getKey(), DateUtils.convert(dates[0])); wrapper.le(entry.getKey(), DateUtils.convert(dates[1])); - } else if (entry.getKey().equals("loc_no")){ + } else if (entry.getKey().equals("loc_no")) { wrapper.like(entry.getKey(), val); } else { - if (entry.getKey().equals("loc_type1")){ - sign=true; + if (entry.getKey().equals("loc_type1")) { + sign = true; } wrapper.eq(entry.getKey(), val); } } - if (sign){ - wrapper.and().ne("loc_sts","Y"); + if (sign) { + wrapper.and().ne("loc_sts", "Y"); } } @@ -110,19 +116,19 @@ return R.ok(); } - @RequestMapping(value = "/locMast/update/auth") - @ManagerAuth(memo = "搴撲綅淇敼") - public R update(LocMast locMast){ + @RequestMapping(value = "/locMast/update/auth") + @ManagerAuth(memo = "搴撲綅淇敼") + public R update(LocMast locMast) { - if (Cools.isEmpty(locMast) || null==locMast.getLocNo()){ + if (Cools.isEmpty(locMast) || null == locMast.getLocNo()) { return R.error(); } WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>() .eq("source_loc_no", locMast.getLocNo()) .or().eq("loc_no", locMast.getLocNo())); - if(!Cools.isEmpty(wrkMast)){ - return R.error("璇ュ簱浣嶆鍦ㄤ綔涓氾紝璇峰厛澶勭悊宸ヤ綔妗�"); + if (!Cools.isEmpty(wrkMast)) { + return R.error("璇ュ簱浣嶆鍦ㄤ綔涓氾紝璇峰厛澶勭悊宸ヤ綔妗�"); } LocMast oldLocMast = locMastService.selectById(locMast.getLocNo()); @@ -134,6 +140,31 @@ if (oldLocMast.getLocSts().equals("R") || oldLocMast.getLocSts().equals("F") || oldLocMast.getLocSts().equals("S")) { if (locMast.getLocSts().equals("O") || locMast.getLocSts().equals("D")) { List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo())); + // 娣诲姞鍘嗗彶宸ヤ綔涓绘。 + WrkMastLog wrkMastLog = new WrkMastLog(); + wrkMastLog.setWrkNo(commonService.getWorkNo(3)); + wrkMastLog.setIoTime(now); + wrkMastLog.setWrkSts(5); + wrkMastLog.setIoType(19); + wrkMastLog.setIoPri(13D); // 浼樺厛绾� + wrkMastLog.setCrnNo(locMast.getCrnNo()); + wrkMastLog.setSourceLocNo(locMast.getLocNo()); + wrkMastLog.setLocNo(locMast.getLocNo()); + wrkMastLog.setBarcode(locMast.getBarcode()); // 鎵樼洏鐮� + wrkMastLog.setFullPlt("Y"); // 婊℃澘锛歒 + wrkMastLog.setPicking("N"); // 鎷f枡 + wrkMastLog.setExitMk("N"); // 閫�鍑� + wrkMastLog.setEmptyMk("N"); // 绌烘澘 + wrkMastLog.setLinkMis("Y"); + // 鎿嶄綔浜哄憳鏁版嵁 + wrkMastLog.setAppeTime(now); + wrkMastLog.setModiTime(now); + wrkMastLog.setAppeUser(getUserId()); + wrkMastLog.setModiUser(getUserId()); + boolean res = wrkMastLogService.insert(wrkMastLog); + if (!res) { + throw new CoolException("淇濆瓨宸ヤ綔妗eけ璐�"); + } for (LocDetl locDetl : locDetls) { // 淇濆瓨璋冩暣璁板綍 AdjDetl adjDetl = new AdjDetl(); @@ -148,6 +179,20 @@ adjDetl.setAppeUser(getUserId()); if (!adjDetlService.insert(adjDetl)) { throw new CoolException("鏈嶅姟鍣ㄩ敊璇紝璇疯仈绯荤鐞嗗憳"); + } + + // 娣诲姞鍘嗗彶宸ヤ綔鏄庣粏 + WrkDetlLog wrkDetl = new WrkDetlLog(); + wrkDetl.sync(locDetl); + wrkDetl.setWrkNo(wrkMastLog.getWrkNo()); + wrkDetl.setIoTime(wrkMastLog.getIoTime()); + wrkDetl.setAnfme(0.0); + wrkDetl.setAppeTime(now); + wrkDetl.setModiTime(now); + wrkMastLog.setAppeUser(getUserId()); + wrkMastLog.setModiUser(getUserId()); + if (!wrkDetlLogService.insert(wrkDetl)) { + throw new CoolException("淇濆瓨宸ヤ綔鏄庣粏澶辫触"); } } if (!locDetlService.delete(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo()))) { @@ -171,7 +216,7 @@ if (locMast.getFrozen() == 1 && oldLocMast.getFrozen() == 0 && locMast.getLocSts().equals("F") && oldLocMast.getLocSts().equals("F")) { locDetlMapper.updateDetlFrozenByLocNo(oldLocMast.getLocNo()); } - if(!locMastService.updateById(locMast)) { + if (!locMastService.updateById(locMast)) { throw new CoolException("鏈嶅姟鍣ㄩ敊璇紝璇疯仈绯荤鐞嗗憳"); } return R.ok(); @@ -179,12 +224,12 @@ @RequestMapping(value = "/locMast/delete/auth") @ManagerAuth(memo = "搴撲綅鍒犻櫎") - public R delete(@RequestParam String param){ + public R delete(@RequestParam String param) { List<LocMast> list = JSONArray.parseArray(param, LocMast.class); - if (Cools.isEmpty(list)){ + if (Cools.isEmpty(list)) { return R.error(); } - for (LocMast entity : list){ + for (LocMast entity : list) { locMastService.delete(new EntityWrapper<>(entity)); } return R.ok(); @@ -192,7 +237,7 @@ @RequestMapping(value = "/locMast/export/auth") @ManagerAuth(memo = "搴撲綅瀵煎嚭") - public R export(@RequestBody JSONObject param){ + public R export(@RequestBody JSONObject param) { List<String> fields = JSONObject.parseArray(param.getJSONArray("fields").toJSONString(), String.class); EntityWrapper<LocMast> wrapper = new EntityWrapper<>(); Map<String, Object> map = excludeTrash(param.getJSONObject("locMast")); @@ -208,7 +253,7 @@ wrapper.like("loc_no", condition); Page<LocMast> page = locMastService.selectPage(new Page<>(0, 10), wrapper); List<Map<String, Object>> result = new ArrayList<>(); - for (LocMast locMast : page.getRecords()){ + for (LocMast locMast : page.getRecords()) { Map<String, Object> map = new HashMap<>(); map.put("id", locMast.getLocNo()); map.put("value", locMast.getLocNo()); @@ -221,7 +266,7 @@ @ManagerAuth public R query(@RequestBody JSONObject param) { Wrapper<LocMast> wrapper = new EntityWrapper<LocMast>().eq(humpToLine(String.valueOf(param.get("key"))), param.get("val")); - if (null != locMastService.selectOne(wrapper)){ + if (null != locMastService.selectOne(wrapper)) { return R.parse(BaseRes.REPEAT).add(getComment(LocMast.class, String.valueOf(param.get("key")))); } return R.ok(); @@ -231,38 +276,36 @@ @ManagerAuth(memo = "鍒濆鍖栧簱浣�") // @Transactional public R init(LocMastInitParam param) { - try{ + try { List<LocMast> list = new ArrayList<>(); - BasWhs basWhs = basWhsService.selectByIdentifying(param.getIdentifying()); - if (Cools.isEmpty(basWhs)){ + BasWhsType basWhsType = basWhsTypeService.selectByIdentifying(param.getIdentifying()); + if (Cools.isEmpty(basWhsType)) { return R.error("搴撳瀷涓嶅瓨鍦紒锛侊紒"); } - for (int r=param.getStartRow(); r<=param.getEndRow(); r++){ - for (int b=param.getStartBay(); b<=param.getEndBay(); b++) { - for (int l=param.getStartLev(); l<=param.getEndLev(); l++) { + for (int r = param.getStartRow(); r <= param.getEndRow(); r++) { + for (int b = param.getStartBay(); b <= param.getEndBay(); b++) { + for (int l = param.getStartLev(); l <= param.getEndLev(); l++) { // 鑾峰彇搴撲綅鍙� String locNo = String.format("%02d", r) + String.format("%03d", b) + String.format("%02d", l); // 鑾峰彇鍫嗗灈鏈哄彿 int crnNo = 0; - try{ - Shelves shelves = new Shelves(param.getEndRow() - param.getStartRow() + 1, param.getCrnAmount(),param.getStartRow()); - for (List<Integer> node : shelves.nodes){ - + try { + Shelves shelves = new Shelves(param.getEndRow() - param.getStartRow() + 1, param.getCrnAmount(), param.getStartRow()); + for (List<Integer> node : shelves.nodes) { if (node.contains(r)) { - if (!Cools.isEmpty(param.getStaCrn()) && param.getStaCrn() > 0){ + if (!Cools.isEmpty(param.getStaCrn()) && param.getStaCrn() > 0) { crnNo = shelves.nodes.indexOf(node) + param.getStaCrn(); - }else { + } else { crnNo = shelves.nodes.indexOf(node) + 1; } - break; } } - }catch (Exception e){ + } catch (Exception e) { throw new Exception("瑙f瀽鍫嗗灈鏈哄彿澶辫触锛岃濉啓姝g‘鐨勬暟鎹�!!!"); } - Date now = new Date(); + Date now = new Date(); LocMast locMast = new LocMast(); locMast.setLocNo(locNo); locMast.setLocSts("O"); @@ -278,18 +321,18 @@ locMast.setAppeTime(now); locMast.setModiUser(getUserId()); locMast.setModiTime(now); - locMast.setWhsType(basWhs.getId()); + locMast.setWhsType(basWhsType.getId()); list.add(locMast); } } } - if (!Cools.isEmpty(param.getEnable()) && param.getEnable() == 1){ + if (!Cools.isEmpty(param.getEnable()) && param.getEnable() == 1) { locMastService.delete(new EntityWrapper<>()); } locMastService.insertBatch(list); return R.ok("鍒濆鍖栨垚鍔�"); - }catch (Exception e){ - return R.error("鍒濆鍖栧け璐�===>"+e.getMessage()); + } catch (Exception e) { + return R.error("鍒濆鍖栧け璐�===>" + e.getMessage()); } } } -- Gitblit v1.9.1