From 19838a8bf458e94bed799363d11b35b517ab15df Mon Sep 17 00:00:00 2001 From: lsh <lsh@163.com> Date: 星期三, 18 十二月 2024 18:48:46 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/controller/LocMastController.java | 226 ++++++++++++++++++++++++++++++++------------------------ 1 files changed, 130 insertions(+), 96 deletions(-) diff --git a/src/main/java/com/zy/asrs/controller/LocMastController.java b/src/main/java/com/zy/asrs/controller/LocMastController.java index d2d4f7d..757a36f 100644 --- a/src/main/java/com/zy/asrs/controller/LocMastController.java +++ b/src/main/java/com/zy/asrs/controller/LocMastController.java @@ -10,19 +10,18 @@ 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.LocMast; +import com.core.exception.CoolException; +import com.zy.asrs.entity.*; import com.zy.asrs.entity.param.LocMastInitParam; -import com.zy.asrs.service.LocDetlService; -import com.zy.asrs.service.LocMastService; -import com.zy.asrs.utils.Utils; +import com.zy.asrs.mapper.LocDetlMapper; +import com.zy.asrs.service.*; import com.zy.common.entity.Parameter; import com.zy.common.model.Shelves; import com.zy.common.web.BaseController; import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.transaction.annotation.Transactional; import org.springframework.web.bind.annotation.*; +import javax.annotation.Resource; import java.util.*; @RestController @@ -32,6 +31,17 @@ private LocMastService locMastService; @Autowired private LocDetlService locDetlService; + @Autowired + private BasWhsService basWhsService; + + @Resource + private WrkMastService wrkMastService; + + @Resource + private AdjDetlService adjDetlService; + + @Resource + private LocDetlMapper locDetlMapper; @RequestMapping(value = "/locMast/init/pwd") public R locMastInitPwd(@RequestParam(required = false) String pwd) { @@ -68,15 +78,24 @@ } private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){ + boolean sign = false; 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); wrapper.ge(entry.getKey(), DateUtils.convert(dates[0])); wrapper.le(entry.getKey(), DateUtils.convert(dates[1])); - } else { + } else if (entry.getKey().equals("loc_no")){ wrapper.like(entry.getKey(), val); + } else { + if (entry.getKey().equals("loc_type1")){ + sign=true; + } + wrapper.eq(entry.getKey(), val); } + } + if (sign){ + wrapper.and().ne("loc_sts","Y"); } } @@ -94,22 +113,67 @@ @RequestMapping(value = "/locMast/update/auth") @ManagerAuth(memo = "搴撲綅淇敼") public R update(LocMast locMast){ + 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("璇ュ簱浣嶆鍦ㄤ綔涓氾紝璇峰厛澶勭悊宸ヤ綔妗�"); + } + LocMast oldLocMast = locMastService.selectById(locMast.getLocNo()); if (locMast.getLocSts().equals("F") && (oldLocMast.getLocSts().equals("D") || oldLocMast.getLocSts().equals("O"))) { return R.error("褰撳墠鎿嶄綔宸茶闃绘锛岃鑱旂郴绠$悊鍛�"); } + Date now = new Date(); // 鏈夌墿鏂欐椂淇敼涓虹┖搴撲綅鎴栬�呯┖鏉垮簱浣嶏紝鍒欏垹闄ゅ簱瀛樻槑缁� - if (oldLocMast.getLocSts().equals("R") || oldLocMast.getLocSts().equals("F")) { + if (oldLocMast.getLocSts().equals("R") || oldLocMast.getLocSts().equals("F") || oldLocMast.getLocSts().equals("S")) { if (locMast.getLocSts().equals("O") || locMast.getLocSts().equals("D")) { - locDetlService.delete(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo())); + List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo())); + for (LocDetl locDetl : locDetls) { + // 淇濆瓨璋冩暣璁板綍 + AdjDetl adjDetl = new AdjDetl(); + adjDetl.setLocNo(locDetl.getLocNo()); + adjDetl.setMatnr(locDetl.getMatnr()); + adjDetl.setBatch(locDetl.getBatch()); + adjDetl.setOriQty(locDetl.getAnfme()); + adjDetl.setAdjQty(0.0D); + adjDetl.setModiTime(now); + adjDetl.setModiUser(getUserId()); + adjDetl.setAppeTime(now); + adjDetl.setAppeUser(getUserId()); + if (!adjDetlService.insert(adjDetl)) { + throw new CoolException("鏈嶅姟鍣ㄩ敊璇紝璇疯仈绯荤鐞嗗憳"); + } + } + if (!locDetlService.delete(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo()))) { + throw new CoolException("鏈嶅姟鍣ㄩ敊璇紝璇疯仈绯荤鐞嗗憳"); + } + locMast.setBarcode(""); } } locMast.setModiUser(getUserId()); - locMast.setModiTime(new Date()); - locMastService.updateById(locMast); + locMast.setModiTime(now); + AdjDetl adjDetl = new AdjDetl(); + adjDetl.setLocNo(locMast.getLocNo()); + adjDetl.setMatnr("鍘熷簱浣嶇姸鎬侊細" + oldLocMast.getLocSts()); + adjDetl.setBatch("鏇存敼搴撲綅鐘舵�佷负锛�" + locMast.getLocSts()); + adjDetl.setModiTime(now); + adjDetl.setModiUser(getUserId()); + if (!adjDetlService.insert(adjDetl)) { + throw new CoolException("搴撲綅璋冩暣璁板綍澶辫触"); + } + // 搴撲綅鍐荤粨->鍐荤粨鎵�鏈夊簱瀛� + if (locMast.getFrozen() == 1 && oldLocMast.getFrozen() == 0 && locMast.getLocSts().equals("F") && oldLocMast.getLocSts().equals("F")) { + locDetlMapper.updateDetlFrozenByLocNo(oldLocMast.getLocNo()); + } + if(!locMastService.updateById(locMast)) { + throw new CoolException("鏈嶅姟鍣ㄩ敊璇紝璇疯仈绯荤鐞嗗憳"); + } return R.ok(); } @@ -167,95 +231,65 @@ @ManagerAuth(memo = "鍒濆鍖栧簱浣�") // @Transactional public R init(LocMastInitParam param) { - List<LocMast> list = new ArrayList<>(); - 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; - Shelves shelves = new Shelves(param.getEndRow() - param.getStartRow() + 1, param.getCrnAmount()); - for (List<Integer> node : shelves.nodes){ - if (node.contains(r)) { - crnNo = shelves.nodes.indexOf(node) + 1; - break; + try{ + List<LocMast> list = new ArrayList<>(); + BasWhs basWhs = basWhsService.selectByIdentifying(param.getIdentifying()); + if (Cools.isEmpty(basWhs)){ + 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++) { + // 鑾峰彇搴撲綅鍙� + 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){ + + if (node.contains(r)) { + if (!Cools.isEmpty(param.getStaCrn()) && param.getStaCrn() > 0){ + crnNo = shelves.nodes.indexOf(node) + param.getStaCrn(); + }else { + crnNo = shelves.nodes.indexOf(node) + 1; + } + + break; + } + } + }catch (Exception e){ + throw new Exception("瑙f瀽鍫嗗灈鏈哄彿澶辫触锛岃濉啓姝g‘鐨勬暟鎹�!!!"); } + + Date now = new Date(); + LocMast locMast = new LocMast(); + locMast.setLocNo(locNo); + locMast.setLocSts("O"); + locMast.setRow1(r); // 鎺� + locMast.setBay1(b); // 鍒� + locMast.setLev1(l); // 灞� + locMast.setGro1(r); // 缁� + locMast.setCrnNo(crnNo); // 鍫嗗灈鏈� + locMast.setLocType1(!Cools.isEmpty(param.getLocType1()) ? param.getLocType1() : 1); + locMast.setLocType2(param.getLocType2()); + locMast.setLocType3(param.getLocType3()); + locMast.setAppeUser(getUserId()); + locMast.setAppeTime(now); + locMast.setModiUser(getUserId()); + locMast.setModiTime(now); + locMast.setWhsType(basWhs.getId()); + list.add(locMast); } - Date now = new Date(); - LocMast locMast = new LocMast(); - locMast.setLocNo(locNo); - locMast.setLocSts("O"); - locMast.setRow1(r); // 鎺� - locMast.setBay1(b); // 鍒� - locMast.setLev1(l); // 灞� - locMast.setCrnNo(crnNo); // 鍫嗗灈鏈� - locMast.setLocType1(!Cools.isEmpty(param.getLocType1()) ? param.getLocType1() : 1); - locMast.setLocType2(param.getLocType2()); - locMast.setLocType3(param.getLocType3()); - locMast.setAppeUser(getUserId()); - locMast.setAppeTime(now); - locMast.setModiUser(getUserId()); - locMast.setModiTime(now); - list.add(locMast); } } + 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()); } - locMastService.delete(new EntityWrapper<>()); - locDetlService.delete(new EntityWrapper<>()); - locMastService.insertBatch(list); - return R.ok("鍒濆鍖栨垚鍔�"); - } - - @RequestMapping(value = "/locMast/convert/size/auth") - @ManagerAuth(memo = "澶у皬搴撲綅杞崲") - @Transactional - public R convertSize(@RequestParam String param) { - List<LocMast> list = JSONArray.parseArray(param, LocMast.class); - if (Cools.isEmpty(list)){ - return R.error(); - } - for (LocMast entity : list){ - if (!entity.getCrnNo().equals(1) && !entity.getCrnNo().equals(4)){ - return R.error("璇烽�夋嫨1鍙枫��4鍙峰爢鍨涙満鐨勮揣浣嶏紒锛侊紒涓嶇鍚堟潯浠跺簱浣嶏細"+entity.getLocNo()); - } - if (!entity.getLocSts().equals("O") && !entity.getLocSts().equals("Y")){ - return R.error("璇烽�夋嫨绌洪棽銆佽鍚堝苟鐨勮揣浣嶏紒锛侊紒涓嶇鍚堟潯浠跺簱浣嶏細"+entity.getLocNo()); - } - } - List<String> innermostSideLoc = Utils.getInnermostSideLoc(list); - StringBuilder msg=new StringBuilder(); - for (String locNo : innermostSideLoc){ - String innermostSideLocLBR = Utils.getInnermostSideLocLBR(locNo); - LocMast locMast1 = locMastService.selectById(innermostSideLocLBR);//娴� - if (Cools.isEmpty(locMast1)){ - msg.append("璇烽�夋嫨娴呭簱浣嶅瓨鍦ㄧ殑璐т綅锛侊紒锛佷笉绗﹀悎鏉′欢搴撲綅锛�").append(innermostSideLocLBR).append("/n"); - continue; - } - if (!locMast1.getLocSts().equals("O")){ - msg.append("璇烽�夋嫨娴呭簱浣嶇┖闂茬殑璐т綅锛侊紒锛佷笉绗﹀悎鏉′欢搴撲綅锛�").append(locMast1.getLocNo()).append("/n"); - continue; - } - LocMast locMast = locMastService.selectById(locNo);//娣� - if (Cools.isEmpty(locMast)){ - msg.append("璇烽�夋嫨娣卞簱浣嶅瓨鍦ㄧ殑璐т綅锛侊紒锛佷笉绗﹀悎鏉′欢搴撲綅锛�").append(locNo).append("/n"); - continue; - } - if (!Cools.isEmpty(locMast) && locMast.getLocSts().equals("O")){ - locMast1.setLocType1((short)2); - locMast.setLocType1((short)2); - locMast.setLocSts("Y"); - }else if (!Cools.isEmpty(locMast) && locMast.getLocSts().equals("Y")){ - locMast1.setLocType1((short)1); - locMast.setLocType1((short)1); - locMast.setLocSts("O"); - }else { - msg.append("璇烽�夋嫨娣卞簱浣嶅簱浣嶇┖闂层�佽鍚堝苟鐨勮揣浣嶏紒锛侊紒涓嶇鍚堟潯浠跺簱浣嶏細").append(locMast.getLocNo()).append("/n"); - continue; - } - locMastService.updateById(locMast1); - locMastService.updateById(locMast); - } - return R.ok(msg); } } -- Gitblit v1.9.1