From 4a615ac9fb9a871a53ee071bf2046c41e8caad19 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@63.com> Date: 星期一, 28 三月 2022 11:13:42 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java | 85 +++++++++++++++++++++++++++++++----------- 1 files changed, 62 insertions(+), 23 deletions(-) diff --git a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java index d78a656..58f8a31 100644 --- a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java @@ -5,11 +5,11 @@ import com.core.common.Cools; import com.core.exception.CoolException; import com.zy.asrs.entity.MatCode; +import com.zy.asrs.entity.Order; +import com.zy.asrs.entity.OrderDetl; import com.zy.asrs.entity.WaitPakin; import com.zy.asrs.entity.param.CombParam; -import com.zy.asrs.service.MatCodeService; -import com.zy.asrs.service.MobileService; -import com.zy.asrs.service.WaitPakinService; +import com.zy.asrs.service.*; import com.zy.asrs.utils.VersionUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -28,6 +28,10 @@ private MatCodeService matCodeService; @Autowired private WaitPakinService waitPakinService; + @Autowired + private OrderService orderService; + @Autowired + private OrderDetlService orderDetlService; @Override @Transactional @@ -35,31 +39,66 @@ if (Cools.isEmpty(param.getBarcode()) || param.getCombMats().isEmpty()) { throw new CoolException(BaseRes.PARAM); } - int count = waitPakinService.selectCount(new EntityWrapper<WaitPakin>(). - eq("zpallet", param.getBarcode()).eq("io_status", "N")); - if (count > 0) { + // 鍒ゆ柇鏄惁鏈夌浉鍚屾潯鐮佺殑鏁版嵁 + if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>(). + eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) { throw new CoolException("鏉$爜鏁版嵁宸插瓨鍦�"); } - for (CombParam.CombMat combMat : param.getCombMats()) { - MatCode matCode = matCodeService.selectById(combMat.getMatNo()); - if (Cools.isEmpty(matCode)) { - throw new CoolException("鐗╂枡鏁版嵁閿欒"); - } - WaitPakin waitPakin = new WaitPakin(); - waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮� - waitPakin.setStatus("Y"); // 鐘舵�� - waitPakin.setAnfme(combMat.getCount()); // 鏁伴噺 - waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� - waitPakin.setAppeUser(userId); - waitPakin.setAppeTime(new Date()); - waitPakin.setModiUser(userId); - waitPakin.setModiTime(new Date()); - VersionUtils.setWaitPakIn(waitPakin, matCode); + Date now = new Date(); + // 鏃犲崟缁勬墭 + if (Cools.isEmpty(param.getOrderNo())) { + for (CombParam.CombMat combMat : param.getCombMats()) { + MatCode matCode = matCodeService.selectById(combMat.getMatNo()); + if (Cools.isEmpty(matCode)) { + throw new CoolException("鐗╂枡鏁版嵁閿欒"); + } + WaitPakin waitPakin = new WaitPakin(); + waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮� + waitPakin.setStatus("Y"); // 鐘舵�� + waitPakin.setAnfme(combMat.getCount()); // 鏁伴噺 + waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� + waitPakin.setAppeUser(userId); + waitPakin.setAppeTime(now); + waitPakin.setModiUser(userId); + waitPakin.setModiTime(now); + VersionUtils.setWaitPakIn(waitPakin, matCode); - if (!waitPakinService.insert(waitPakin)) { - throw new CoolException("淇濆瓨鏁版嵁澶辫触"); + if (!waitPakinService.insert(waitPakin)) { + throw new CoolException("淇濆瓨鏁版嵁澶辫触"); + } + } + // 鍏宠仈缁勬墭 + } else { + Order order = orderService.selectByNo(param.getOrderNo()); + if (order.getSettle() > 2) { + throw new CoolException("鍗曟嵁缂栧彿宸茶繃鏈�"); + } + for (CombParam.CombMat comb : param.getCombMats()) { + OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), comb.getMatNo(), comb.getBatch()); + if (comb.getCount() > orderDetl.getEnableQty()) { + throw new CoolException(orderDetl.getMatnr() + "鍏ュ簱鏁伴噺涓嶅悎娉�"); + } + // 淇敼鍗曠粏鏁伴噺 + if (!orderDetlService.increase(order.getId(), comb.getMatNo(), comb.getBatch(), comb.getCount())) { + throw new CoolException("淇敼鍗曟嵁鏄庣粏鏁伴噺澶辫触"); + } + // 娣诲姞鍏ュ簱閫氱煡妗� + WaitPakin waitPakin = new WaitPakin(); + waitPakin.setZpallet(param.getBarcode()); // 鎵樼洏鐮� + waitPakin.setStatus("Y"); // 鐘舵�� + waitPakin.setAnfme(comb.getCount()); // 鏁伴噺 + waitPakin.setIoStatus("N"); // 鍏ュ嚭鐘舵�� + waitPakin.setAppeUser(userId); + waitPakin.setAppeTime(now); + waitPakin.setModiUser(userId); + waitPakin.setModiTime(now); + VersionUtils.setWaitPakIn(waitPakin, orderDetl); + if (!waitPakinService.insert(waitPakin)) { + throw new CoolException("娣诲姞鍏ュ簱閫氱煡妗eけ璐�"); + } } } + } } -- Gitblit v1.9.1