| | |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import zy.cloud.wms.common.model.BillDto; |
| | | import zy.cloud.wms.common.model.OrderStoDto; |
| | | import zy.cloud.wms.common.service.MainService; |
| | | import zy.cloud.wms.common.service.asrs.AsrsService; |
| | |
| | | |
| | | import java.util.ArrayList; |
| | | import java.util.Date; |
| | | import java.util.Iterator; |
| | | import java.util.List; |
| | | |
| | | /** |
| | |
| | | private AsrsService asrsService; |
| | | @Autowired |
| | | private ErpService erpService; |
| | | @Autowired |
| | | private CheckService checkService; |
| | | |
| | | @Override |
| | | @Transactional |
| | |
| | | } |
| | | |
| | | // 上报给erp |
| | | if (!erpService.uploadBill(combs, param.getDocType(), docNum)) { |
| | | List<BillDto> dtos = new ArrayList<>(); |
| | | for (Comb comb : combs) { |
| | | BillDto billDto = new BillDto(); |
| | | billDto.setMatnr(comb.getMatnr()); |
| | | billDto.setQty(comb.getAnfme()); |
| | | dtos.add(billDto); |
| | | } |
| | | if (!erpService.uploadBill(dtos, param.getDocType(), docNum)) { |
| | | throw new CoolException("无法上报至erp"); |
| | | } |
| | | |
| | |
| | | // 修改单据状态 |
| | | if (!custOrderService.updateStatus(param.getNumber(), 4)) { |
| | | throw new CoolException("修改单据状态失败"); |
| | | } |
| | | // 采购退货单 |
| | | if (param.getNumber().startsWith("PR-")) { |
| | | List<BillDto> dtos = new ArrayList<>(); |
| | | for (Pakout pakout : pakouts) { |
| | | BillDto billDto = new BillDto(); |
| | | billDto.setMatnr(pakout.getMatnr()); |
| | | billDto.setQty(pakout.getAnfme()); |
| | | dtos.add(billDto); |
| | | } |
| | | // erp单据上传 -- 采购退货单 |
| | | if (!erpService.uploadBill(dtos, 6, pakouts.get(0).getDocNum())) { |
| | | throw new CoolException("无法上报至erp"); |
| | | } |
| | | |
| | | } |
| | | return R.ok(); |
| | | } |
| | |
| | | return R.error("暂不缺货,不需要立库调拨"); |
| | | } |
| | | |
| | | @Override |
| | | public R stockCheck(StoCheckParam param, Long userId) { |
| | | if (Cools.isEmpty(param.getLocNo())) { |
| | | return R.error("请选择货位"); |
| | | } |
| | | Node node = nodeService.selectByUuid(param.getLocNo()); |
| | | if (Cools.isEmpty(node)) { |
| | | return R.error("货位异常,请联系管理员"); |
| | | } |
| | | // 准备数据 |
| | | Date now = new Date(); |
| | | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("node_id", node.getId())); |
| | | List<String> locDetlMatnrs = new ArrayList<>(); |
| | | locDetls.forEach(locDetl -> locDetlMatnrs.add(locDetl.getMatnr())); |
| | | Iterator<LocDetl> detlIterator = locDetls.iterator(); |
| | | List<PakinMatDto> dtos = param.getDtos(); |
| | | |
| | | // 1.盈亏 修改数量 |
| | | while (detlIterator.hasNext()){ |
| | | LocDetl locDetl = detlIterator.next(); |
| | | for (PakinMatDto dto : dtos) { |
| | | if (locDetl.getMatnr().equals(dto.getMatnr())) { |
| | | if (!locDetl.getAnfme().equals(dto.getCount())) { |
| | | Check check = new Check( |
| | | String.valueOf(snowflakeIdWorker.nextId()), // 盘点编号 |
| | | node.getId(), // 盘点货位 |
| | | node.getUuid(), // 货位编号 |
| | | node.getName(), // 货位名称 |
| | | locDetl.getMatnr(), // 商品编号 |
| | | locDetl.getMaktx(), // 商品名称 |
| | | locDetl.getUnit(), // 单位 |
| | | null, // 单据类型 |
| | | null, // 单据编号 |
| | | locDetl.getAnfme(), // 账面数量 |
| | | dto.getCount(), // 实盘数量 |
| | | dto.getCount() - locDetl.getAnfme(), // 差值 |
| | | locDetl.getAnfme() < dto.getCount() ? 1 : 2, // 盈亏 |
| | | 1, // 状态 |
| | | userId, // 添加人员 |
| | | now, // 添加时间 |
| | | userId, // 修改人员 |
| | | now, // 修改时间 |
| | | null // 备注 |
| | | ); |
| | | if (!checkService.insert(check)) { |
| | | throw new CoolException("保存盘点记录失败"); |
| | | } |
| | | } |
| | | detlIterator.remove(); |
| | | break; |
| | | } |
| | | } |
| | | } |
| | | |
| | | // 2.盘亏 删除库存 |
| | | for (LocDetl locDetl : locDetls) { |
| | | Check check = new Check( |
| | | String.valueOf(snowflakeIdWorker.nextId()), // 盘点编号 |
| | | node.getId(), // 盘点货位 |
| | | node.getUuid(), // 货位编号 |
| | | node.getName(), // 货位名称 |
| | | locDetl.getMatnr(), // 商品编号 |
| | | locDetl.getMaktx(), // 商品名称 |
| | | locDetl.getUnit(), // 单位 |
| | | null, // 单据类型 |
| | | null, // 单据编号 |
| | | locDetl.getAnfme(), // 账面数量 |
| | | 0D, // 实盘数量 |
| | | 0D - locDetl.getAnfme(), // 差值 |
| | | 2, // 盈亏 |
| | | 1, // 状态 |
| | | userId, // 添加人员 |
| | | now, // 添加时间 |
| | | userId, // 修改人员 |
| | | now, // 修改时间 |
| | | null // 备注 |
| | | ); |
| | | if (!checkService.insert(check)) { |
| | | throw new CoolException("保存盘点记录失败"); |
| | | } |
| | | |
| | | } |
| | | |
| | | // 3.盘盈 新增库存 |
| | | for (PakinMatDto dto : dtos) { |
| | | if (!locDetlMatnrs.contains(dto.getMatnr())) { |
| | | Mat mat = matService.selectByMatnr(dto.getMatnr()); |
| | | Check check = new Check( |
| | | String.valueOf(snowflakeIdWorker.nextId()), // 盘点编号 |
| | | node.getId(), // 盘点货位 |
| | | node.getUuid(), // 货位编号 |
| | | node.getName(), // 货位名称 |
| | | mat.getMatnr(), // 商品编号 |
| | | mat.getMaktx(), // 商品名称 |
| | | mat.getUnit(), // 单位 |
| | | null, // 单据类型 |
| | | null, // 单据编号 |
| | | 0D, // 账面数量 |
| | | dto.getCount(), // 实盘数量 |
| | | dto.getCount() - 0D, // 差值 |
| | | 1, // 盈亏 |
| | | 1, // 状态 |
| | | userId, // 添加人员 |
| | | now, // 添加时间 |
| | | userId, // 修改人员 |
| | | now, // 修改时间 |
| | | null // 备注 |
| | | ); |
| | | if (!checkService.insert(check)) { |
| | | throw new CoolException("保存盘点记录失败"); |
| | | } |
| | | |
| | | } |
| | | } |
| | | |
| | | return R.ok(); |
| | | } |
| | | |
| | | @Override |
| | | public R stockCheckAuditing(Long checkId, Long userId) { |
| | | |
| | | |
| | | |
| | | return R.ok(); |
| | | } |
| | | |
| | | } |