|  |  |  | 
|---|
|  |  |  | import com.zy.asrs.common.domain.entity.StaDesc; | 
|---|
|  |  |  | import com.zy.asrs.common.domain.enums.IoWorkType; | 
|---|
|  |  |  | import com.zy.asrs.common.domain.enums.WorkNoType; | 
|---|
|  |  |  | import com.zy.asrs.common.domain.param.EmptyPlateOutParam; | 
|---|
|  |  |  | import com.zy.asrs.common.domain.param.FullStoreParam; | 
|---|
|  |  |  | import com.zy.asrs.common.domain.param.LocDetlAdjustParam; | 
|---|
|  |  |  | import com.zy.asrs.common.domain.param.StockOutParam; | 
|---|
|  |  |  | import com.zy.asrs.common.sys.service.StaDescService; | 
|---|
|  |  |  | import com.zy.asrs.common.utils.Utils; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  | import java.util.concurrent.TimeUnit; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * Created by vincent on 2020/6/11 | 
|---|
|  |  |  | 
|---|
|  |  |  | private StaDescService staDescService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private LocDetlService locDetlService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private AdjDetlService adjDetlService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OrderService orderService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | LocTypeDto locTypeDto = new LocTypeDto(); | 
|---|
|  |  |  | StartupDto dto = commonService.getLocNo(1, param.getDevpNo(), hostId, locTypeDto, 0); | 
|---|
|  |  |  | locTypeDto.setLocType1(param.getLocType1()); | 
|---|
|  |  |  | locTypeDto.setLocRangeDto(param.getLocRangeDto()); | 
|---|
|  |  |  | List<String> matnrs = param.getList().stream().map(FullStoreParam.MatCodeStore::getMatnr).distinct().collect(Collectors.toList()); | 
|---|
|  |  |  | String batch = param.getList().get(0).getBatch(); | 
|---|
|  |  |  | StartupDto dto = commonService.getLocNo(1, param.getDevpNo(), matnrs, batch, hostId, locTypeDto, 0); | 
|---|
|  |  |  | // 生成工作号 | 
|---|
|  |  |  | int workNo = dto.getWorkNo(); | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | 
|---|
|  |  |  | wrkMast.setModiUser(String.valueOf(userId)); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | wrkMast.setHostId(hostId); | 
|---|
|  |  |  | wrkMast.setCrnNo(dto.getCrnNo()); | 
|---|
|  |  |  | if (!wrkMastService.save(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public String emptyPlateIn(Integer devpNo, Long userId, Long hostId) { | 
|---|
|  |  |  | // 源站点状态检测 | 
|---|
|  |  |  | BasDevp sourceStaNo = basDevpService.checkSiteStatus(devpNo, true, hostId); | 
|---|
|  |  |  | // 检索库位 | 
|---|
|  |  |  | LocTypeDto locTypeDto = new LocTypeDto(sourceStaNo); | 
|---|
|  |  |  | StartupDto dto = commonService.getLocNo(10, devpNo, null, null, hostId, locTypeDto, 0); | 
|---|
|  |  |  | int workNo = dto.getWorkNo(); | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setIoTime(new Date()); | 
|---|
|  |  |  | wrkMast.setWrkSts(1L); // 工作状态:生成入库ID | 
|---|
|  |  |  | wrkMast.setIoType(10); // 入出库状态:10.空板入库 | 
|---|
|  |  |  | wrkMast.setIoPri(13D); // 优先级:13 | 
|---|
|  |  |  | wrkMast.setCrnNo(dto.getCrnNo()); | 
|---|
|  |  |  | wrkMast.setSourceStaNo(dto.getSourceStaNo()); | 
|---|
|  |  |  | wrkMast.setStaNo(dto.getStaNo()); | 
|---|
|  |  |  | wrkMast.setLocNo(dto.getLocNo()); | 
|---|
|  |  |  | wrkMast.setFullPlt("N"); // 满板 | 
|---|
|  |  |  | wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk("Y"); // 空板 | 
|---|
|  |  |  | wrkMast.setCtnType(sourceStaNo.getCtnType()); // 容器类型 | 
|---|
|  |  |  | // 操作人员数据 | 
|---|
|  |  |  | wrkMast.setAppeUser(String.valueOf(userId)); | 
|---|
|  |  |  | wrkMast.setAppeTime(new Date()); | 
|---|
|  |  |  | wrkMast.setModiUser(String.valueOf(userId)); | 
|---|
|  |  |  | wrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | wrkMast.setHostId(hostId); | 
|---|
|  |  |  | boolean res = wrkMastService.save(wrkMast); | 
|---|
|  |  |  | if (!res) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 更新源站点信息 | 
|---|
|  |  |  | sourceStaNo.setWrkNo(workNo); | 
|---|
|  |  |  | sourceStaNo.setModiUser(userId); | 
|---|
|  |  |  | sourceStaNo.setModiTime(new Date()); | 
|---|
|  |  |  | if (!basDevpService.updateById(sourceStaNo)){ | 
|---|
|  |  |  | throw new CoolException("更新源站失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 更新目标库位状态 | 
|---|
|  |  |  | LocMast locMast = locMastService.getOne(new LambdaQueryWrapper<LocMast>() | 
|---|
|  |  |  | .eq(LocMast::getLocNo, dto.getLocNo()) | 
|---|
|  |  |  | .eq(LocMast::getHostId, hostId)); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("O")){ | 
|---|
|  |  |  | locMast.setLocSts("S"); // S.入库预约 | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(new Date()); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)){ | 
|---|
|  |  |  | throw new CoolException("改变库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException(dto.getLocNo()+"目标库位已被占用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return dto.getLocNo(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void startupFullTakeStore(StockOutParam param, Long userId, Long hostId) { | 
|---|
|  |  |  | // 获取库位明细 | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void emptyPlateOut(EmptyPlateOutParam param, Long userId, Long hostId) { | 
|---|
|  |  |  | if (Cools.isEmpty(param.getOutSite())) { | 
|---|
|  |  |  | throw new CoolException("站点不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (String locNo : param.getLocNos()) { | 
|---|
|  |  |  | // 获取工作号 | 
|---|
|  |  |  | int workNo = commonService.getWorkNo(WorkNoType.PAKOUT.type); | 
|---|
|  |  |  | // 获取库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.getOne(new LambdaQueryWrapper<LocMast>() | 
|---|
|  |  |  | .eq(LocMast::getLocNo, locNo) | 
|---|
|  |  |  | .eq(LocMast::getHostId, hostId)); | 
|---|
|  |  |  | if (Cools.isEmpty(locMast)) { | 
|---|
|  |  |  | throw new CoolException(locNo+"库位不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!locMast.getLocSts().equals("D")){ | 
|---|
|  |  |  | throw new CoolException("所选库位存在状态不为D的库位,库位号:"+locMast.getLocNo()+" 、当前状态:"+locMast.getLocSts()+"-"+locMast.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 获取源站 | 
|---|
|  |  |  | StaDesc staDesc = staDescService.getOne(new LambdaQueryWrapper<StaDesc>() | 
|---|
|  |  |  | .eq(StaDesc::getTypeNo, 110) | 
|---|
|  |  |  | .eq(StaDesc::getStnNo, param.getOutSite()) | 
|---|
|  |  |  | .eq(StaDesc::getDeviceNo, locMast.getCrnNo())); | 
|---|
|  |  |  | Integer sourceStaNo = staDesc.getDeviceStn(); | 
|---|
|  |  |  | if (Cools.isEmpty(sourceStaNo)) { | 
|---|
|  |  |  | throw new CoolException("检索源站失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 保存工作档 | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setIoTime(now); | 
|---|
|  |  |  | wrkMast.setWrkSts(101L); // 工作状态:101.生成出库ID | 
|---|
|  |  |  | wrkMast.setIoType(110); // 入出库状态: 110.空板出库 | 
|---|
|  |  |  | wrkMast.setIoPri(10D); | 
|---|
|  |  |  | wrkMast.setSourceStaNo(sourceStaNo); // 源站 | 
|---|
|  |  |  | wrkMast.setStaNo(param.getOutSite()); // 目标站 | 
|---|
|  |  |  | wrkMast.setCrnNo(locMast.getCrnNo()); | 
|---|
|  |  |  | wrkMast.setSourceLocNo(locNo); // 源库位 | 
|---|
|  |  |  | wrkMast.setFullPlt("N"); // 满板:Y | 
|---|
|  |  |  | wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk("Y"); // 空板 | 
|---|
|  |  |  | wrkMast.setAppeUser(String.valueOf(userId)); | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(String.valueOf(userId)); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | wrkMast.setHostId(hostId); | 
|---|
|  |  |  | boolean res = wrkMastService.save(wrkMast); | 
|---|
|  |  |  | if (!res) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 更新库位状态 D.空板 -> R.出库预约 | 
|---|
|  |  |  | if (locMast.getLocSts().equals("D")){ | 
|---|
|  |  |  | locMast.setLocSts("R"); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("更新库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void locCheckOut(StockOutParam param, Long userId, Long hostId) { | 
|---|
|  |  |  | // 目标站点状态检测 | 
|---|
|  |  |  | BasDevp staNo = basDevpService.checkSiteStatus(param.getOutSite(), false, hostId); | 
|---|
|  |  |  | // 获取库位明细 | 
|---|
|  |  |  | List<LocDetlDto> locDetlDtos = new ArrayList<>(); | 
|---|
|  |  |  | for (StockOutParam.LocDetl paramLocDetl : param.getLocDetls()) { | 
|---|
|  |  |  | if (!Cools.isEmpty(paramLocDetl.getLocNo(), paramLocDetl.getMatnr(), paramLocDetl.getCount())) { | 
|---|
|  |  |  | LocDetl one = locDetlService.selectItem(paramLocDetl.getLocNo(), paramLocDetl.getMatnr(), paramLocDetl.getBatch(), hostId); | 
|---|
|  |  |  | if (null != one) locDetlDtos.add(new LocDetlDto(one, paramLocDetl.getCount())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!locDetlDtos.isEmpty()) { | 
|---|
|  |  |  | // 启动出库开始 107.盘点出库 | 
|---|
|  |  |  | stockOut(param.getOutSite(), locDetlDtos, IoWorkType.CHECK_OUT, userId, hostId); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("库位物料不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void stockOut(Integer staNo, List<LocDetlDto> locDetlDtos, IoWorkType ioWorkType, Long userId, Long hostId) { | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 合并同类项 | 
|---|
|  |  |  | 
|---|
|  |  |  | assert ioType != null; | 
|---|
|  |  |  | // 获取库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.getOne(new LambdaQueryWrapper<LocMast>().eq(LocMast::getLocNo, dto.getLocNo()).eq(LocMast::getHostId, hostId)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String barcode = locMast.getBarcode(); | 
|---|
|  |  |  | int count = wrkMastService.count(new LambdaQueryWrapper<WrkMast>().eq(WrkMast::getBarcode, barcode)); | 
|---|
|  |  |  | if (count > 0) { | 
|---|
|  |  |  | throw new CoolException("工作档已生成"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取路径 | 
|---|
|  |  |  | StaDesc staDesc = staDescService.getOne(new LambdaQueryWrapper<StaDesc>().eq(StaDesc::getTypeNo, ioType).eq(StaDesc::getDeviceStn, staNo).eq(StaDesc::getHostId, hostId)); | 
|---|
|  |  |  | StaDesc staDesc = staDescService.getOne(new LambdaQueryWrapper<StaDesc>().eq(StaDesc::getTypeNo, ioType).eq(StaDesc::getStnNo, staNo).eq(StaDesc::getHostId, hostId)); | 
|---|
|  |  |  | // 生成工作号 | 
|---|
|  |  |  | int workNo = commonService.getWorkNo(WorkNoType.getWorkNoType(ioType)); | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | 
|---|
|  |  |  | wrkMast.setWrkSts(101L); // 工作状态:101.生成出库 | 
|---|
|  |  |  | wrkMast.setIoType(ioType); // 入出库状态 | 
|---|
|  |  |  | wrkMast.setIoPri(13D); // 优先级:13 | 
|---|
|  |  |  | wrkMast.setSourceStaNo(staDesc.getDeviceStn()); // 源站 | 
|---|
|  |  |  | wrkMast.setStaNo(staDesc.getStnNo()); // 目标站 | 
|---|
|  |  |  | wrkMast.setSourceStaNo(Cools.isEmpty(staDesc.getDeviceStn())? 0 : staDesc.getDeviceStn()); // 源站 | 
|---|
|  |  |  | wrkMast.setStaNo(Cools.isEmpty(staDesc.getStnNo()) ? 0:staDesc.getStnNo()); // 目标站 | 
|---|
|  |  |  | wrkMast.setSourceLocNo(dto.getLocNo()); // 源库位 | 
|---|
|  |  |  | wrkMast.setFullPlt("Y"); // 满板:Y | 
|---|
|  |  |  | wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk("N"); // 空板 | 
|---|
|  |  |  | wrkMast.setBarcode(locMast.getBarcode()); | 
|---|
|  |  |  | wrkMast.setBarcode(barcode); | 
|---|
|  |  |  | wrkMast.setAppeUser(String.valueOf(userId)); // 操作人员数据 | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(String.valueOf(userId)); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | wrkMast.setHostId(hostId); | 
|---|
|  |  |  | wrkMast.setCrnNo(staDesc.getDeviceNo()); | 
|---|
|  |  |  | if (!wrkMastService.save(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败,出库库位号:" + dto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | wrkDetl.setAppeUser(userId); | 
|---|
|  |  |  | wrkDetl.setModiTime(now); | 
|---|
|  |  |  | wrkDetl.setModiUser(userId); | 
|---|
|  |  |  | wrkDetl.setHostId(hostId); | 
|---|
|  |  |  | wrkDetl.setWrkMastId(wrkMast.getId()); | 
|---|
|  |  |  | if (!wrkDetlService.save(wrkDetl)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档明细失败"); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void stockOut(Integer staNo, TaskDto taskDto, Long userId, Long hostId) { | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | List<LocDto> locDtos = taskDto.getLocDtos(); | 
|---|
|  |  |  | for (LocDto locDto : locDtos) { | 
|---|
|  |  |  | if (!taskDto.getLocNo().equals(locDto.getLocNo()) && !taskDto.getStaNo().equals(locDto.getStaNo())) { | 
|---|
|  |  |  | throw new CoolException("订单出库异常,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 获取库位 | 
|---|
|  |  |  | LocMast locMast = locMastService.getOne(new LambdaQueryWrapper<LocMast>() | 
|---|
|  |  |  | .eq(LocMast::getLocNo, taskDto.getLocNo()) | 
|---|
|  |  |  | .eq(LocMast::getHostId, hostId)); | 
|---|
|  |  |  | // 获取路径 | 
|---|
|  |  |  | int ioType = taskDto.isAll() ? 101 : 103; | 
|---|
|  |  |  | if(ioType==101){ | 
|---|
|  |  |  | staNo=102; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 获取路径 | 
|---|
|  |  |  | StaDesc staDesc = staDescService.getOne(new LambdaQueryWrapper<StaDesc>().eq(StaDesc::getTypeNo, ioType).eq(StaDesc::getStnNo, staNo).eq(StaDesc::getHostId, hostId)); | 
|---|
|  |  |  | // 生成工作号 | 
|---|
|  |  |  | int workNo = commonService.getWorkNo(WorkNoType.getWorkNoType(ioType)); | 
|---|
|  |  |  | // 生成工作档 | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setIoTime(now); | 
|---|
|  |  |  | wrkMast.setWrkSts(101L); // 工作状态:101.生成出库 | 
|---|
|  |  |  | wrkMast.setIoType(ioType); // 入出库状态 | 
|---|
|  |  |  | wrkMast.setIoPri(13D); // 优先级:13 | 
|---|
|  |  |  | wrkMast.setSourceStaNo(staDesc.getDeviceStn()); // 源站 | 
|---|
|  |  |  | wrkMast.setStaNo(staDesc.getStnNo()); // 目标站 | 
|---|
|  |  |  | wrkMast.setSourceLocNo(taskDto.getLocNo()); // 源库位 | 
|---|
|  |  |  | wrkMast.setFullPlt("Y"); // 满板:Y | 
|---|
|  |  |  | wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk("N"); // 空板 | 
|---|
|  |  |  | wrkMast.setCrnNo(locMast.getCrnNo()); | 
|---|
|  |  |  | wrkMast.setBarcode(locMast.getBarcode()); | 
|---|
|  |  |  | wrkMast.setAppeUser(String.valueOf(userId)); // 操作人员数据 | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(String.valueOf(userId)); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | wrkMast.setHostId(hostId); | 
|---|
|  |  |  | if (!wrkMastService.save(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败,出库库位号:"+taskDto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 生成工作档明细 | 
|---|
|  |  |  | for (LocDto locDto : taskDto.getLocDtos()) { | 
|---|
|  |  |  | if (locDto.getAnfme()==null || locDto.getAnfme() <= 0.0D) { continue; } | 
|---|
|  |  |  | Order order = orderService.getOne(new LambdaQueryWrapper<Order>() | 
|---|
|  |  |  | .eq(Order::getOrderNo, locDto.getOrderNo()) | 
|---|
|  |  |  | .eq(Order::getHostId, hostId)); | 
|---|
|  |  |  | OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), locDto.getMatnr(), locDto.getBatch(),hostId); | 
|---|
|  |  |  | if (orderDetl == null) { | 
|---|
|  |  |  | orderDetl = orderDetlService.selectItem(order.getId(), locDto.getMatnr(), null,hostId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | LocDetl locDetl = locDetlService.selectItem(locDto.getLocNo(), locDto.getMatnr(), locDto.getBatch(), hostId); | 
|---|
|  |  |  | if (locDetl == null || locDetl.getAnfme() < locDto.getAnfme()) { | 
|---|
|  |  |  | throw new CoolException(locDto.getLocNo() + "库位中" + locDto.getMatnr() + "商品库存不足!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | WrkDetl wrkDetl = new WrkDetl(); | 
|---|
|  |  |  | wrkDetl.sync(orderDetl); | 
|---|
|  |  |  | wrkDetl.setZpallet(wrkMast.getBarcode()); | 
|---|
|  |  |  | wrkDetl.setIoTime(now); | 
|---|
|  |  |  | wrkDetl.setWrkNo(workNo); | 
|---|
|  |  |  | wrkDetl.setBatch(locDto.getBatch()); | 
|---|
|  |  |  | wrkDetl.setOrderNo(locDto.getOrderNo()); | 
|---|
|  |  |  | wrkDetl.setAnfme(locDto.getAnfme()); // 数量 | 
|---|
|  |  |  | wrkDetl.setAppeTime(now); | 
|---|
|  |  |  | wrkDetl.setAppeUser(userId); | 
|---|
|  |  |  | wrkDetl.setModiTime(now); | 
|---|
|  |  |  | wrkDetl.setModiUser(userId); | 
|---|
|  |  |  | wrkDetl.setHostId(hostId); | 
|---|
|  |  |  | wrkDetl.setWrkMastId(wrkMast.getId()); | 
|---|
|  |  |  | if (!wrkDetlService.save(wrkDetl)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改订单明细 | 
|---|
|  |  |  | if (!orderDetlService.increaseWorkQty(orderDetl.getOrderId(), orderDetl.getMatnr(), orderDetl.getBatch(), locDto.getAnfme(), hostId)) { | 
|---|
|  |  |  | throw new CoolException("修改订单明细数量失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | orderService.updateSettle(orderDetl.getOrderId(), 2L, userId, hostId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改库位状态:   F.在库 ====>>> R.出库预约/P.拣料/盘点/并板出库中 | 
|---|
|  |  |  | locMast = locMastService.getOne(new LambdaQueryWrapper<LocMast>() | 
|---|
|  |  |  | .eq(LocMast::getLocNo, taskDto.getLocNo()) | 
|---|
|  |  |  | .eq(LocMast::getHostId, hostId)); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("F")) { | 
|---|
|  |  |  | locMast.setLocSts(ioType==101?"R":"P"); | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("预约库位状态失败,库位号:"+taskDto.getLocNo()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException(taskDto.getLocNo() + "库位不是在库状态"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void completeWrkMast(String workNo, Long userId, Long hostId) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.getOne(new LambdaQueryWrapper<WrkMast>().eq(WrkMast::getWrkNo, workNo).eq(WrkMast::getHostId, hostId)); | 
|---|
|  |  |  | if (Cools.isEmpty(wrkMast)){ | 
|---|
|  |  |  | throw new CoolException(workNo+"工作档不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (wrkMast.getWrkSts() == 4 || wrkMast.getWrkSts() == 14) { | 
|---|
|  |  |  | if (wrkMast.getWrkSts() == 4 || wrkMast.getWrkSts() == 199) { | 
|---|
|  |  |  | throw new CoolException("当前工作档已完成"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 入库 + 库位转移 | 
|---|
|  |  |  | 
|---|
|  |  |  | if (Cools.isEmpty(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException(workNo + "工作档不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (wrkMast.getIoType() == 300) { | 
|---|
|  |  |  | //RGV调度任务 | 
|---|
|  |  |  | //删除工作档 | 
|---|
|  |  |  | wrkMastService.removeById(wrkMast.getId()); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String locNo = ""; // 待修改目标库位 | 
|---|
|  |  |  | String locSts = ""; // 待修改目标库位状态 | 
|---|
|  |  |  | // 入库取消(修改目标库位) | 
|---|
|  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("当前工作状态无法取消"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 订单关联 | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.list(new LambdaQueryWrapper<WrkDetl>().eq(WrkDetl::getWrkNo, wrkMast.getWrkNo()).eq(WrkDetl::getHostId, hostId)); | 
|---|
|  |  |  | for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | if (!Cools.isEmpty(wrkDetl.getOrderNo())) { | 
|---|
|  |  |  | if (!orderDetlService.decrease(wrkDetl.getOrderNo(), hostId, wrkDetl.getMatnr(), wrkDetl.getBatch(), wrkDetl.getAnfme())) { | 
|---|
|  |  |  | throw new CoolException("订单数据回滚失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //修改订单主表状态,没有作业数量时才可以修改 | 
|---|
|  |  |  | boolean flag = true; | 
|---|
|  |  |  | List<OrderDetl> orderDetls = orderDetlService.list(new LambdaQueryWrapper<OrderDetl>() | 
|---|
|  |  |  | .eq(OrderDetl::getOrderNo, wrkDetl.getOrderNo()) | 
|---|
|  |  |  | .eq(OrderDetl::getHostId, hostId)); | 
|---|
|  |  |  | for(OrderDetl orderDetl : orderDetls){ | 
|---|
|  |  |  | if(orderDetl.getWorkQty() > 0){ | 
|---|
|  |  |  | flag = false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(flag){ | 
|---|
|  |  |  | Order order = orderService.getOne(new LambdaQueryWrapper<Order>() | 
|---|
|  |  |  | .eq(Order::getOrderNo, wrkDetl.getOrderNo()) | 
|---|
|  |  |  | .eq(Order::getHostId, hostId)); | 
|---|
|  |  |  | if(!Cools.isEmpty(order) && order.getSettle()==2){ | 
|---|
|  |  |  | order.setSettle(1L); | 
|---|
|  |  |  | order.setUpdateBy(userId); | 
|---|
|  |  |  | order.setUpdateTime(new Date()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(!orderService.updateById(order)){ | 
|---|
|  |  |  | throw new CoolException("修改订单状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void adjustLocDetl(LocDetlAdjustParam param, Long userId, Long hostId) { | 
|---|
|  |  |  | param.integrate(); | 
|---|
|  |  |  | LocMast locMast = locMastService.getOne(new LambdaQueryWrapper<LocMast>().eq(LocMast::getLocNo, param.getLocNo()).eq(LocMast::getHostId, hostId)); | 
|---|
|  |  |  | if (Cools.isEmpty(locMast)) { | 
|---|
|  |  |  | throw new CoolException("库位不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!(locMast.getLocSts().equals("F") || locMast.getLocSts().equals("D") || locMast.getLocSts().equals("O"))) { | 
|---|
|  |  |  | throw new CoolException("当前库位不可调整!库位状态:" + locMast.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.list(new LambdaQueryWrapper<LocDetl>().eq(LocDetl::getLocNo, param.getLocNo()).eq(LocDetl::getHostId, hostId)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<LocDetlAdjustParam.LocDetlAdjust> list = param.getList(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 修改数量 | 
|---|
|  |  |  | Iterator<LocDetl> iterator = locDetls.iterator(); | 
|---|
|  |  |  | while (iterator.hasNext()) { | 
|---|
|  |  |  | LocDetl locDetl = iterator.next(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Iterator<LocDetlAdjustParam.LocDetlAdjust> iterator1 = list.iterator(); | 
|---|
|  |  |  | while (iterator1.hasNext()) { | 
|---|
|  |  |  | LocDetlAdjustParam.LocDetlAdjust adjust = iterator1.next(); | 
|---|
|  |  |  | if (adjust.getCount() == 0) { continue; } | 
|---|
|  |  |  | if (locDetl.getMatnr().equals(adjust.getMatnr()) && Cools.eq(locDetl.getBatch(), adjust.getBatch())) { | 
|---|
|  |  |  | if (!locDetl.getAnfme().equals(adjust.getCount())) { | 
|---|
|  |  |  | // todo 盘点记录 | 
|---|
|  |  |  | // 修改库存 | 
|---|
|  |  |  | if (!locDetlService.updateAnfme(adjust.getCount(), locDetl.getLocNo(), locDetl.getMatnr(), locDetl.getBatch(), hostId)) { | 
|---|
|  |  |  | throw new CoolException(locDetl.getLocNo() + "库位," + locDetl.getMatnr() + "商品," + locDetl.getBatch() + "序列码修改数量失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 保存调整记录 | 
|---|
|  |  |  | AdjDetl adjDetl = new AdjDetl(); | 
|---|
|  |  |  | adjDetl.setLocNo(locDetl.getLocNo()); | 
|---|
|  |  |  | adjDetl.setMatnr(locDetl.getMatnr()); | 
|---|
|  |  |  | adjDetl.setBatch(locDetl.getBatch()); | 
|---|
|  |  |  | adjDetl.setOriQty(locDetl.getAnfme()); | 
|---|
|  |  |  | adjDetl.setAdjQty(adjust.getCount()); | 
|---|
|  |  |  | adjDetl.setModiTime(now); | 
|---|
|  |  |  | adjDetl.setModiUser(userId); | 
|---|
|  |  |  | adjDetl.setAppeTime(now); | 
|---|
|  |  |  | adjDetl.setAppeUser(userId); | 
|---|
|  |  |  | adjDetl.setHostId(hostId); | 
|---|
|  |  |  | adjDetlService.save(adjDetl); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | iterator.remove(); | 
|---|
|  |  |  | iterator1.remove(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 删除库存 | 
|---|
|  |  |  | for (LocDetl locDetl : locDetls) { | 
|---|
|  |  |  | // todo 盘点记录 | 
|---|
|  |  |  | if (!locDetlService.updateAnfme(-1.0D, locDetl.getLocNo(), locDetl.getMatnr(), locDetl.getBatch(), hostId)) { | 
|---|
|  |  |  | throw new CoolException("删除" + locDetl.getLocNo() + "库位," + locDetl.getMatnr() + "商品," + locDetl.getBatch() + "序列码库存明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 保存调整记录 | 
|---|
|  |  |  | 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(userId); | 
|---|
|  |  |  | adjDetl.setAppeTime(now); | 
|---|
|  |  |  | adjDetl.setAppeUser(userId); | 
|---|
|  |  |  | adjDetl.setHostId(hostId); | 
|---|
|  |  |  | adjDetlService.save(adjDetl); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 添加库存 | 
|---|
|  |  |  | for (LocDetlAdjustParam.LocDetlAdjust adjust : list) { | 
|---|
|  |  |  | if (adjust.getCount() == 0.0D) { continue; } | 
|---|
|  |  |  | Mat mat = matService.getOne(new LambdaQueryWrapper<Mat>().eq(Mat::getMatnr, adjust.getMatnr()).eq(Mat::getHostId, hostId)); | 
|---|
|  |  |  | LocDetl locDetl = new LocDetl(); | 
|---|
|  |  |  | locDetl.sync(mat); | 
|---|
|  |  |  | locDetl.setBatch(adjust.getBatch()); | 
|---|
|  |  |  | locDetl.setLocNo(locMast.getLocNo()); | 
|---|
|  |  |  | locDetl.setAnfme(adjust.getCount()); // 数量 | 
|---|
|  |  |  | locDetl.setModiUser(userId); // 操作人员信息 | 
|---|
|  |  |  | locDetl.setModiTime(now); | 
|---|
|  |  |  | locDetl.setAppeUser(userId); | 
|---|
|  |  |  | locDetl.setAppeTime(now); | 
|---|
|  |  |  | locDetl.setHostId(hostId); | 
|---|
|  |  |  | if (!locDetlService.save(locDetl)) { | 
|---|
|  |  |  | throw new CoolException("添加" + locDetl.getLocNo() + "库位," + locDetl.getMatnr() + "商品," + locDetl.getBatch() + "序列码库存明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 保存调整记录 | 
|---|
|  |  |  | AdjDetl adjDetl = new AdjDetl(); | 
|---|
|  |  |  | adjDetl.setLocNo(locMast.getLocNo()); | 
|---|
|  |  |  | adjDetl.setMatnr(adjust.getMatnr()); | 
|---|
|  |  |  | adjDetl.setBatch(adjust.getBatch()); | 
|---|
|  |  |  | adjDetl.setOriQty(0.0D); | 
|---|
|  |  |  | adjDetl.setAdjQty(adjust.getCount()); | 
|---|
|  |  |  | adjDetl.setModiTime(now); | 
|---|
|  |  |  | adjDetl.setModiUser(userId); | 
|---|
|  |  |  | adjDetl.setAppeTime(now); | 
|---|
|  |  |  | adjDetl.setAppeUser(userId); | 
|---|
|  |  |  | adjDetl.setHostId(hostId); | 
|---|
|  |  |  | adjDetlService.save(adjDetl); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改库位状态 | 
|---|
|  |  |  | int count = locDetlService.count(new LambdaQueryWrapper<LocDetl>().eq(LocDetl::getLocNo, locMast.getLocNo()).eq(LocDetl::getHostId, hostId)); | 
|---|
|  |  |  | if (locMast.getLocSts().equals("F")) { | 
|---|
|  |  |  | if (count == 0) { | 
|---|
|  |  |  | locMast.setLocSts("D"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (locMast.getLocSts().equals("D") || locMast.getLocSts().equals("O")) { | 
|---|
|  |  |  | if (count > 0) { | 
|---|
|  |  |  | locMast.setLocSts("F"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | locMast.setModiUser(userId); | 
|---|
|  |  |  | locMast.setModiTime(new Date()); | 
|---|
|  |  |  | if (!locMastService.updateById(locMast)) { | 
|---|
|  |  |  | throw new CoolException("更新库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public void locMove(String sourceLocNo, String locNo, Long userId, Long hostId) { | 
|---|
|  |  |  | LocMast sourceLoc = locMastService.getOne(new LambdaQueryWrapper<LocMast>() | 
|---|
|  |  |  | .eq(LocMast::getLocNo, sourceLocNo) | 
|---|
|  |  |  | .eq(LocMast::getHostId, hostId)); | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.list(new LambdaQueryWrapper<LocDetl>() | 
|---|
|  |  |  | .eq(LocDetl::getLocNo, sourceLocNo) | 
|---|
|  |  |  | .eq(LocDetl::getHostId, hostId)); | 
|---|
|  |  |  | if (Cools.isEmpty(sourceLoc)){ | 
|---|
|  |  |  | throw new CoolException("未找到库位"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | LocMast loc = locMastService.getOne(new LambdaQueryWrapper<LocMast>() | 
|---|
|  |  |  | .eq(LocMast::getLocNo, locNo) | 
|---|
|  |  |  | .eq(LocMast::getHostId, hostId)); | 
|---|
|  |  |  | if (Cools.isEmpty(loc)){ | 
|---|
|  |  |  | throw new CoolException("未找到库位"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!sourceLoc.getCrnNo().equals(loc.getCrnNo())) { | 
|---|
|  |  |  | //            throw new CoolException("移转库位属于不同堆垛机");   todo:luxiaotao | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | // 获取工作号 | 
|---|
|  |  |  | int workNo = commonService.getWorkNo(WorkNoType.PICK.type); | 
|---|
|  |  |  | // 保存工作档 | 
|---|
|  |  |  | WrkMast wrkMast = new WrkMast(); | 
|---|
|  |  |  | wrkMast.setWrkNo(workNo); | 
|---|
|  |  |  | wrkMast.setIoTime(now); | 
|---|
|  |  |  | wrkMast.setWrkSts(101L); // 工作状态:101.生成出库任务 | 
|---|
|  |  |  | wrkMast.setIoType(11); // 入出库状态: 11.库格移载 | 
|---|
|  |  |  | wrkMast.setIoPri(10D); | 
|---|
|  |  |  | wrkMast.setSourceLocNo(sourceLocNo); // 源库位 | 
|---|
|  |  |  | wrkMast.setLocNo(locNo); // 目标库位 | 
|---|
|  |  |  | wrkMast.setFullPlt(Cools.isEmpty(locDetls)?"N":"Y"); // 满板:Y | 
|---|
|  |  |  | wrkMast.setPicking("N"); // 拣料 | 
|---|
|  |  |  | wrkMast.setExitMk("N"); // 退出 | 
|---|
|  |  |  | wrkMast.setEmptyMk(sourceLoc.getLocSts().equals("D")?"Y":"N"); // 空板 | 
|---|
|  |  |  | wrkMast.setBarcode(sourceLoc.getBarcode()); // 托盘码 | 
|---|
|  |  |  | wrkMast.setAppeUser(String.valueOf(userId)); | 
|---|
|  |  |  | wrkMast.setAppeTime(now); | 
|---|
|  |  |  | wrkMast.setModiUser(String.valueOf(userId)); | 
|---|
|  |  |  | wrkMast.setModiTime(now); | 
|---|
|  |  |  | wrkMast.setHostId(hostId); | 
|---|
|  |  |  | boolean res = wrkMastService.save(wrkMast); | 
|---|
|  |  |  | if (!res) { | 
|---|
|  |  |  | throw new CoolException("保存工作档失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 工作档明细保存 | 
|---|
|  |  |  | for (LocDetl locDetl : locDetls) { | 
|---|
|  |  |  | WrkDetl wrkDetl = new WrkDetl(); | 
|---|
|  |  |  | wrkDetl.sync(locDetl); | 
|---|
|  |  |  | wrkDetl.setWrkNo(workNo); | 
|---|
|  |  |  | wrkDetl.setIoTime(now); | 
|---|
|  |  |  | wrkDetl.setAnfme(locDetl.getAnfme()); | 
|---|
|  |  |  | wrkDetl.setAppeTime(now); | 
|---|
|  |  |  | wrkDetl.setAppeUser(userId); | 
|---|
|  |  |  | wrkDetl.setModiTime(now); | 
|---|
|  |  |  | wrkDetl.setModiUser(userId); | 
|---|
|  |  |  | wrkDetl.setHostId(hostId); | 
|---|
|  |  |  | wrkDetl.setWrkMastId(wrkMast.getId()); | 
|---|
|  |  |  | if (!wrkDetlService.save(wrkDetl)) { | 
|---|
|  |  |  | throw new CoolException("保存工作档明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改源库位状态 | 
|---|
|  |  |  | if (sourceLoc.getLocSts().equals("D") || sourceLoc.getLocSts().equals("F")) { | 
|---|
|  |  |  | sourceLoc.setLocSts("R"); // R.出库预约 | 
|---|
|  |  |  | sourceLoc.setModiUser(userId); | 
|---|
|  |  |  | sourceLoc.setModiTime(now); | 
|---|
|  |  |  | if (!locMastService.updateById(sourceLoc)){ | 
|---|
|  |  |  | throw new CoolException("更新源库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException(sourceLoc.getLocNo() + "源库位出库失败,状态:"+sourceLoc.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改目标库位状态 | 
|---|
|  |  |  | if (loc.getLocSts().equals("O")) { | 
|---|
|  |  |  | loc.setLocSts("S"); // S.入库预约 | 
|---|
|  |  |  | loc.setModiTime(now); | 
|---|
|  |  |  | loc.setModiUser(userId); | 
|---|
|  |  |  | if (!locMastService.updateById(loc)) { | 
|---|
|  |  |  | throw new CoolException("更新目标库位状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | throw new CoolException("移转失败,目标库位状态:"+loc.getLocSts$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|