From 035ecbe3a3540011f29a8f2287aead232749aaad Mon Sep 17 00:00:00 2001 From: zc <zc@123> Date: 星期六, 19 四月 2025 10:38:25 +0800 Subject: [PATCH] qw --- src/main/java/com/zy/asrs/controller/LocMastController.java | 159 ++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 122 insertions(+), 37 deletions(-) diff --git a/src/main/java/com/zy/asrs/controller/LocMastController.java b/src/main/java/com/zy/asrs/controller/LocMastController.java index 8ece97a..37db305 100644 --- a/src/main/java/com/zy/asrs/controller/LocMastController.java +++ b/src/main/java/com/zy/asrs/controller/LocMastController.java @@ -10,10 +10,16 @@ import com.core.common.Cools; import com.core.common.DateUtils; import com.core.common.R; +import com.zy.asrs.entity.BasWhs; +import com.zy.asrs.entity.LocDetl; import com.zy.asrs.entity.LocMast; import com.zy.asrs.entity.param.LocMastInitParam; +import com.zy.asrs.service.BasWhsService; +import com.zy.asrs.service.LocDetlService; import com.zy.asrs.service.LocMastService; +import com.zy.common.entity.Parameter; import com.zy.common.model.Shelves; +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.*; @@ -25,6 +31,24 @@ @Autowired private LocMastService locMastService; + @Autowired + private LocDetlService locDetlService; + @Autowired + private BasWhsService basWhsService; + + @RequestMapping(value = "/locMast/init/pwd") + public R locMastInitPwd(@RequestParam(required = false) String pwd) { + if (Cools.isEmpty(pwd)) { + return R.error("璇疯緭鍏ュ彛浠�"); + } + return R.ok().add(Parameter.get().getLocMastInitPwd().equals(pwd)); + } + + @PostMapping(value = "/group/empty/stock") + @ManagerAuth(memo = "鑾峰彇鍚岀粍璐ф灦鐨勭┖搴撲綅") + public R getGroupEmptyStock(@RequestParam(required = false) String sourceLocNo) { + return R.ok().add(locMastService.queryGroupEmptyStock(sourceLocNo)); + } @RequestMapping(value = "/locMast/{id}/auth") @ManagerAuth @@ -42,19 +66,46 @@ excludeTrash(param); EntityWrapper<LocMast> wrapper = new EntityWrapper<>(); convert(param, wrapper); + // 涓嶅悓缁ф壙瑙掕壊鏄剧ず涓嶅悓搴撲俊鎭� + RoleUtils.addRoleWrapperByCrn(getUserId(),wrapper); if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));} return R.ok(locMastService.selectPage(new Page<>(curr, limit), wrapper)); } - private void convert(Map<String, Object> map, EntityWrapper wrapper){ + @RequestMapping(value = "/locMast/crn/list/auth") + @ManagerAuth + public R crnList(@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); + wrapper.in("crn_no", 1,2); + 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){ + boolean sign = false; for (Map.Entry<String, Object> entry : map.entrySet()){ - if (entry.getKey().endsWith(">")) { - wrapper.ge(Cools.deleteChar(entry.getKey()), DateUtils.convert(String.valueOf(entry.getValue()))); - } else if (entry.getKey().endsWith("<")) { - wrapper.le(Cools.deleteChar(entry.getKey()), DateUtils.convert(String.valueOf(entry.getValue()))); + 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 if (entry.getKey().equals("loc_no")){ + wrapper.like(entry.getKey(), val); } else { - wrapper.like(entry.getKey(), String.valueOf(entry.getValue())); + if (entry.getKey().equals("loc_type1")){ + sign=true; + } + wrapper.eq(entry.getKey(), val); } + } + if (sign){ + wrapper.and().ne("loc_sts","Y"); } } @@ -74,6 +125,16 @@ public R update(LocMast locMast){ if (Cools.isEmpty(locMast) || null==locMast.getLocNo()){ 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("褰撳墠鎿嶄綔宸茶闃绘锛岃鑱旂郴绠$悊鍛�"); + } + // 鏈夌墿鏂欐椂淇敼涓虹┖搴撲綅鎴栬�呯┖鏉垮簱浣嶏紝鍒欏垹闄ゅ簱瀛樻槑缁� + if (oldLocMast.getLocSts().equals("R") || oldLocMast.getLocSts().equals("F")) { + if (locMast.getLocSts().equals("O") || locMast.getLocSts().equals("D")) { + locDetlService.delete(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo())); + } } locMast.setModiUser(getUserId()); locMast.setModiTime(new Date()); @@ -135,41 +196,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); } - LocMast locMast = new LocMast(); - locMast.setLocNo(locNo); - locMast.setLocType("O"); - locMast.setRow1(r); // 鎺� - locMast.setBay1(b); // 鍒� - locMast.setLev1(l); // 灞� - locMast.setCrnNo(crnNo); // 鍫嗗灈鏈� - if (null != param.getWhsType()) { - locMast.setWhsType(Long.valueOf(param.getWhsType())); - } - locMast.setAppeUser(getUserId()); - locMast.setAppeTime(new Date()); - locMast.setModiUser(getUserId()); - locMast.setModiTime(new Date()); - 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<>()); - locMastService.insertBatch(list); - return R.ok("鍒濆鍖栨垚鍔�"); } } -- Gitblit v1.9.1