| | |
| | | import com.zy.common.web.BaseController; |
| | | import io.swagger.models.auth.In; |
| | | import lombok.Synchronized; |
| | | import org.slf4j.Logger; |
| | | import org.slf4j.LoggerFactory; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import org.springframework.web.bind.annotation.*; |
| | |
| | | @RequestMapping("agvMobile") |
| | | public class AgvMobileController extends BaseController { |
| | | |
| | | |
| | | private static final Logger log = LoggerFactory.getLogger(AgvMobileController.class); |
| | | @Autowired |
| | | private AgvMobileService agvMobileService; |
| | | @Autowired |
| | |
| | | } |
| | | |
| | | /* |
| | | 启动入库,组托 + 生产工作档 |
| | | 启动入库,组托 + 生成工作档 |
| | | */ |
| | | @PostMapping("/start/pakin/auth") |
| | | @Synchronized |
| | |
| | | String matnr = params.get("matnr"); |
| | | String floor = params.get("floor"); |
| | | |
| | | Wrapper<AgvLocDetl> wrapper = new EntityWrapper<AgvLocDetl>().eq("matnr", matnr); |
| | | Wrapper<AgvLocDetl> wrapper = new EntityWrapper<AgvLocDetl>().eq("matnr", matnr).ne("process_sts",1); |
| | | |
| | | |
| | | // wrapper.eq("orderNo",orderNo); |
| | | |
| | | wrapper = Cools.isEmpty(threeCode) ? wrapper.isNull("three_code") : wrapper.eq("three_code",threeCode); |
| | | |
| | | if (threeCode.substring(0,2).equals(30)) { |
| | | wrapper.isNull("specs").or().eq("specs","").eq("floor",1); |
| | | } |
| | | List<AgvLocDetl> agvLocDetls = agvLocDetlService.selectList(wrapper); |
| | | List<AgvLocDetl> locDetls = new ArrayList<>(); |
| | | for (AgvLocDetl agvLocDetl : agvLocDetls) { |
| | | AgvLocMast agvLocMast = new AgvLocMast(); |
| | | if (Cools.isEmpty(floor)) { |
| | | agvLocMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", agvLocDetl.getLocNo()).notLike("loc_no","F1")); |
| | | } else { |
| | | // 如果是加工单 只在 lev1 = 1 查库存 |
| | | if ("JG".equals(orderNo.substring(0,2))) { |
| | | agvLocMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("lev1",1).eq("loc_no", agvLocDetl.getLocNo()).like("loc_no",floor)); |
| | | } else { |
| | | agvLocMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", agvLocDetl.getLocNo()).like("loc_no",floor)); |
| | | } |
| | | } |
| | | |
| | | if (Cools.isEmpty(agvLocMast)) continue; |
| | | agvLocDetl.setLocSts(agvLocMast.getLocSts()); |
| | | agvLocDetl.setLocSts$(agvLocMast.getLocSts$()); |
| | | locDetls.add(agvLocDetl); |
| | | } |
| | | |
| | | |
| | | return R.ok(locDetls); |
| | | } |
| | | |
| | | /* |
| | | 查询库存 入库订单与销售单号 |
| | | */ |
| | | @PostMapping("/query/locDetl/v3") |
| | | public R queryAgvLocDetl3(@RequestBody HashMap<String,String> params){ |
| | | |
| | | String orderNo = params.get("orderNo"); |
| | | String threeCode = params.get("threeCode"); |
| | | String matnr = params.get("matnr"); |
| | | String floor = params.get("floor"); |
| | | |
| | | Wrapper<AgvLocDetl> wrapper = new EntityWrapper<AgvLocDetl>().eq("matnr", matnr).ne("process_sts",1); |
| | | |
| | | |
| | | // wrapper.eq("orderNo",orderNo); |
| | | |
| | |
| | | agvLocMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", agvLocDetl.getLocNo()).notLike("loc_no","F1")); |
| | | } else { |
| | | agvLocMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", agvLocDetl.getLocNo()).like("loc_no",floor)); |
| | | } |
| | | |
| | | if (Cools.isEmpty(agvLocMast)) continue; |
| | | agvLocDetl.setLocSts(agvLocMast.getLocSts()); |
| | | agvLocDetl.setLocSts$(agvLocMast.getLocSts$()); |
| | | locDetls.add(agvLocDetl); |
| | | } |
| | | |
| | | |
| | | return R.ok(locDetls); |
| | | } |
| | | |
| | | /* |
| | | 查询库存 入库订单与销售单号 |
| | | */ |
| | | @PostMapping("/query/locDetl/v2") |
| | | public R queryAgvLocDetl2(@RequestBody HashMap<String,String> params){ |
| | | |
| | | String orderNo = params.get("orderNo"); |
| | | String threeCode = params.get("threeCode"); |
| | | String matnr = params.get("matnr"); |
| | | String floor = params.get("floor"); |
| | | |
| | | OrderDetl orderDetl = orderDetlService.selectOne(new EntityWrapper<OrderDetl>().eq("order_no", orderNo).eq("three_code", threeCode).eq("matnr", matnr)); |
| | | Wrapper<AgvLocDetl> wrapper = new EntityWrapper<AgvLocDetl>().eq("matnr", matnr); |
| | | |
| | | |
| | | // wrapper.eq("orderNo",orderNo); |
| | | |
| | | wrapper = Cools.isEmpty(threeCode) ? wrapper.isNull("three_code") : wrapper.eq("three_code",threeCode); |
| | | |
| | | if (threeCode.substring(0,2).equals(30)) { |
| | | wrapper.isNull("specs").or().eq("specs","").eq("floor",1); |
| | | } |
| | | List<AgvLocDetl> agvLocDetls = agvLocDetlService.selectList(wrapper); |
| | | List<AgvLocDetl> locDetls = new ArrayList<>(); |
| | | for (AgvLocDetl agvLocDetl : agvLocDetls) { |
| | | AgvLocMast agvLocMast = new AgvLocMast(); |
| | | if (Cools.isEmpty(floor)) { |
| | | agvLocMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", agvLocDetl.getLocNo()).notLike("loc_no","F1")); |
| | | } else { |
| | | // 如果是加工单 只在 lev1 = 1 查库存 |
| | | if (orderDetl.getSource().equals(35)) { |
| | | agvLocMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("lev1",1).eq("loc_no", agvLocDetl.getLocNo()).like("loc_no",floor)); |
| | | } else { |
| | | agvLocMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", agvLocDetl.getLocNo()).like("loc_no",floor)); |
| | | } |
| | | } |
| | | |
| | | if (Cools.isEmpty(agvLocMast)) continue; |
| | |
| | | |
| | | |
| | | |
| | | if((!Cools.eq("F",agvLocMastByContainerCode.getLocSts()) |
| | | && !Cools.eq("D",agvLocMastByContainerCode.getLocSts())) |
| | | || (!Cools.eq("F",agvLocMastByLocNo.getLocSts()) |
| | | if((!Cools.eq("F",agvLocMastByLocNo.getLocSts()) |
| | | && !Cools.eq("D",agvLocMastByLocNo.getLocSts()))){ |
| | | |
| | | return R.error("库位状态不为F或者D,无法维护"); |
| | |
| | | } |
| | | |
| | | if((listByLocNo == null && listByContainerCode == null) || listByLocNo.equals(listByContainerCode)){ |
| | | return R.ok("该库位与货架库存一致,无需维护"); |
| | | //agvLocMastByContainerCode.setBarcode(agvLocMastByLocNo.getBarcode()); |
| | | //agvLocMastService.updateById(agvLocMastByContainerCode); |
| | | |
| | | agvLocMastByLocNo.setBarcode(containerCode); |
| | | agvLocMastService.updateById(agvLocMastByLocNo); |
| | | //return R.ok("该库位与货架库存一致,无需维护"); |
| | | return R.ok("维护成功"); |
| | | } |
| | | |
| | | |
| | |
| | | if (mT.equals("unAuto")) { |
| | | moveType = "2"; |
| | | ioType = 111; |
| | | //int count = agvWrkMastService.selectCount(new EntityWrapper<AgvWrkMast>().eq("io_type", ioType)); |
| | | //if (count>3){ |
| | | // log.equals("111任务堵塞,稍后再试!!!当前限制数量3条,限制条件:io_type = 111"); |
| | | // throw new CoolException("111任务堵塞,稍后再试!"); |
| | | //} |
| | | } else { |
| | | moveType = "1"; |
| | | ioType = 108; |
| | |
| | | AgvWrkMast source_loc_no = agvWrkMastService.selectOne(new EntityWrapper<AgvWrkMast>().eq("source_loc_no", locNo)); |
| | | if (!Cools.isEmpty(source_loc_no)) { |
| | | throw new CoolException("当前库位已生成任务!"); |
| | | } |
| | | AgvLocMast locMastS = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", locNo).eq("loc_sts","F")); |
| | | if (Cools.isEmpty(locMastS)) { |
| | | throw new CoolException("当前库位非在库状态!库位号="+locNo); |
| | | } |
| | | AgvWrkMast wrkMast = createWrkMast(ioType, 22L, locNo, "", barcode, now, getUserId(), 30,floor); |
| | | // 同步调拨单 |
| | |
| | | throw new CoolException("保存工作明细失败"); |
| | | } |
| | | // 更新订单 |
| | | OrderDetl orderDetl = orderDetlService.selectOne(new EntityWrapper<OrderDetl>().eq("order_no", "DB" + agvLocDetl.getOrderNo()).eq("matnr", agvLocDetl.getMatnr()).eq("three_code",agvLocDetl.getThreeCode())); |
| | | OrderDetl orderDetl = orderDetlService.selectOne(new EntityWrapper<OrderDetl>().eq("source",33).eq("matnr", agvLocDetl.getMatnr()).eq("three_code",agvLocDetl.getThreeCode())); |
| | | orderDetl.setQty(orderDetl.getQty() + agvLocDetl.getAnfme()); |
| | | if (!orderDetlService.update(orderDetl,new EntityWrapper<OrderDetl>().eq("order_no","DB" + agvLocDetl.getOrderNo()).eq("matnr", agvLocDetl.getMatnr()).eq("three_code",agvLocDetl.getThreeCode()))){ |
| | | if (!orderDetlService.update(orderDetl,new EntityWrapper<OrderDetl>().eq("source",33).eq("matnr", agvLocDetl.getMatnr()).eq("three_code",agvLocDetl.getThreeCode()))){ |
| | | throw new CoolException("修改订单明细失败,请联系管理员"+agvLocDetl.getOrderNo()+agvLocDetl.getMatnr()); |
| | | } |
| | | } |
| | | // 更新源库位 |
| | | AgvLocMast locMast = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", locNo)); |
| | | locMast.setLocSts("R"); |
| | | agvLocMastService.updateById(locMast); |
| | | } |
| | | return R.ok(); |
| | | } |
| | | |
| | | @PostMapping("/agv/v3/locMove") |
| | | @Transactional |
| | | @ManagerAuth(memo = "回调单任务下发") |
| | | @Synchronized |
| | | public R agvLocMove3(@RequestBody HashMap<String,Object> params){ |
| | | Date now = new Date(); |
| | | List<HashMap<String,String>> dbList = (List<HashMap<String, String>>) params.get("dbList"); |
| | | params.get("dbList"); |
| | | for (HashMap<String, String> map : dbList) { |
| | | String locNo = map.get("locNo"); |
| | | String barcode = map.get("suppCode"); |
| | | AgvWrkMast source_loc_no = agvWrkMastService.selectOne(new EntityWrapper<AgvWrkMast>().eq("source_loc_no", locNo)); |
| | | if (!Cools.isEmpty(source_loc_no)) { |
| | | throw new CoolException("当前库位已生成任务!"); |
| | | } |
| | | AgvLocMast locMastS = agvLocMastService.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_no", locNo).eq("loc_sts","F")); |
| | | if (Cools.isEmpty(locMastS)) { |
| | | throw new CoolException("当前库位非在库状态!库位号="+locNo); |
| | | } |
| | | AgvWrkMast wrkMast = createWrkMast(114, 22L, locNo, "", barcode, now, getUserId(), 30,1); |
| | | // 同步调拨单 |
| | | List<AgvLocDetl> agvLocDetls = agvLocDetlService.selectList(new EntityWrapper<AgvLocDetl>().eq("loc_no", locNo)); |
| | | for (AgvLocDetl agvLocDetl : agvLocDetls) { |
| | | AgvWrkDetl wrkDetl = new AgvWrkDetl(); |
| | | wrkDetl.setWrkNo(wrkMast.getWrkNo()); |
| | | wrkDetl.sync(agvLocDetl); |
| | | wrkDetl.setSuppCode(agvLocDetl.getSuppCode()); |
| | | wrkDetl.setIoTime(now); |
| | | wrkDetl.setAppeUser(getUserId()); |
| | | wrkDetl.setAppeTime(now); |
| | | wrkDetl.setModiUser(getUserId()); |
| | | wrkDetl.setModiTime(now); |
| | | if (!agvWrkDetlService.insert(wrkDetl)) { |
| | | throw new CoolException("保存工作明细失败"); |
| | | } |
| | | // 更新订单 |
| | | // 先查询库订单明细 所属的订单 |
| | | |
| | | OrderDetl orderDetl = orderDetlService.selectOne(new EntityWrapper<OrderDetl>().eq("source",36).eq("matnr", agvLocDetl.getMatnr()).eq("three_code",agvLocDetl.getThreeCode())); |
| | | orderDetl.setQty(orderDetl.getQty() + agvLocDetl.getAnfme()); |
| | | if (!orderDetlService.update(orderDetl,new EntityWrapper<OrderDetl>().eq("source",36).eq("matnr", agvLocDetl.getMatnr()).eq("three_code",agvLocDetl.getThreeCode()))){ |
| | | throw new CoolException("修改订单明细失败,请联系管理员"+agvLocDetl.getOrderNo()+agvLocDetl.getMatnr()); |
| | | } |
| | | } |
| | |
| | | @ManagerAuth(memo = "站点回退") |
| | | @Synchronized |
| | | public R doBack(@RequestBody AgvMobileStartPakin param){ |
| | | if (Cools.isEmpty(param)){ |
| | | return R.error("参数为空"); |
| | | } |
| | | agvMobileService.doBack(param, getUserId()); |
| | | return R.ok(); |
| | | } |
| | |
| | | return R.ok(); |
| | | } |
| | | |
| | | @PostMapping("/hand/control/processed") |
| | | @Transactional |
| | | @ManagerAuth(memo = "确认加工完成") |
| | | @Synchronized |
| | | public R processed(@RequestBody AgvMobileStartPakin param){ |
| | | agvMobileService.processed(param, getUserId()); |
| | | return R.ok(); |
| | | } |
| | | |
| | | |
| | | public static void main(String[] args) { |
| | | List<AgvLocDetl> agvLocDetls1 = new ArrayList<>(); |
| | | List<AgvLocDetl> agvLocDetls2 = new ArrayList<>(); |