|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson.JSON; | 
|---|
|  |  |  | import com.alibaba.fastjson.JSONObject; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
|---|
|  |  |  | import com.core.common.Cools; | 
|---|
|  |  |  | import com.core.common.DateUtils; | 
|---|
|  |  |  | import com.core.exception.CoolException; | 
|---|
|  |  |  | import com.zy.asrs.entity.DocType; | 
|---|
|  |  |  | import com.zy.asrs.entity.Order; | 
|---|
|  |  |  | import com.zy.asrs.entity.OrderDetl; | 
|---|
|  |  |  | import com.zy.asrs.service.ApiLogService; | 
|---|
|  |  |  | import com.zy.asrs.service.DocTypeService; | 
|---|
|  |  |  | import com.zy.asrs.service.OrderDetlService; | 
|---|
|  |  |  | import com.zy.asrs.service.OrderService; | 
|---|
|  |  |  | import com.zy.asrs.entity.*; | 
|---|
|  |  |  | import com.zy.asrs.service.*; | 
|---|
|  |  |  | import com.zy.asrs.task.AbstractHandler; | 
|---|
|  |  |  | import com.zy.asrs.task.core.ReturnT; | 
|---|
|  |  |  | import com.zy.asrs.utils.MatUtils; | 
|---|
|  |  |  | import com.zy.asrs.utils.MathUtils; | 
|---|
|  |  |  | import com.zy.asrs.utils.OrderInAndOutUtil; | 
|---|
|  |  |  | import com.zy.common.constant.MesConstant; | 
|---|
|  |  |  | import com.zy.common.model.DetlDto; | 
|---|
|  |  |  | import com.zy.common.model.MesPakinParam; | 
|---|
|  |  |  | import com.zy.common.model.MesPakoutParam; | 
|---|
|  |  |  | import com.zy.common.utils.HttpHandler; | 
|---|
|  |  |  | import com.zy.nc.entity.NccSaleDbddWms; | 
|---|
|  |  |  | import com.zy.nc.entity.NccSaleXsfhmxWms; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.jdbc.core.JdbcTemplate; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.math.BigDecimal; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * Created by vincent on 2020/7/7 | 
|---|
|  |  |  | 
|---|
|  |  |  | private OrderService orderService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OrderDetlService orderDetlService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ApiLogService apiLogService; | 
|---|
|  |  |  | private OrderDetlPakoutService orderDetlPakoutService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WrkDetlService wrkDetlService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WrkMastService wrkMastService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private InventoryCheckOrderDetlService inventoryCheckOrderDetlService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private DocTypeService docTypeService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ReportToThirdService reportToThirdService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public ReturnT<String> startOrderIssuedOnceMore(Order order) { | 
|---|
|  |  |  | DocType docType = docTypeService.selectById(order.getDocType()); | 
|---|
|  |  |  | if (null == docType) { | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Order order1 = OrderInAndOutUtil.selectByNo(order.getPakinPakoutStatus$(), order.getOrderNo()); | 
|---|
|  |  |  | if (!Cools.isEmpty(order1)) { | 
|---|
|  |  |  | return FAIL.setMsg("请等待...订单执行档案正在转历史档案!!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<OrderDetl> orderDetls = OrderInAndOutUtil.selectByOrderId(order.getPakinPakoutStatus$(), order.getId()); | 
|---|
|  |  |  | if (!Cools.isEmpty(orderDetls) || !orderDetls.isEmpty()) { | 
|---|
|  |  |  | return FAIL.setMsg("请等待...订单执行明细档案正在转历史档案!!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 单据明细档 | 
|---|
|  |  |  | List<OrderDetl> orderDetlList = orderDetlService.selectByOrderId(order.getId()); | 
|---|
|  |  |  | for (OrderDetl orderDetl : orderDetlList) { | 
|---|
|  |  |  | if (orderDetl.getQty().equals(0D)) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | orderDetl.setWorkQty(orderDetl.getQty()); | 
|---|
|  |  |  | orderDetl.setAnfme(MathUtils.subtract(orderDetl.getAnfme(), orderDetl.getQty())); | 
|---|
|  |  |  | orderDetl.setQty(0D); | 
|---|
|  |  |  | orderDetlService.updateById(orderDetl); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 修改订单状态 99.再次作业 ===>> 1.待作业 | 
|---|
|  |  |  | if (!orderService.updateSettle(order.getId(), 1L, null)) { | 
|---|
|  |  |  | throw new CoolException("服务器内部错误,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public ReturnT<String> startOrderIssued(Order order) { | 
|---|
|  |  |  | DocType docType = docTypeService.selectById(order.getDocType()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<OrderDetl> orderDetls = orderDetlService.selectByOrderId(order.getId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | OrderInAndOutUtil.insertOrder(order.getPakinPakoutStatus$(),order); | 
|---|
|  |  |  | OrderInAndOutUtil.insertOrder(order.getPakinPakoutStatus$(), order); | 
|---|
|  |  |  | // 单据明细档 | 
|---|
|  |  |  | List<DetlDto> list = new ArrayList<>(); | 
|---|
|  |  |  | List<OrderDetl> orderDetlList = new ArrayList<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (OrderDetl detail : orderDetls) { | 
|---|
|  |  |  | DetlDto dto = new DetlDto(detail.getMatnr(), detail.getBatch(),detail.getBrand(),detail.getStandby1(),detail.getStandby2(),detail.getStandby3(), detail.getAnfme()); | 
|---|
|  |  |  | DetlDto dto = new DetlDto(detail.getMatnr(), detail.getBatch(), detail.getBrand(), detail.getStandby1(), detail.getStandby2(), detail.getStandby3(), detail.getBoxType1(), detail.getBoxType2(), detail.getBoxType3(), detail.getAnfme()); | 
|---|
|  |  |  | dto.setOrderNo(detail.getOrderNo()); | 
|---|
|  |  |  | if (DetlDto.has(list, dto)) { | 
|---|
|  |  |  | DetlDto detlDto = DetlDto.find(list, dto.getMatnr(), dto.getBatch(),dto.getBrand(),dto.getStandby1(),dto.getStandby2(),dto.getStandby3()); | 
|---|
|  |  |  | DetlDto detlDto = DetlDto.find(list, dto.getMatnr(), dto.getBatch(), dto.getBrand(), dto.getStandby1(), dto.getStandby2(), dto.getStandby3(), dto.getBoxType1(), dto.getBoxType2(), dto.getBoxType3()); | 
|---|
|  |  |  | assert detlDto != null; | 
|---|
|  |  |  | detlDto.setAnfme(detlDto.getAnfme() + detail.getAnfme()); | 
|---|
|  |  |  | detlDto.setAnfme(MathUtils.add(detlDto.getAnfme(), detail.getAnfme())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | OrderDetl orderDetl = OrderDetl.find(orderDetlList, dto.getMatnr(), dto.getBatch(),dto.getBrand(),dto.getStandby1(),dto.getStandby2(),dto.getStandby3()); | 
|---|
|  |  |  | OrderDetl orderDetl = OrderDetl.find(orderDetlList, dto.getMatnr(), dto.getBatch(), dto.getBrand(), dto.getStandby1(), dto.getStandby2(), dto.getStandby3(), dto.getBoxType1(), dto.getBoxType2(), dto.getBoxType3()); | 
|---|
|  |  |  | assert orderDetl != null; | 
|---|
|  |  |  | orderDetl.setAnfme(orderDetl.getAnfme() + detail.getAnfme()); | 
|---|
|  |  |  | orderDetl.setAnfme(MathUtils.add(orderDetl.getAnfme(), detail.getAnfme())); | 
|---|
|  |  |  | Double weight = MatUtils.calcWeight(orderDetl.getMatnr(), orderDetl.getAnfme()); | 
|---|
|  |  |  | orderDetl.setWeight(weight); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | list.add(dto); | 
|---|
|  |  |  | orderDetlList.add(detail); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (OrderDetl orderDetl : orderDetlList){ | 
|---|
|  |  |  | OrderInAndOutUtil.insertOrderDetl(order.getPakinPakoutStatus$(),order,orderDetl); | 
|---|
|  |  |  | for (OrderDetl orderDetl : orderDetlList) { | 
|---|
|  |  |  | orderDetl.setWorkQty(0D); | 
|---|
|  |  |  | OrderInAndOutUtil.insertOrderDetl(order.getPakinPakoutStatus$(), order, orderDetl); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改订单状态 1.未作业 ===>> 2.作业中 | 
|---|
|  |  |  | if (!orderService.updateSettle(order.getId(), 2L, null)) { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public ReturnT<String> startOrderInAndOutUtil(Order order) { | 
|---|
|  |  |  | DocType docType = docTypeService.selectById(order.getDocType()); | 
|---|
|  |  |  | if (null == docType) { | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (docType.getDocName().equals("销售发货") || docType.getDocName().equals("集团内部调拨")) { | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Order orderSou = orderService.selectByNo(order.getOrderNo()); | 
|---|
|  |  |  | if (!orderSou.getSettle().equals(2L)){ | 
|---|
|  |  |  | if (orderSou == null) { | 
|---|
|  |  |  | return FAIL.setMsg(order.getOrderNo() + "订单不存在,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!orderSou.getSettle().equals(2L)) { | 
|---|
|  |  |  | return FAIL.setMsg("订单状态不正确,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<OrderDetl> orderDetlList = orderDetlService.selectByOrderId(orderSou.getId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<OrderDetl> orderDetls = OrderInAndOutUtil.selectByOrderId(order.getPakinPakoutStatus$(), order.getId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (OrderDetl orderDetlSou : orderDetlList){ | 
|---|
|  |  |  | for (OrderDetl orderDetl : orderDetls){ | 
|---|
|  |  |  | if (orderDetl.getQty().equals(0D)){ | 
|---|
|  |  |  | for (OrderDetl orderDetlSou : orderDetlList) { | 
|---|
|  |  |  | for (OrderDetl orderDetl : orderDetls) { | 
|---|
|  |  |  | if (orderDetl.getQty().equals(0D)) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (orderDetlSou.beSimilar(orderDetl)){ | 
|---|
|  |  |  | double v = orderDetlSou.getAnfme() - orderDetlSou.getQty(); | 
|---|
|  |  |  | if (v<orderDetl.getQty() || orderDetl.getQty().equals(v)){ | 
|---|
|  |  |  | if (orderDetlSou.beSimilar(orderDetl)) { | 
|---|
|  |  |  | double v = MathUtils.subtract(orderDetlSou.getAnfme(), orderDetlSou.getQty()); | 
|---|
|  |  |  | if (v < orderDetl.getQty() || orderDetl.getQty().equals(v)) { | 
|---|
|  |  |  | orderDetlSou.setQty(orderDetlSou.getAnfme()); | 
|---|
|  |  |  | orderDetl.setQty(orderDetl.getQty() - v); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | orderDetlSou.setQty(orderDetlSou.getQty()+orderDetl.getQty()); | 
|---|
|  |  |  | orderDetlSou.setQty(orderDetlSou.getQty() + orderDetl.getQty()); | 
|---|
|  |  |  | orderDetl.setQty(0D); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (OrderDetl orderDetlSou : orderDetlList){ | 
|---|
|  |  |  | for (OrderDetl orderDetlSou : orderDetlList) { | 
|---|
|  |  |  | orderDetlService.updateById(orderDetlSou); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改订单状态 2.作业中 ===>> 4.待上报 | 
|---|
|  |  |  | 
|---|
|  |  |  | throw new CoolException("服务器内部错误,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改订单状态 4.完成 ===>> 6.结束 | 
|---|
|  |  |  | OrderInAndOutUtil.updateOrder(order.getPakinPakoutStatus$(),order.getId(),6L,null); | 
|---|
|  |  |  | OrderInAndOutUtil.updateOrder(order.getPakinPakoutStatus$(), order.getId(), 6L, null); | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public ReturnT<String> checkXSFH(Order order) { | 
|---|
|  |  |  | DocType docType = docTypeService.selectById(order.getDocType()); | 
|---|
|  |  |  | if (null == docType) { | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!docType.getDocName().equals("销售发货")) { | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Order orderSou = orderService.selectByNo(order.getOrderNo()); | 
|---|
|  |  |  | if (orderSou == null) { | 
|---|
|  |  |  | return FAIL.setMsg("订单不存在,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!orderSou.getSettle().equals(2L)) { | 
|---|
|  |  |  | return FAIL.setMsg("订单状态不正确,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<OrderDetl> orderDetls = OrderInAndOutUtil.selectByOrderId(order.getPakinPakoutStatus$(), order.getId()); | 
|---|
|  |  |  | boolean complete = true; | 
|---|
|  |  |  | //        for (OrderDetl orderDetl : orderDetls) { | 
|---|
|  |  |  | //            if (orderDetl.getAnfme() > orderDetl.getQty()) { | 
|---|
|  |  |  | //                complete = false; | 
|---|
|  |  |  | //                break; | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | if (complete) { | 
|---|
|  |  |  | List<OrderDetl> old = orderDetlService.selectByOrderId(orderSou.getId()); | 
|---|
|  |  |  | if (!orderDetlService.delete(new EntityWrapper<OrderDetl>().eq("order_no", order.getOrderNo()))) { | 
|---|
|  |  |  | throw new CoolException("重整出库订单【orderNo = " + order.getOrderNo() + "】明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | HashMap<String, List<NccSaleXsfhmxWms>> matnrMap = new HashMap<>(); | 
|---|
|  |  |  | for (OrderDetl orderDetl : old) { | 
|---|
|  |  |  | String remark = orderDetl.getRemark(); | 
|---|
|  |  |  | if(Cools.isEmpty(remark)) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | NccSaleXsfhmxWms currentData = JSONObject.parseObject(orderDetl.getRemark(), NccSaleXsfhmxWms.class); | 
|---|
|  |  |  | if (currentData == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<NccSaleXsfhmxWms> list = new ArrayList<>(); | 
|---|
|  |  |  | if (matnrMap.containsKey(orderDetl.getMatnr())) { | 
|---|
|  |  |  | list = matnrMap.get(orderDetl.getMatnr()); | 
|---|
|  |  |  | list.add(currentData); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | list.add(currentData); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | matnrMap.put(orderDetl.getMatnr(), list); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (Map.Entry<String, List<NccSaleXsfhmxWms>> entry : matnrMap.entrySet()) { | 
|---|
|  |  |  | String matnr = entry.getKey(); | 
|---|
|  |  |  | List<NccSaleXsfhmxWms> list = entry.getValue(); | 
|---|
|  |  |  | list.sort(Comparator.comparing(NccSaleXsfhmxWms::getNastnum).reversed()); | 
|---|
|  |  |  | matnrMap.put(matnr, list); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectAndLogByOrderNo(order.getOrderNo()); | 
|---|
|  |  |  | for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | List<OrderDetl> insertList = new ArrayList<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Double isused = wrkDetl.getWeight(); | 
|---|
|  |  |  | while (isused > 0D) { | 
|---|
|  |  |  | List<NccSaleXsfhmxWms> list = matnrMap.get(wrkDetl.getMatnr()); | 
|---|
|  |  |  | if (!list.isEmpty()) { | 
|---|
|  |  |  | NccSaleXsfhmxWms nccSaleXsfhmxWms = list.get(0); | 
|---|
|  |  |  | BigDecimal orderStock = nccSaleXsfhmxWms.getNastnum(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //实际出库数量 | 
|---|
|  |  |  | double realWeight = 0D; | 
|---|
|  |  |  | BigDecimal diff = orderStock.subtract(BigDecimal.valueOf(isused)); | 
|---|
|  |  |  | if (diff.doubleValue() >= 0) { | 
|---|
|  |  |  | nccSaleXsfhmxWms.setNastnum(diff); | 
|---|
|  |  |  | list.set(0, nccSaleXsfhmxWms); | 
|---|
|  |  |  | matnrMap.put(wrkDetl.getMatnr(), list); | 
|---|
|  |  |  | realWeight = isused; | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | list.remove(0); | 
|---|
|  |  |  | matnrMap.put(wrkDetl.getMatnr(), list); | 
|---|
|  |  |  | realWeight = orderStock.doubleValue(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //计算主数量 | 
|---|
|  |  |  | Double anfme = MatUtils.calcAnfmeFromWeight(wrkDetl.getMatnr(), realWeight); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | OrderDetl orderDetl = new OrderDetl(); | 
|---|
|  |  |  | orderDetl.sync(wrkDetl); | 
|---|
|  |  |  | orderDetl.setQty(anfme); | 
|---|
|  |  |  | orderDetl.setWeight(realWeight); | 
|---|
|  |  |  | orderDetl.setOrderId(orderSou.getId()); | 
|---|
|  |  |  | orderDetl.setOrderNo(orderSou.getOrderNo()); | 
|---|
|  |  |  | orderDetl.setStatus(1); | 
|---|
|  |  |  | orderDetl.setCreateTime(orderSou.getCreateTime()); | 
|---|
|  |  |  | orderDetl.setCreateBy(orderSou.getCreateBy()); | 
|---|
|  |  |  | orderDetl.setUpdateTime(orderSou.getUpdateTime()); | 
|---|
|  |  |  | orderDetl.setUpdateBy(orderSou.getUpdateBy()); | 
|---|
|  |  |  | orderDetl.setId(null); | 
|---|
|  |  |  | orderDetl.setRemark(JSON.toJSONString(nccSaleXsfhmxWms)); | 
|---|
|  |  |  | insertList.add(orderDetl); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | isused -= orderStock.doubleValue(); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | throw new CoolException("重整出库订单【orderNo = " + order.getOrderNo() + "】明细失败,ERP原始数据为空"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (OrderDetl orderDetl : insertList) { | 
|---|
|  |  |  | if (!orderDetlService.insert(orderDetl)) { | 
|---|
|  |  |  | throw new CoolException("重整出库订单【orderNo = " + order.getOrderNo() + "】明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | //                OrderDetl orderDetl = new OrderDetl(); | 
|---|
|  |  |  | //                orderDetl.sync(wrkDetl); | 
|---|
|  |  |  | //                orderDetl.setQty(wrkDetl.getAnfme()); | 
|---|
|  |  |  | //                orderDetl.setOrderId(orderSou.getId()); | 
|---|
|  |  |  | //                orderDetl.setOrderNo(orderSou.getOrderNo()); | 
|---|
|  |  |  | //                orderDetl.setStatus(1); | 
|---|
|  |  |  | //                orderDetl.setCreateTime(orderSou.getCreateTime()); | 
|---|
|  |  |  | //                orderDetl.setCreateBy(orderSou.getCreateBy()); | 
|---|
|  |  |  | //                orderDetl.setUpdateTime(orderSou.getUpdateTime()); | 
|---|
|  |  |  | //                orderDetl.setUpdateBy(orderSou.getUpdateBy()); | 
|---|
|  |  |  | //                orderDetl.setId(null); | 
|---|
|  |  |  | //                //先按照批次匹配,再按照无批次号批次,因为销售发货,批次号可能带,有可能不携带,所以就会有问题;而且考虑到一条订单里如果相同物料,一条带批次,一条不带批次,情况 | 
|---|
|  |  |  | //                for (OrderDetl xxx : old) { | 
|---|
|  |  |  | //                    if (xxx.beSimilar(wrkDetl)) { | 
|---|
|  |  |  | //                        if(Cools.isEmpty(orderDetl.getRemark())) { | 
|---|
|  |  |  | //                            orderDetl.setRemark(xxx.getRemark()); | 
|---|
|  |  |  | //                        }else { | 
|---|
|  |  |  | //                            NccSaleXsfhmxWms currentData = JSONObject.parseObject(orderDetl.getRemark(), NccSaleXsfhmxWms.class); | 
|---|
|  |  |  | //                            if (currentData == null) { | 
|---|
|  |  |  | //                                continue; | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                            NccSaleXsfhmxWms nextData = JSONObject.parseObject(xxx.getRemark(), NccSaleXsfhmxWms.class); | 
|---|
|  |  |  | //                            if (nextData == null) { | 
|---|
|  |  |  | //                                continue; | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                            BigDecimal currentFslDecimal = currentData.getNastnum(); | 
|---|
|  |  |  | //                            BigDecimal nextFslDecimal = nextData.getNastnum(); | 
|---|
|  |  |  | //                            if(currentFslDecimal.doubleValue() < nextFslDecimal.doubleValue()) { | 
|---|
|  |  |  | //                                orderDetl.setRemark(xxx.getRemark()); | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //                if (Cools.isEmpty(orderDetl.getRemark())) { | 
|---|
|  |  |  | //                    for (OrderDetl xxx : old) { | 
|---|
|  |  |  | //                        if (xxx.beSimilarByWrkDetl(wrkDetl)) { | 
|---|
|  |  |  | //                            if(Cools.isEmpty(orderDetl.getRemark())) { | 
|---|
|  |  |  | //                                orderDetl.setRemark(xxx.getRemark()); | 
|---|
|  |  |  | //                            }else { | 
|---|
|  |  |  | //                                NccSaleXsfhmxWms currentData = JSONObject.parseObject(orderDetl.getRemark(), NccSaleXsfhmxWms.class); | 
|---|
|  |  |  | //                                if (currentData == null) { | 
|---|
|  |  |  | //                                    continue; | 
|---|
|  |  |  | //                                } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                                NccSaleXsfhmxWms nextData = JSONObject.parseObject(xxx.getRemark(), NccSaleXsfhmxWms.class); | 
|---|
|  |  |  | //                                if (nextData == null) { | 
|---|
|  |  |  | //                                    continue; | 
|---|
|  |  |  | //                                } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                                BigDecimal currentFslDecimal = currentData.getNastnum(); | 
|---|
|  |  |  | //                                BigDecimal nextFslDecimal = nextData.getNastnum(); | 
|---|
|  |  |  | //                                if(currentFslDecimal.doubleValue() < nextFslDecimal.doubleValue()) { | 
|---|
|  |  |  | //                                    orderDetl.setRemark(xxx.getRemark()); | 
|---|
|  |  |  | //                                } | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                    if (Cools.isEmpty(orderDetl.getRemark())) { | 
|---|
|  |  |  | //                        throw new CoolException("重整出库订单【orderNo = " + order.getOrderNo() + "】明细失败,ERP原始数据为空"); | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //                if (!orderDetlService.insert(orderDetl)) { | 
|---|
|  |  |  | //                    throw new CoolException("重整出库订单【orderNo = " + order.getOrderNo() + "】明细失败"); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 修改订单状态 2.作业中 ===>> 4.待上报 | 
|---|
|  |  |  | if (!orderService.updateSettle(orderSou.getId(), 4L, null)) { | 
|---|
|  |  |  | throw new CoolException("服务器内部错误,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改订单状态 4.完成 ===>> 6.结束 | 
|---|
|  |  |  | OrderInAndOutUtil.updateOrder(order.getPakinPakoutStatus$(), order.getId(), 6L, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public ReturnT<String> checkDBDD(Order order) { | 
|---|
|  |  |  | DocType docType = docTypeService.selectById(order.getDocType()); | 
|---|
|  |  |  | if (null == docType) { | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!docType.getDocName().equals("集团内部调拨")) { | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Order orderSou = orderService.selectByNo(order.getOrderNo()); | 
|---|
|  |  |  | if (orderSou == null) { | 
|---|
|  |  |  | return FAIL.setMsg("订单不存在,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!orderSou.getSettle().equals(2L)) { | 
|---|
|  |  |  | return FAIL.setMsg("订单状态不正确,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<OrderDetl> orderDetls = OrderInAndOutUtil.selectByOrderId(order.getPakinPakoutStatus$(), order.getId()); | 
|---|
|  |  |  | boolean complete = true; | 
|---|
|  |  |  | //        for (OrderDetl orderDetl : orderDetls) { | 
|---|
|  |  |  | //            if (orderDetl.getAnfme() > orderDetl.getQty()) { | 
|---|
|  |  |  | //                complete = false; | 
|---|
|  |  |  | //                break; | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | if (complete) { | 
|---|
|  |  |  | List<OrderDetl> old = orderDetlService.selectByOrderId(orderSou.getId()); | 
|---|
|  |  |  | if (!orderDetlService.delete(new EntityWrapper<OrderDetl>().eq("order_no", order.getOrderNo()))) { | 
|---|
|  |  |  | throw new CoolException("重整出库订单【orderNo = " + order.getOrderNo() + "】明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | HashMap<String, List<NccSaleDbddWms>> matnrMap = new HashMap<>(); | 
|---|
|  |  |  | for (OrderDetl orderDetl : old) { | 
|---|
|  |  |  | String remark = orderDetl.getRemark(); | 
|---|
|  |  |  | if(Cools.isEmpty(remark)) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | NccSaleDbddWms currentData = JSONObject.parseObject(orderDetl.getRemark(), NccSaleDbddWms.class); | 
|---|
|  |  |  | if (currentData == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<NccSaleDbddWms> list = new ArrayList<>(); | 
|---|
|  |  |  | if (matnrMap.containsKey(orderDetl.getMatnr())) { | 
|---|
|  |  |  | list = matnrMap.get(orderDetl.getMatnr()); | 
|---|
|  |  |  | list.add(currentData); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | list.add(currentData); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | matnrMap.put(orderDetl.getMatnr(), list); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (Map.Entry<String, List<NccSaleDbddWms>> entry : matnrMap.entrySet()) { | 
|---|
|  |  |  | String matnr = entry.getKey(); | 
|---|
|  |  |  | List<NccSaleDbddWms> list = entry.getValue(); | 
|---|
|  |  |  | list.sort(Comparator.comparing(NccSaleDbddWms::getFsl).reversed()); | 
|---|
|  |  |  | matnrMap.put(matnr, list); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectAndLogByOrderNo(order.getOrderNo()); | 
|---|
|  |  |  | for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | List<OrderDetl> insertList = new ArrayList<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Double isused = wrkDetl.getWeight(); | 
|---|
|  |  |  | while (isused > 0D) { | 
|---|
|  |  |  | List<NccSaleDbddWms> list = matnrMap.get(wrkDetl.getMatnr()); | 
|---|
|  |  |  | if (!list.isEmpty()) { | 
|---|
|  |  |  | NccSaleDbddWms nccSaleDbddWms = list.get(0); | 
|---|
|  |  |  | BigDecimal orderStock = nccSaleDbddWms.getFsl(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //实际出库数量 | 
|---|
|  |  |  | double realWeight = 0D; | 
|---|
|  |  |  | BigDecimal diff = orderStock.subtract(BigDecimal.valueOf(isused)); | 
|---|
|  |  |  | if (diff.doubleValue() >= 0) { | 
|---|
|  |  |  | nccSaleDbddWms.setFsl(diff); | 
|---|
|  |  |  | list.set(0, nccSaleDbddWms); | 
|---|
|  |  |  | matnrMap.put(wrkDetl.getMatnr(), list); | 
|---|
|  |  |  | realWeight = isused; | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | list.remove(0); | 
|---|
|  |  |  | matnrMap.put(wrkDetl.getMatnr(), list); | 
|---|
|  |  |  | realWeight = orderStock.doubleValue(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //计算主数量 | 
|---|
|  |  |  | Double anfme = MatUtils.calcAnfmeFromWeight(wrkDetl.getMatnr(), realWeight); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | OrderDetl orderDetl = new OrderDetl(); | 
|---|
|  |  |  | orderDetl.sync(wrkDetl); | 
|---|
|  |  |  | orderDetl.setQty(anfme); | 
|---|
|  |  |  | orderDetl.setWeight(realWeight); | 
|---|
|  |  |  | orderDetl.setOrderId(orderSou.getId()); | 
|---|
|  |  |  | orderDetl.setOrderNo(orderSou.getOrderNo()); | 
|---|
|  |  |  | orderDetl.setStatus(1); | 
|---|
|  |  |  | orderDetl.setCreateTime(orderSou.getCreateTime()); | 
|---|
|  |  |  | orderDetl.setCreateBy(orderSou.getCreateBy()); | 
|---|
|  |  |  | orderDetl.setUpdateTime(orderSou.getUpdateTime()); | 
|---|
|  |  |  | orderDetl.setUpdateBy(orderSou.getUpdateBy()); | 
|---|
|  |  |  | orderDetl.setId(null); | 
|---|
|  |  |  | orderDetl.setRemark(JSON.toJSONString(nccSaleDbddWms)); | 
|---|
|  |  |  | insertList.add(orderDetl); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | isused -= orderStock.doubleValue(); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | throw new CoolException("重整调拨出库订单【orderNo = " + order.getOrderNo() + "】明细失败,ERP原始数据为空"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (OrderDetl orderDetl : insertList) { | 
|---|
|  |  |  | if (!orderDetlService.insert(orderDetl)) { | 
|---|
|  |  |  | throw new CoolException("重整调拨出库订单【orderNo = " + order.getOrderNo() + "】明细失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            List<WrkDetl> wrkDetls = wrkDetlService.selectAndLogByOrderNo(order.getOrderNo()); | 
|---|
|  |  |  | //            for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | //                OrderDetl orderDetl = new OrderDetl(); | 
|---|
|  |  |  | //                orderDetl.sync(wrkDetl); | 
|---|
|  |  |  | //                orderDetl.setQty(wrkDetl.getAnfme()); | 
|---|
|  |  |  | //                orderDetl.setOrderId(orderSou.getId()); | 
|---|
|  |  |  | //                orderDetl.setOrderNo(orderSou.getOrderNo()); | 
|---|
|  |  |  | //                orderDetl.setStatus(1); | 
|---|
|  |  |  | //                orderDetl.setCreateTime(orderSou.getCreateTime()); | 
|---|
|  |  |  | //                orderDetl.setCreateBy(orderSou.getCreateBy()); | 
|---|
|  |  |  | //                orderDetl.setUpdateTime(orderSou.getUpdateTime()); | 
|---|
|  |  |  | //                orderDetl.setUpdateBy(orderSou.getUpdateBy()); | 
|---|
|  |  |  | //                orderDetl.setId(null); | 
|---|
|  |  |  | //                //先按照批次匹配,再按照无批次号批次,因为销售发货,批次号可能带,有可能不携带,所以就会有问题;而且考虑到一条订单里如果相同物料,一条带批次,一条不带批次,情况 | 
|---|
|  |  |  | //                for (OrderDetl xxx : old) { | 
|---|
|  |  |  | //                    if (xxx.beSimilar(wrkDetl)) { | 
|---|
|  |  |  | //                        if(Cools.isEmpty(orderDetl.getRemark())) { | 
|---|
|  |  |  | //                            orderDetl.setRemark(xxx.getRemark()); | 
|---|
|  |  |  | //                        }else { | 
|---|
|  |  |  | //                            NccSaleDbddWms currentData = JSONObject.parseObject(orderDetl.getRemark(), NccSaleDbddWms.class); | 
|---|
|  |  |  | //                            if (currentData == null) { | 
|---|
|  |  |  | //                                continue; | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                            NccSaleDbddWms nextData = JSONObject.parseObject(xxx.getRemark(), NccSaleDbddWms.class); | 
|---|
|  |  |  | //                            if (nextData == null) { | 
|---|
|  |  |  | //                                continue; | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                            BigDecimal currentFslDecimal = currentData.getFsl(); | 
|---|
|  |  |  | //                            BigDecimal nextFslDecimal = nextData.getFsl(); | 
|---|
|  |  |  | //                            if(currentFslDecimal.doubleValue() < nextFslDecimal.doubleValue()) { | 
|---|
|  |  |  | //                                orderDetl.setRemark(xxx.getRemark()); | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //                if (Cools.isEmpty(orderDetl.getRemark())) { | 
|---|
|  |  |  | //                    for (OrderDetl xxx : old) { | 
|---|
|  |  |  | //                        if (xxx.beSimilarByWrkDetl(wrkDetl)) { | 
|---|
|  |  |  | //                            if(Cools.isEmpty(orderDetl.getRemark())) { | 
|---|
|  |  |  | //                                orderDetl.setRemark(xxx.getRemark()); | 
|---|
|  |  |  | //                            }else { | 
|---|
|  |  |  | //                                NccSaleDbddWms currentData = JSONObject.parseObject(orderDetl.getRemark(), NccSaleDbddWms.class); | 
|---|
|  |  |  | //                                if (currentData == null) { | 
|---|
|  |  |  | //                                    continue; | 
|---|
|  |  |  | //                                } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                                NccSaleDbddWms nextData = JSONObject.parseObject(xxx.getRemark(), NccSaleDbddWms.class); | 
|---|
|  |  |  | //                                if (nextData == null) { | 
|---|
|  |  |  | //                                    continue; | 
|---|
|  |  |  | //                                } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                                BigDecimal currentFslDecimal = currentData.getFsl(); | 
|---|
|  |  |  | //                                BigDecimal nextFslDecimal = nextData.getFsl(); | 
|---|
|  |  |  | //                                if(currentFslDecimal.doubleValue() < nextFslDecimal.doubleValue()) { | 
|---|
|  |  |  | //                                    orderDetl.setRemark(xxx.getRemark()); | 
|---|
|  |  |  | //                                } | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //                    if (Cools.isEmpty(orderDetl.getRemark())) { | 
|---|
|  |  |  | //                        throw new CoolException("重整出库订单【orderNo = " + order.getOrderNo() + "】明细失败,ERP原始数据为空"); | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //                if (!orderDetlService.insert(orderDetl)) { | 
|---|
|  |  |  | //                    throw new CoolException("重整出库订单【orderNo = " + order.getOrderNo() + "】明细失败"); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 修改订单状态 2.作业中 ===>> 4.待上报 | 
|---|
|  |  |  | if (!orderService.updateSettle(orderSou.getId(), 4L, null)) { | 
|---|
|  |  |  | throw new CoolException("服务器内部错误,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改订单状态 4.完成 ===>> 6.结束 | 
|---|
|  |  |  | OrderInAndOutUtil.updateOrder(order.getPakinPakoutStatus$(), order.getId(), 6L, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public ReturnT<String> startOrderReport(Order order) { | 
|---|
|  |  |  | DocType docType = docTypeService.selectById(order.getDocType()); | 
|---|
|  |  |  | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<OrderDetl> orderDetls = orderDetlService.selectByOrderId(order.getId()); | 
|---|
|  |  |  | // 入库完成上报 | 
|---|
|  |  |  | if (docType.getPakin() == 1) { | 
|---|
|  |  |  | MesPakinParam pakinParam = new MesPakinParam(); | 
|---|
|  |  |  | pakinParam.setPakinTime(DateUtils.convert(order.getUpdateTime())); | 
|---|
|  |  |  | pakinParam.setLgortFrom("5008"); | 
|---|
|  |  |  | pakinParam.setLgortTo("5006"); | 
|---|
|  |  |  | for (OrderDetl orderDetl : orderDetls) { | 
|---|
|  |  |  | String serial = Cools.isEmpty(orderDetl.getBatch()) ? "" : orderDetl.getBatch(); | 
|---|
|  |  |  | pakinParam.getList().add(new MesPakinParam.Detl(orderDetl.getMatnr() + (Cools.isEmpty(serial) ? "" : "-" + serial), orderDetl.getAnfme())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String response = ""; | 
|---|
|  |  |  | boolean success = false; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | response = new HttpHandler.Builder() | 
|---|
|  |  |  | .setUri(MesConstant.URL) | 
|---|
|  |  |  | .setPath(MesConstant.PAKIN_URL) | 
|---|
|  |  |  | .setJson(JSON.toJSONString(pakinParam)) | 
|---|
|  |  |  | .build() | 
|---|
|  |  |  | .doPost(); | 
|---|
|  |  |  | JSONObject jsonObject = JSON.parseObject(response); | 
|---|
|  |  |  | if (jsonObject.getInteger("code").equals(200)) { | 
|---|
|  |  |  | success = true; | 
|---|
|  |  |  | // 修改订单状态 4.完成 ===>> 6.已上报 | 
|---|
|  |  |  | if (!orderService.updateSettle(order.getId(), 6L, null)) { | 
|---|
|  |  |  | throw new CoolException("服务器内部错误,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | log.error("请求接口失败!!!url:{};request:{};response:{}", MesConstant.URL+MesConstant.PAKIN_URL, JSON.toJSONString(pakinParam), response); | 
|---|
|  |  |  | throw new CoolException("上报mes系统失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | log.error("fail", e); | 
|---|
|  |  |  | //            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); | 
|---|
|  |  |  | return FAIL.setMsg(e.getMessage()); | 
|---|
|  |  |  | } finally { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | // 保存接口日志 | 
|---|
|  |  |  | apiLogService.save( | 
|---|
|  |  |  | "成品库入库上报", | 
|---|
|  |  |  | MesConstant.URL + MesConstant.PAKIN_URL, | 
|---|
|  |  |  | null, | 
|---|
|  |  |  | "127.0.0.1", | 
|---|
|  |  |  | JSON.toJSONString(pakinParam), | 
|---|
|  |  |  | response, | 
|---|
|  |  |  | success | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } catch (Exception e) { log.error("", e); } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 出库完成上报 | 
|---|
|  |  |  | if (docType.getPakout() == 1) { | 
|---|
|  |  |  | MesPakoutParam pakoutParam = new MesPakoutParam(); | 
|---|
|  |  |  | pakoutParam.setTag(!order.getDocType$().equalsIgnoreCase("手动出库单")); | 
|---|
|  |  |  | pakoutParam.setPakoutTime(DateUtils.convert(order.getUpdateTime())); | 
|---|
|  |  |  | pakoutParam.setLgortFrom("5006"); | 
|---|
|  |  |  | pakoutParam.setLgortTo("1111"); | 
|---|
|  |  |  | if (!pakoutParam.isTag()) { | 
|---|
|  |  |  | pakoutParam.setKunnr("C1000"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | pakoutParam.setOrderNo(order.getOrderNo()); | 
|---|
|  |  |  | for (OrderDetl orderDetl : orderDetls) { | 
|---|
|  |  |  | String serial = Cools.isEmpty(orderDetl.getBatch()) ? "" : orderDetl.getBatch(); | 
|---|
|  |  |  | pakoutParam.getList().add(new MesPakoutParam.Detl(orderDetl.getMatnr() + (Cools.isEmpty(serial) ? "" : "-" + serial), orderDetl.getAnfme())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String response = ""; | 
|---|
|  |  |  | boolean success = false; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | response = new HttpHandler.Builder() | 
|---|
|  |  |  | .setUri(MesConstant.URL) | 
|---|
|  |  |  | .setPath(MesConstant.PAKOUT_URL) | 
|---|
|  |  |  | .setJson(JSON.toJSONString(pakoutParam)) | 
|---|
|  |  |  | .build() | 
|---|
|  |  |  | .doPost(); | 
|---|
|  |  |  | JSONObject jsonObject = JSON.parseObject(response); | 
|---|
|  |  |  | if (jsonObject.getInteger("code").equals(200)) { | 
|---|
|  |  |  | success = true; | 
|---|
|  |  |  | // 修改订单状态 4.完成 ===>> 6.已上报 | 
|---|
|  |  |  | if (!orderService.updateSettle(order.getId(), 6L, null)) { | 
|---|
|  |  |  | throw new CoolException("服务器内部错误,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | log.error("请求接口失败!!!url:{};request:{};response:{}", MesConstant.URL+MesConstant.PAKOUT_URL, JSON.toJSONString(pakoutParam), response); | 
|---|
|  |  |  | throw new CoolException("上报mes系统失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | log.error("fail", e); | 
|---|
|  |  |  | //            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); | 
|---|
|  |  |  | return FAIL.setMsg(e.getMessage()); | 
|---|
|  |  |  | } finally { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | // 保存接口日志 | 
|---|
|  |  |  | apiLogService.save( | 
|---|
|  |  |  | "成品库出库上报", | 
|---|
|  |  |  | MesConstant.URL + MesConstant.PAKOUT_URL, | 
|---|
|  |  |  | null, | 
|---|
|  |  |  | "127.0.0.1", | 
|---|
|  |  |  | JSON.toJSONString(pakoutParam), | 
|---|
|  |  |  | response, | 
|---|
|  |  |  | success | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } catch (Exception e) { log.error("", e); } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | reportToThirdService.report(order, orderDetls, docType); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | return FAIL; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public ReturnT<String> reportCheck(InventoryCheckOrder checkOrder) { | 
|---|
|  |  |  | List<InventoryCheckOrderDetl> checkOrderDetls = inventoryCheckOrderDetlService.selectList(new EntityWrapper<InventoryCheckOrderDetl>().eq("order_no", checkOrder.getOrderNo())); | 
|---|
|  |  |  | for (InventoryCheckOrderDetl checkOrderDetl : checkOrderDetls) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return SUCCESS; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|