自动化立体仓库 - WMS系统
#
ytfl
2025-10-14 a516fec01d3af6fbd55fb8ec1177ff55f5b0f156
src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java
@@ -2,29 +2,27 @@
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.common.constant.MesConstant;
import com.zy.common.model.MesPakinParam;
import com.zy.common.model.MesPakoutParam;
import com.zy.common.utils.HttpHandler;
import com.zy.asrs.utils.MatUtils;
import com.zy.asrs.utils.MathUtils;
import com.zy.asrs.utils.OrderInAndOutUtil;
import com.zy.common.model.DetlDto;
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.List;
import java.math.BigDecimal;
import java.util.*;
/**
 * Created by vincent on 2020/7/7
@@ -39,122 +37,564 @@
    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> start(Order order) {
    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());
        if (null == docType) {
            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); }
        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.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(), dto.getBoxType1(), dto.getBoxType2(), dto.getBoxType3());
                assert detlDto != null;
                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(), dto.getBoxType1(), dto.getBoxType2(), dto.getBoxType3());
                assert orderDetl != null;
                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);
            }
        }
        // 出库完成上报
        if (docType.getPakout() == 1) {
            if (true) {
                return SUCCESS;
            }
            MesPakoutParam pakoutParam = new MesPakoutParam();
            pakoutParam.setTag(!order.getDocType$().equalsIgnoreCase("手动出库单"));
            pakoutParam.setPakoutTime(DateUtils.convert(order.getUpdateTime()));
            pakoutParam.setLgortFrom("5006");
            pakoutParam.setLgortTo("1111");
            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); }
            }
        for (OrderDetl orderDetl : orderDetlList) {
            orderDetl.setWorkQty(0D);
            OrderInAndOutUtil.insertOrderDetl(order.getPakinPakoutStatus$(), order, orderDetl);
        }
        // 修改订单状态 1.未作业 ===>> 2.作业中
        if (!orderService.updateSettle(order.getId(), 2L, null)) {
            throw new CoolException("服务器内部错误,请联系管理员");
        }
        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 == 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)) {
                    continue;
                }
                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());
                        orderDetl.setQty(0D);
                    }
                }
            }
        }
        for (OrderDetl orderDetlSou : orderDetlList) {
            orderDetlService.updateById(orderDetlSou);
        }
        // 修改订单状态 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> 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());
        if (null == docType) {
            return SUCCESS;
        }
        List<OrderDetl> orderDetls = orderDetlService.selectByOrderId(order.getId());
        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;
    }
}