From 7d4d4849daf849f2676899a96ceabd8ade703a32 Mon Sep 17 00:00:00 2001 From: lsh <lsh@163.com> Date: 星期二, 15 四月 2025 14:38:01 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java | 283 ++++++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 240 insertions(+), 43 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 ea00821..002d171 100644 --- a/src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java +++ b/src/main/java/com/zy/asrs/task/handler/OrderSyncHandler.java @@ -2,25 +2,31 @@ import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; +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.task.AbstractHandler; import com.zy.asrs.task.core.ReturnT; +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 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 org.springframework.transaction.interceptor.TransactionAspectSupport; +import java.util.ArrayList; import java.util.List; /** @@ -38,55 +44,246 @@ private OrderDetlService orderDetlService; @Autowired private ApiLogService apiLogService; + @Autowired + private DocTypeService docTypeService; @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("璇风瓑寰�...璁㈠崟鎵ц妗f姝e湪杞巻鍙叉。妗堬紒锛侊紒"); + } + List<OrderDetl> orderDetls = OrderInAndOutUtil.selectByOrderId(order.getPakinPakoutStatus$(), order.getId()); + if (!Cools.isEmpty(orderDetls) || !orderDetls.isEmpty()) { + return FAIL.setMsg("璇风瓑寰�...璁㈠崟鎵ц鏄庣粏妗f姝e湪杞巻鍙叉。妗堬紒锛侊紒"); + } + + // 鍗曟嵁鏄庣粏妗� + List<OrderDetl> orderDetlList = orderDetlService.selectByOrderId(order.getId()); + for (OrderDetl orderDetl : orderDetlList){ + if (orderDetl.getQty().equals(0D)){ + continue; + } + orderDetl.setWorkQty(orderDetl.getQty()); + orderDetl.setAnfme(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()); - MesPakinParam pakinParam = new MesPakinParam(); - pakinParam.setPakinTime(DateUtils.convert(order.getUpdateTime())); - pakinParam.setLgortFrom("5008"); - pakinParam.setLgortTo("5006"); - for (OrderDetl orderDetl : orderDetls) { - pakinParam.getList().add(new MesPakinParam.Detl(orderDetl.getMatnr(), 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("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝璇疯仈绯荤鐞嗗憳"); - } + 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()); + 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(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(orderDetl.getAnfme() + detail.getAnfme()); } else { - log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL+MesConstant.PAKIN_URL, JSON.toJSONString(pakinParam), response); - throw new CoolException("涓婃姤mes绯荤粺澶辫触"); + list.add(dto); + orderDetlList.add(detail); } - } catch (Exception e) { - log.error("fail", e); - TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); - return FAIL.setMsg(e.getMessage()); - } finally { + } + 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; + } + Order orderSou = orderService.selectByNo(order.getOrderNo()); + if (!orderSou.getSettle().equals(2L)){ + return FAIL.setMsg("璁㈠崟鐘舵�佷笉姝g‘锛岃鑱旂郴绠$悊鍛�"); + } + 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 = 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> startOrderReport(Order order) { + DocType docType = docTypeService.selectById(order.getDocType()); + if (null == docType) { + return SUCCESS; + } + long settle = 6L; + 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) { + if (!orderDetl.getQty().equals(orderDetl.getAnfme())){ + settle = 99L;//浜屾鐢熸垚鍗曟嵁 + } + 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 { - // 淇濆瓨鎺ュ彛鏃ュ織 -// apiLogService.save( -// "鎴愬搧搴撳叆搴撲笂鎶�", -// MesConstant.URL + MesConstant.PAKIN_URL, -// null, -// "127.0.0.1", -// JSON.toJSONString(pakinParam), -// response, -// success -// ); - } catch (Exception e) { log.error("", e); } +// 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)) { + if (true) { + success = true; + // 淇敼璁㈠崟鐘舵�� 4.瀹屾垚 ===>> 6.宸蹭笂鎶� + if (!orderService.updateSettle(order.getId(), settle, null)) { + throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝璇疯仈绯荤鐞嗗憳"); + } + } else { + log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", 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) { + if (!orderDetl.getQty().equals(orderDetl.getAnfme())){ + settle = 99L;//浜屾鐢熸垚鍗曟嵁 + } + 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)) { + if (true) { + success = true; + // 淇敼璁㈠崟鐘舵�� 4.瀹屾垚 ===>> 6.宸蹭笂鎶� + if (!orderService.updateSettle(order.getId(), settle, null)) { + throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝璇疯仈绯荤鐞嗗憳"); + } + } else { + log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", 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); } + } } return SUCCESS; } -- Gitblit v1.9.1