From 6d3b7e69524cdc6fd4c44fe9f37661a19a56c6ff Mon Sep 17 00:00:00 2001 From: zhang <zc857179121@qq.com> Date: 星期二, 03 六月 2025 21:08:32 +0800 Subject: [PATCH] 1 --- src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java | 95 +++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 78 insertions(+), 17 deletions(-) diff --git a/src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java b/src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java index 85cab5c..86490b6 100644 --- a/src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java +++ b/src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java @@ -1,25 +1,20 @@ package com.zy.asrs.task.handler; -import com.alibaba.fastjson.JSON; -import com.alibaba.fastjson.JSONObject; +import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.core.common.Cools; 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.entity.*; import com.zy.asrs.service.*; import com.zy.asrs.task.AbstractHandler; import com.zy.asrs.task.core.ReturnT; import com.zy.asrs.utils.OrderInAndOutUtil; import com.zy.common.model.DetlDto; -import com.zy.common.utils.HttpHandler; 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.io.IOException; import java.util.ArrayList; import java.util.List; @@ -36,6 +31,9 @@ private OrderService orderService; @Autowired private OrderDetlService orderDetlService; + + @Autowired + private InventoryCheckOrderDetlService inventoryCheckOrderDetlService; @Autowired private DocTypeService docTypeService; @@ -123,6 +121,9 @@ if (null == docType) { return SUCCESS; } +// if (docType.getDocName().equals("閿�鍞彂璐�")) { +// return SUCCESS; +// } Order orderSou = orderService.selectByNo(order.getOrderNo()); if (!orderSou.getSettle().equals(2L)) { return FAIL.setMsg("璁㈠崟鐘舵�佷笉姝g‘锛岃鑱旂郴绠$悊鍛�"); @@ -136,15 +137,29 @@ if (orderDetl.getQty().equals(0D)) { continue; } - if (orderDetlSou.beSimilar(orderDetl)) { - double v = 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); + if (!Cools.isEmpty(orderDetlSou.getBatch())){ + if (orderDetlSou.beSimilar(orderDetl)) { + double v = 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); + } + } + }else { + if (orderDetlSou.beSimilar2(orderDetl)) { + double v = 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); + } } } } @@ -162,15 +177,61 @@ } @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.getSettle().equals(2L)) { + return FAIL.setMsg("璁㈠崟鐘舵�佷笉姝g‘锛岃鑱旂郴绠$悊鍛�"); + } + + 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) { + // 淇敼璁㈠崟鐘舵�� 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()); - reportToThirdService.report(order, orderDetls, docType); + 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; + } } -- Gitblit v1.9.1