From 4c8c41b153db001d80a990090e2cce1669af72dc Mon Sep 17 00:00:00 2001
From: LSH
Date: 星期一, 22 五月 2023 17:04:13 +0800
Subject: [PATCH] #

---
 src/main/resources/mapper/ManLocDetlMapper.xml                    |   45 +++
 src/main/java/com/zy/asrs/controller/OpenController.java          |   20 -
 src/main/webapp/static/js/order/order.js                          |    2 
 src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java     |  351 ++++++++++++++++-------------
 src/main/java/com/zy/asrs/service/ManLocDetlService.java          |    6 
 src/main/java/com/zy/asrs/controller/MobileController.java        |   18 +
 src/main/java/com/zy/asrs/service/impl/ManLocDetlServiceImpl.java |   15 +
 src/main/java/com/zy/asrs/mapper/ManLocDetlMapper.java            |    6 
 src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java       |  209 -----------------
 src/main/java/com/zy/asrs/service/OpenService.java                |    4 
 src/main/java/com/zy/asrs/service/MobileService.java              |    5 
 11 files changed, 288 insertions(+), 393 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/MobileController.java b/src/main/java/com/zy/asrs/controller/MobileController.java
index 1e98b5e..232ba46 100644
--- a/src/main/java/com/zy/asrs/controller/MobileController.java
+++ b/src/main/java/com/zy/asrs/controller/MobileController.java
@@ -340,4 +340,22 @@
         return R.ok("鍑哄簱鎴愬姛");
     }
 
+    //骞冲簱pda涓婃灦
+    @RequestMapping("/manDetl/in")
+    public R manDetlAdd(@RequestBody JSONObject json){
+        if (json == null){
+            return R.error("浼犲叆鏁版嵁涓虹┖");
+        }
+        return mobileService.manDetlIn(json);
+    }
+
+    //骞冲簱pda涓嬫灦
+    @RequestMapping("/manDetl/out")
+    public R manDetlDelete(@RequestBody JSONObject json){
+        if (json == null){
+            return R.error("浼犲叆鏁版嵁涓虹┖");
+        }
+        return mobileService.manDetlOut(json);
+    }
+
 }
diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java
index 5ec0d66..5430a22 100644
--- a/src/main/java/com/zy/asrs/controller/OpenController.java
+++ b/src/main/java/com/zy/asrs/controller/OpenController.java
@@ -172,24 +172,4 @@
         System.out.println(JSON.toJSONString(param1));
     }
 
-
-    @RequestMapping("/manDetl/in")
-    public R manDetlAdd(@RequestBody JSONObject json){
-        if (json == null){
-            return R.error("浼犲叆鏁版嵁涓虹┖");
-        }
-        return openService.manDetlIn(json);
-    }
-
-
-    @RequestMapping("/manDetl/out")
-    public R manDetlDelete(@RequestBody JSONObject json){
-        if (json == null){
-            return R.error("浼犲叆鏁版嵁涓虹┖");
-        }
-        return openService.manDetlOut(json);
-    }
-
-
-
 }
diff --git a/src/main/java/com/zy/asrs/mapper/ManLocDetlMapper.java b/src/main/java/com/zy/asrs/mapper/ManLocDetlMapper.java
index 250a289..9114e18 100644
--- a/src/main/java/com/zy/asrs/mapper/ManLocDetlMapper.java
+++ b/src/main/java/com/zy/asrs/mapper/ManLocDetlMapper.java
@@ -83,4 +83,10 @@
     List<ManLocDetl> selectAllPage(Map<String, Object> condition);
 
     long selectAllPageSize(Map<String, Object> condition);
+
+    ManLocDetl selectInventory(String LocNo, String Matnr, String batch);
+
+    int deleteDatailed (String locNo, String matnr,String batch);
+
+    int increase(Double anfme,String locNo, String matnr,String batch);
 }
diff --git a/src/main/java/com/zy/asrs/service/ManLocDetlService.java b/src/main/java/com/zy/asrs/service/ManLocDetlService.java
index 4530bbc..1170144 100644
--- a/src/main/java/com/zy/asrs/service/ManLocDetlService.java
+++ b/src/main/java/com/zy/asrs/service/ManLocDetlService.java
@@ -62,4 +62,10 @@
 
     Page<ManLocDetl> selectAllPage(Page<ManLocDetl> param);
 
+    ManLocDetl selectInventory(String LocNo,String Matnr,String batch);
+
+    int deleteDatailed (String locNo, String matnr,String batch);
+
+    int increase(Double anfme,String locNo, String matnr,String batch);
+
 }
diff --git a/src/main/java/com/zy/asrs/service/MobileService.java b/src/main/java/com/zy/asrs/service/MobileService.java
index 973abec..c1cd82b 100644
--- a/src/main/java/com/zy/asrs/service/MobileService.java
+++ b/src/main/java/com/zy/asrs/service/MobileService.java
@@ -1,6 +1,7 @@
 package com.zy.asrs.service;
 
 import com.alibaba.fastjson.JSONObject;
+import com.core.common.R;
 import com.zy.asrs.entity.BasDevp;
 import com.zy.asrs.entity.LocDetl;
 import com.zy.asrs.entity.OrderDetl;
@@ -38,4 +39,8 @@
 
     void stockOut(OrderDetl orderDetl, BasDevp staNo, LocDetl locDetl,
                   Double curOutQty, Integer ioType, Long userId, Date now);
+
+    R manDetlIn(JSONObject json);
+
+    R manDetlOut(JSONObject json);
 }
diff --git a/src/main/java/com/zy/asrs/service/OpenService.java b/src/main/java/com/zy/asrs/service/OpenService.java
index be4655c..e6233e5 100644
--- a/src/main/java/com/zy/asrs/service/OpenService.java
+++ b/src/main/java/com/zy/asrs/service/OpenService.java
@@ -46,8 +46,4 @@
     void syncMat(MatSyncParam param);
 
     R getInOutDetl();
-
-    R manDetlIn(JSONObject json);
-
-    R manDetlOut(JSONObject json);
 }
diff --git a/src/main/java/com/zy/asrs/service/impl/ManLocDetlServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/ManLocDetlServiceImpl.java
index 1f566fe..f42392f 100644
--- a/src/main/java/com/zy/asrs/service/impl/ManLocDetlServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/ManLocDetlServiceImpl.java
@@ -186,5 +186,20 @@
         return param;
     }
 
+    @Override
+    public ManLocDetl selectInventory(String LocNo, String Matnr, String batch) {
+        return baseMapper.selectInventory(LocNo,Matnr,batch);
+    }
+
+    @Override
+    public int deleteDatailed(String locNo, String matnr, String batch) {
+        return baseMapper.deleteDatailed(locNo,matnr,batch);
+    }
+
+    @Override
+    public int increase(Double anfme,String locNo, String matnr, String batch) {
+        return baseMapper.increase(anfme,locNo,matnr,batch);
+    }
+
 
 }
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 7450d05..b965eab 100644
--- a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java
@@ -1,6 +1,7 @@
 package com.zy.asrs.service.impl;
 
 import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.baomidou.mybatisplus.mapper.Wrapper;
@@ -21,6 +22,7 @@
 import com.zy.common.model.MesCombParam;
 import com.zy.common.service.CommonService;
 import com.zy.common.utils.HttpHandler;
+import com.zy.common.utils.Synchro;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
@@ -58,9 +60,9 @@
     @Autowired
     private OpenService openService;
     @Autowired
-    private SnowflakeIdWorker snowflakeIdWorker;
+    private DocTypeService docTypeService;
     @Autowired
-    private ApiLogService apiLogService;
+    private ManPakOutService manPakOutService;
     @Autowired
     private BasCrnpService basCrnpService;
     @Autowired
@@ -354,163 +356,6 @@
 
     }
 
-//    @Override
-//    @Transactional
-//    public void packComb(CombParam param, Long userId) {
-//        if (Cools.isEmpty(param.getBarcode(), param.getCombMats())) {
-//            throw new CoolException(BaseRes.PARAM);
-//        }
-//        // 鍒ゆ柇鏄惁鏈夌浉鍚屾潯鐮佺殑鏁版嵁
-//        if (waitPakinService.selectCount(new EntityWrapper<WaitPakin>().
-//                eq("zpallet", param.getBarcode()).eq("io_status", "N")) > 0) {
-//            throw new CoolException(param.getBarcode() + "鏁版嵁姝e湪杩涜鍏ュ簱");
-//        }
-//        Date now = new Date();
-//
-//        boolean packDown = Parameter.get().getPackDown().equals("true");
-//
-//        // 鏃犲崟缁勬墭
-//        if (Cools.isEmpty(param.getOrderNo())) {
-//
-//            // 鐢熸垚鍏ュ簱閫氱煡妗�
-//            List<DetlDto> detlDtos = new ArrayList<>();
-//            param.getCombMats().forEach(elem -> {
-//                // 鎵撳寘涓婄嚎鏁版嵁鏍¢獙
-//                if (packDown) {
-//                    Pack pack = packService.selectByBarcode(elem.getMatnr());
-//                    if (pack == null) {
-//                        throw new CoolException(elem.getMatnr() + "鏉$爜鍐椾綑锛岃妫�鏌ワ紒");
-//                    }
-//                    if (pack.getSettle() != 1) {
-//                        throw new CoolException(elem.getMatnr() + "鏉$爜宸蹭笅绾匡紝璇锋鏌ワ紒");
-//                    }
-//                }
-//                Mat analyse = MatUtils.analyseMat(elem.getMatnr());
-//                // 鏉$爜銆佺墿鏂欎唬鐮併�佸簭鍒楀彿銆佹暟閲�
-//                DetlDto detlDto = new DetlDto(elem.getMatnr(), analyse.getMatnr(), analyse.getBarcode(), elem.getAnfme());
-////                DetlDto detlDto = new DetlDto(elem.getMatnr(), elem.getBatch(), elem.getAnfme());
-//                if (DetlDto.has(detlDtos, detlDto)) {
-//                    DetlDto one = DetlDto.find(detlDtos, detlDto.getMatnr(), detlDto.getBatch());
-//                    assert one != null;
-//                    one.setAnfme(one.getAnfme() + detlDto.getAnfme());
-//                } else {
-//                    detlDtos.add(detlDto);
-//                }
-//            });
-//
-//            if (packDown) {
-//                MesCombParam mesCombParam = new MesCombParam();
-//                mesCombParam.setZpallet(param.getBarcode());
-//                mesCombParam.setPakinTime(DateUtils.convert(now));
-//                mesCombParam.setLgort("5008");
-//                mesCombParam.setPlantCode("5000");
-//                mesCombParam.setFromCode("5012-20");
-//                mesCombParam.setStationCode("JJQ-PFZPDB-XX");
-//                for (DetlDto detlDto : detlDtos) {
-//                    mesCombParam.getList().add(new MesCombParam.Detl(detlDto.getOrderNo(), detlDto.getAnfme()));
-//                }
-//                String response = "";
-//                boolean success = false;
-//                try {
-//                    response = new HttpHandler.Builder()
-//                            .setUri(MesConstant.URL)
-//                            .setPath(MesConstant.PACK_DOWN_URL)
-//                            .setJson(JSON.toJSONString(mesCombParam))
-//                            .build()
-//                            .doPost();
-//                    JSONObject jsonObject = JSON.parseObject(response);
-//                    if (jsonObject.getInteger("code").equals(200)) {
-//                        success = true;
-//                    } else if (jsonObject.getInteger("code").equals(500)) {
-//                        log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL+MesConstant.PACK_DOWN_URL, JSON.toJSONString(mesCombParam), response);
-//                        throw new CoolException(jsonObject.getString("msg"));
-//                    } else {
-//                        log.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", MesConstant.URL+MesConstant.PACK_DOWN_URL, JSON.toJSONString(mesCombParam), response);
-//                        throw new CoolException("涓婃姤mes绯荤粺澶辫触");
-//                    }
-//                } catch (Exception e) {
-//                    log.error("fail", e);
-//                    throw new CoolException(e.getMessage());
-//                } finally {
-//                    try {
-//                        // 淇濆瓨鎺ュ彛鏃ュ織
-//                        apiLogService.save(
-//                                "鎵撳寘涓嬬嚎甯墭涓婃姤",
-//                                MesConstant.URL + MesConstant.PACK_DOWN_URL,
-//                                null,
-//                                "127.0.0.1",
-//                                JSON.toJSONString(mesCombParam),
-//                                response,
-//                                success
-//                        );
-//                    } catch (Exception e) { log.error("", e); }
-//                }
-//
-//            }
-//
-//            // 鐢熸垚鍏ュ簱鍗曟嵁
-//            String orderNo = "PACK" + snowflakeIdWorker.nextId();
-//            OpenOrderPakinParam openParam = new OpenOrderPakinParam();
-//            openParam.setOrderNo(orderNo);
-//            openParam.setOrderTime(DateUtils.convert(now));
-//            openParam.setOrderType("鎵撳寘鍏ュ簱鍗�");
-//            openParam.setOrderDetails(detlDtos);
-//            openService.pakinOrderCreate(openParam);
-//            Order order = orderService.selectByNo(orderNo);
-//            if (null == order) {
-//                throw new CoolException("鐢熸垚鍗曟嵁澶辫触");
-//            }
-//            if (!orderService.updateSettle(order.getId(), 2L, userId)) {
-//                throw new CoolException("淇敼鍗曟嵁鐘舵�佸け璐�");
-//            }
-//
-//            // 鐢熸垚鍏ュ簱閫氱煡妗�
-//            for (DetlDto detlDto : detlDtos) {
-//
-//                // 淇敼浣滀笟鏁伴噺 ----------------------------------------
-//                // 璁㈠崟鏄庣粏鏁伴噺鏍¢獙
-//                OrderDetl orderDetl = orderDetlService.selectItem(order.getId(), detlDto.getMatnr(), detlDto.getBatch());
-//                if (detlDto.getAnfme() > orderDetl.getEnableQty()) {
-//                    throw new CoolException(orderDetl.getMatnr() + "鍏ュ簱鏁伴噺涓嶅悎娉�");
-//                }
-//                // 淇敼璁㈠崟浣滀笟鏁伴噺
-//                if (!orderDetlService.increaseWorkQty(order.getId(), detlDto.getMatnr(), detlDto.getBatch(), detlDto.getAnfme())) {
-//                    throw new CoolException("淇敼鍗曟嵁浣滀笟鏁伴噺澶辫触");
-//                }
-//
-//                // 淇濆瓨鍏ュ簱閫氱煡妗�
-//                Mat mat = matService.selectByMatnr(detlDto.getMatnr());
-//                if (Cools.isEmpty(mat)) {
-//                    throw new CoolException(detlDto.getMatnr() + "鍟嗗搧妗f涓嶅瓨鍦�");
-//                }
-//                WaitPakin waitPakin = new WaitPakin();
-//                waitPakin.sync(mat);
-//                waitPakin.setOrderNo(orderNo);
-//                waitPakin.setBatch(detlDto.getBatch());
-//                waitPakin.setZpallet(param.getBarcode());   // 鎵樼洏鐮�
-//                waitPakin.setIoStatus("N");     // 鍏ュ嚭鐘舵��
-//                waitPakin.setAnfme(detlDto.getAnfme());  // 鏁伴噺
-//                waitPakin.setStatus("Y");    // 鐘舵��
-//                waitPakin.setAppeUser(userId);
-//                waitPakin.setAppeTime(now);
-//                waitPakin.setModiUser(userId);
-//                waitPakin.setModiTime(now);
-//                if (!waitPakinService.insert(waitPakin)) {
-//                    throw new CoolException("淇濆瓨鍏ュ簱閫氱煡妗eけ璐�");
-//                }
-//                // 淇敼鎵撳寘鏁版嵁鐘舵��
-//                Pack pack = packService.selectByBarcode(detlDto.getOrderNo());
-//                pack.setSettle(2L);
-//                pack.setUpdateTime(now);
-//                pack.setUpdateBy(userId);
-//                if (!packService.updateById(pack)) {
-//                    throw new CoolException("淇敼鎵撳寘鏁版嵁寮傚父");
-//                }
-//            }
-//
-//        }
-//    }
-
     @Override
     @Transactional
     public void pakoutByOrder(JSONObject param, Long userId) {
@@ -648,4 +493,192 @@
             throw new CoolException(locDetl.getLocNo() + "搴撲綅涓嶆槸鍦ㄥ簱鐘舵��");
         }
     }
+
+    @Transactional
+    @Override
+    public R manDetlIn(JSONObject json) {
+        Date date = new Date();
+        String jsonLocNo = (String) json.get("locNo");
+        Node node = nodeService.selectOne(new EntityWrapper<Node>()
+                .eq("name", jsonLocNo));
+        JSONArray combMats = json.getJSONArray("combMats");
+        for (int i = 0; i < combMats.size(); i++) {
+            OrderDetl jsonOrderDetl = combMats.getObject(i, OrderDetl.class);
+
+            //鏌ヨ鍗�
+            Order order = orderService.selectOne(new EntityWrapper<Order>()
+                    .eq("order_no", jsonOrderDetl.getOrderNo()));
+            if (Cools.isEmpty(node, order)) {
+                return R.error("鍙傛暟涓虹┖");
+            }
+
+            //鍒ゆ柇璁㈠崟绫诲瀷鏄惁鏄叆搴�
+            DocType docType=docTypeService.selectById(order.getDocType());
+            if(docType.getPakin()!=1 || docType.getStatus()!=1){
+                return R.error("璇ヨ鍗曟槸鍑哄簱璁㈠崟锛屾棤娉曞叆搴�");
+            }
+
+            OrderDetl orderDetl = orderDetlService.selectItem(jsonOrderDetl.getOrderNo(),jsonOrderDetl.getMatnr(),jsonOrderDetl.getBatch());
+            if (Cools.isEmpty(orderDetl)) {
+                return R.error("鍗曟嵁鏄庣粏鏈夎,璇锋鏌�");
+            }
+            if (orderDetl.getAnfme() - (jsonOrderDetl.getAnfme() + orderDetl.getWorkQty()) < 0) {
+                return R.error("鍏ュ簱鏁伴噺澶т簬鍙叆鏁伴噺");
+            }
+            //鏌ヨ骞冲簱涓槸鍚︽湁涓�鏍风殑鐗╂枡鍙凤紝鏈夌殑璇濈洿鎺ュ鍔犳暟閲�
+            ManLocDetl checkManLocDetl = manLocDetlService.selectInventory(jsonLocNo,orderDetl.getMatnr(),jsonOrderDetl.getBatch());
+            if (checkManLocDetl == null) {
+                ManLocDetl manLocDetl = new ManLocDetl();
+                Synchro.Copy(orderDetl, manLocDetl);
+                manLocDetl.setLocNo(node.getName());
+                manLocDetl.setNodeId(node.getId());
+                manLocDetl.setMatnr(orderDetl.getMatnr());
+                manLocDetl.setMaktx(jsonOrderDetl.getMaktx());
+                manLocDetl.setAnfme(jsonOrderDetl.getAnfme());
+                manLocDetl.setModiTime(date);
+                manLocDetl.setCreateTime(date);
+                manLocDetl.setBatch(jsonOrderDetl.getBatch());
+                if(!manLocDetlService.insert(manLocDetl)){
+                    return R.error("淇敼骞冲簱鐗╂枡澶辫触锛�");
+                }
+            } else {
+                if(manLocDetlService.increase(checkManLocDetl.getAnfme() + jsonOrderDetl.getAnfme(), jsonOrderDetl.getOrderNo(), jsonOrderDetl.getMaktx(), jsonOrderDetl.getBatch())<=0){
+                    return R.error("淇敼骞冲簱鐗╂枡澶辫触锛�");
+                }
+            }
+            orderDetl.setQty(orderDetl.getQty() + jsonOrderDetl.getAnfme());
+            orderDetl.setWorkQty(orderDetl.getWorkQty() + jsonOrderDetl.getAnfme());
+            orderDetl.setUpdateTime(date);
+            orderDetlService.updateById(orderDetl);
+            //鏇存柊璁㈠崟鐘舵��
+            List<OrderDetl> orderDetls=orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no",order.getOrderNo()));
+            order.setSettle(2L);
+            boolean log=true;
+            for (OrderDetl orderDetl1: orderDetls) {
+                //宸ヤ綔涓殑鏁伴噺灏忎簬鎬昏鍗曟暟鏃讹紝璁㈠崟鐘舵�佹敼涓�2锛屼綔涓氫腑
+                if(orderDetl1.getQty() < orderDetl.getAnfme()){
+                    log=false;
+                }
+            }
+            if(log){
+                order.setSettle(4L);
+            }
+            if(!orderService.updateById(order)){
+                return R.error("鏇存柊璁㈠崟鐘舵�佸け璐�");
+            }
+            orderService.checkComplete(order.getOrderNo());
+        }
+        return R.ok("涓婃灦瀹屾垚");
+    }
+
+    @Transactional
+    @Override
+    public R manDetlOut(JSONObject json) {
+        Date date = new Date();
+        String jsonLocNo = (String) json.get("locNo");
+        Node node = nodeService.selectOne(new EntityWrapper<Node>()
+                .eq("name", jsonLocNo));
+        JSONArray combMats = json.getJSONArray("combMats");
+        for (int i = 0; i < combMats.size(); i++) {
+            OrderDetl jsonOrderDetl = combMats.getObject(i, OrderDetl.class);
+            Order order = orderService.selectOne(new EntityWrapper<Order>()
+                    .eq("order_no", jsonOrderDetl.getOrderNo()));
+
+            //鍒ゆ柇璁㈠崟绫诲瀷鏄惁鏄嚭搴�
+            DocType docType=docTypeService.selectById(order.getDocType());
+            if(docType.getPakout()!=1 || docType.getStatus()!=1){
+                return R.error("璇ヨ鍗曟槸鍏ュ簱璁㈠崟锛屾棤娉曞嚭搴�");
+            }
+            if (Cools.isEmpty(node, order)) {
+                return R.error("鍙傛暟涓虹┖");
+            }
+            OrderDetl orderDetl = orderDetlService.selectItem(jsonOrderDetl.getOrderNo(),jsonOrderDetl.getMatnr(),jsonOrderDetl.getMaktx());
+            if (Cools.isEmpty(orderDetl)) {
+                return R.error("鍗曟嵁鏄庣粏鏈夎,璇锋鏌�");
+            }
+            EntityWrapper<ManPakOut> manPakOutEntityWrapper = new EntityWrapper<>();
+            manPakOutEntityWrapper.eq("loc_no",jsonLocNo);
+            manPakOutEntityWrapper.eq("matnr",jsonOrderDetl.getMatnr());
+            ManPakOut manPakOut = manPakOutService.selectOne(manPakOutEntityWrapper); //鑾峰彇鎷h揣鍗曚腑鐨勫搴旂殑璁㈠崟
+            if(manPakOut.getCount() == null){
+                manPakOut.setCount(0);
+            }
+//            if (jsonOrderDetl.getAnfme() > manPakOut.getAnfme()) { //鍒ゆ柇宸ヤ綔鏁伴噺鏄惁澶т簬鎷h揣鍗曠殑鏁伴噺
+//                return R.error("鍑哄簱鏁伴噺澶т簬鎷h揣鍗曟�绘暟閲�");
+//            }
+            if (jsonOrderDetl.getAnfme() > (manPakOut.getAnfme()-manPakOut.getCount())) { //鍒ゆ柇宸ヤ綔鏁伴噺鏄惁澶т簬鎷h揣鍗曞墿浣欏彲鍑虹殑鏁伴噺
+                return R.error("鍑哄簱鏁伴噺澶т簬鎷h揣鍗曞墿浣欏彲鍑烘暟閲�");
+            }
+            if (orderDetl.getWorkQty() - orderDetl.getQty() <jsonOrderDetl.getAnfme() ){
+                return R.error("鍑哄簱鏁伴噺澶т簬鍗曟嵁鍓╀綑鍙嚭鏁伴噺");
+            }
+            //鏌ヨ骞冲簱涓槸鍚︽湁涓�鏍风殑鐗╂枡鍙�
+            ManLocDetl checkManLocDetl = manLocDetlService.selectInventory(jsonLocNo,orderDetl.getMatnr(),orderDetl.getBatch());
+            if (checkManLocDetl == null) {
+                return R.error("璇ュ簱浣嶆病鏈夊嚭搴撶殑鐗╂枡淇℃伅");
+            }
+            if (jsonOrderDetl.getAnfme() > checkManLocDetl.getAnfme()) {
+                return R.error("鍑哄簱鏁伴噺澶т簬鍙嚭鏁伴噺");
+            }
+            Double finalQty = checkManLocDetl.getAnfme() - jsonOrderDetl.getAnfme();
+            if (finalQty < 0){
+                //  if(manLocDetlService.deleteDatailed(jsonLocNo, jsonOrderDetl.getMatnr(), jsonOrderDetl.getBatch())<=0) {
+                return R.error("鏁伴噺鏈夎锛�");
+                //   }
+            }else {
+                if(manLocDetlService.increase(finalQty, jsonLocNo, jsonOrderDetl.getMatnr(), jsonOrderDetl.getBatch())<=0){
+                    return R.error("淇敼骞冲簱鐗╂枡澶辫触锛�");
+                }
+            }
+            orderDetl.setQty(orderDetl.getQty() + jsonOrderDetl.getAnfme());
+            orderDetl.setUpdateTime(date);
+            orderDetlService.updateById(orderDetl);
+            //鏇存柊璁㈠崟鐘舵��
+            List<OrderDetl> orderDetls=orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no",order.getOrderNo()));
+            order.setSettle(2L);
+            boolean log=true;
+            for (OrderDetl orderDetl1: orderDetls) {
+                //宸ヤ綔涓殑鏁伴噺灏忎簬鎬昏鍗曟暟鏃讹紝璁㈠崟鐘舵�佹敼涓�2锛屼綔涓氫腑
+                if(orderDetl1.getQty() < orderDetl.getAnfme()){
+                    log=false;
+                }
+            }
+            if(log){
+                order.setSettle(4L);
+            }
+            if(!orderService.updateById(order)){
+                return R.error("鏇存柊璁㈠崟鐘舵�佸け璐�");
+            }
+            if(manPakOut.getCount() == null){
+                manPakOut.setCount(0);
+            }
+            manPakOut.setCount(manPakOut.getCount()+jsonOrderDetl.getAnfme().intValue());
+            if (!manPakOutService.update(manPakOut,manPakOutEntityWrapper)){
+                return R.error("鏇存柊鎷h揣鍗曞畬鎴愭暟鐩け璐�");
+            }
+            if (manPakOut.getAnfme().intValue() == manPakOut.getCount()){
+                manPakOut.setStatus(1);
+                if (!manPakOutService.update(manPakOut,manPakOutEntityWrapper)){
+                    return R.error("鏇存柊鎷h揣鍗曠姸鎬佸け璐�");
+                }
+            }
+            EntityWrapper<ManLocDetl> manLocDetlEntityWrapper = new EntityWrapper<>();
+            manLocDetlEntityWrapper.eq("loc_no",manPakOut.getLocNo());
+            manLocDetlEntityWrapper.eq("matnr",manPakOut.getMatnr());
+            if (checkManLocDetl.getAnfme().intValue() == manPakOut.getCount()){
+
+
+                if(!manLocDetlService.delete(manLocDetlEntityWrapper)){
+                    return R.error("鍒犻櫎骞冲簱搴撳瓨澶辫触");
+                }
+            }else{
+                checkManLocDetl.setStatus(1);
+                if(!manLocDetlService.update(checkManLocDetl,manLocDetlEntityWrapper)){
+                    return R.error("鏇存柊骞冲簱搴撳瓨鐘舵�佸け璐�");
+                }
+            }
+
+        }
+        return R.ok("涓嬫灦瀹屾垚");
+    }
 }
diff --git a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
index a722014..858d596 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -157,52 +157,6 @@
         }
     }
 
-//    @Override
-//    @Transactional
-//    public List<OpenOrderCompeteResult> pakinOrderComplete(OpenOrderCompleteParam param) {
-//        List<OpenOrderCompeteResult> results = new ArrayList<>();
-//        if (!Cools.isEmpty(param) && !Cools.isEmpty(param.getOrderNo())) {
-//            // 鎸囧畾璁㈠崟
-//            Order order = orderService.selectByNo(param.getOrderNo());
-//            if (null != order) {
-//                OpenOrderCompeteResult result = new OpenOrderCompeteResult();
-//                results.add(result);
-//                result.setOrderNo(order.getOrderNo());
-//                result.setOrderTime(order.getOrderTime());
-//                result.setOrderType(order.getDocType$());
-//                List<OrderDetl> orderDetls = orderDetlService.selectByOrderId(order.getId());
-//                for (OrderDetl orderDetl : orderDetls) {
-//                    result.getOrderDetails().add(new DetlDto(orderDetl.getOrderNo(), orderDetl.getMatnr(), orderDetl.getBatch(), orderDetl.getQty()));
-//                }
-//                if (order.getSettle() == 4L) {
-//                    // 淇敼璁㈠崟鐘舵�� 4.瀹屾垚 ===>> 6.宸蹭笂鎶�
-//                    if (!orderService.updateSettle(order.getId(), 6L, null)) {
-//                        throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
-//                    }
-//                }
-//            }
-//        } else {
-//            // 鎵�鏈夎鍗�
-//            List<Order> orders = orderService.selectList(new EntityWrapper<Order>().eq("settle", 4L));
-//            for (Order order : orders) {
-//                OpenOrderCompeteResult result = new OpenOrderCompeteResult();
-//                results.add(result);
-//                result.setOrderNo(order.getOrderNo());
-//                result.setOrderTime(order.getOrderTime());
-//                result.setOrderType(order.getDocType$());
-//                List<OrderDetl> orderDetls = orderDetlService.selectByOrderId(order.getId());
-//                for (OrderDetl orderDetl : orderDetls) {
-//                    result.getOrderDetails().add(new DetlDto(orderDetl.getOrderNo(), orderDetl.getMatnr(), orderDetl.getBatch(), orderDetl.getQty()));
-//                }
-//                // 淇敼璁㈠崟鐘舵�� 4.瀹屾垚 ===>> 6.宸蹭笂鎶�
-//                if (!orderService.updateSettle(order.getId(), 6L, null)) {
-//                    throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
-//                }
-//            }
-//        }
-//        return results;
-//    }
-
     @Override
     @Transactional
     public void pakoutOrderCreate(OpenOrderPakoutParam param) {
@@ -293,51 +247,6 @@
             }
         }
     }
-
-//    @Override
-//    public List<OpenOrderCompeteResult> pakoutOrderComplete(OpenOrderCompleteParam param) {
-//        List<OpenOrderCompeteResult> results = new ArrayList<>();
-//        if (!Cools.isEmpty(param) && !Cools.isEmpty(param.getOrderNo())) {
-//            // 鎸囧畾璁㈠崟
-//            Order order = orderService.selectByNo(param.getOrderNo());
-//            if (null != order) {
-//                OpenOrderCompeteResult result = new OpenOrderCompeteResult();
-//                results.add(result);
-//                result.setOrderNo(order.getOrderNo());
-//                result.setOrderTime(order.getOrderTime());
-//                result.setOrderType(order.getDocType$());
-//                List<OrderDetl> orderDetls = orderDetlService.selectByOrderId(order.getId());
-//                for (OrderDetl orderDetl : orderDetls) {
-//                    result.getOrderDetails().add(new DetlDto(orderDetl.getOrderNo(), orderDetl.getMatnr(), orderDetl.getBatch(), orderDetl.getQty()));
-//                }
-//                if (order.getSettle() == 4L) {
-//                    // 淇敼璁㈠崟鐘舵�� 4.瀹屾垚 ===>> 6.宸蹭笂鎶�
-//                    if (!orderService.updateSettle(order.getId(), 6L, null)) {
-//                        throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
-//                    }
-//                }
-//            }
-//        } else {
-//            // 鎵�鏈夎鍗�
-//            List<Order> orders = orderService.selectList(new EntityWrapper<Order>().eq("settle", 4L));
-//            for (Order order : orders) {
-//                OpenOrderCompeteResult result = new OpenOrderCompeteResult();
-//                results.add(result);
-//                result.setOrderNo(order.getOrderNo());
-//                result.setOrderTime(order.getOrderTime());
-//                result.setOrderType(order.getDocType$());
-//                List<OrderDetl> orderDetls = orderDetlService.selectByOrderId(order.getId());
-//                for (OrderDetl orderDetl : orderDetls) {
-//                    result.getOrderDetails().add(new DetlDto(orderDetl.getOrderNo(), orderDetl.getMatnr(), orderDetl.getBatch(), orderDetl.getQty()));
-//                }
-//                // 淇敼璁㈠崟鐘舵�� 4.瀹屾垚 ===>> 6.宸蹭笂鎶�
-//                if (!orderService.updateSettle(order.getId(), 6L, null)) {
-//                    throw new CoolException("鏈嶅姟鍣ㄥ唴閮ㄩ敊璇紝璇疯仈绯荤鐞嗗憳");
-//                }
-//            }
-//        }
-//        return results;
-//    }
 
     @Override
     @Transactional
@@ -576,124 +485,6 @@
     public R getInOutDetl() {
         List<InOutCountDto> top100 = wrkMastService.selectTop100();
         return R.ok().add(top100);
-    }
-
-    @Transactional
-    @Override
-    public R manDetlIn(JSONObject json) {
-        Date date = new Date();
-        String jsonLocNo = (String) json.get("locNo");
-        Node node = nodeService.selectOne(new EntityWrapper<Node>()
-                .eq("name", jsonLocNo));
-
-        String jsonOrderNo = (String) json.get("orderNo");
-        Order order = orderService.selectOne(new EntityWrapper<Order>()
-                .eq("order_no", jsonOrderNo));
-        if (Cools.isEmpty(node, order)) {
-            return R.error("鍙傛暟涓虹┖");
-        }
-
-        JSONArray combMats = json.getJSONArray("combMats");
-        for (int i = 0; i < combMats.size(); i++) {
-            OrderDetl jsonOrderDetl = combMats.getObject(i, OrderDetl.class);
-            OrderDetl orderDetl = orderDetlService.selectOne(new EntityWrapper<OrderDetl>()
-                    .eq("order_no", jsonOrderNo));
-            if (Cools.isEmpty(orderDetl)) {
-                return R.error("鍗曟嵁鏄庣粏鏈夎,璇锋鏌�");
-            }
-            if (orderDetl.getAnfme() - (jsonOrderDetl.getAnfme() + orderDetl.getQty()) < 0) {
-                return R.error("鍏ュ簱鏁伴噺澶т簬鍙叆鏁伴噺");
-            }
-            ManLocDetl checkManLocDetl = manLocDetlService.selectOne(new EntityWrapper<ManLocDetl>()
-                    .eq("loc_no", jsonLocNo)
-                    .eq("matnr", orderDetl.getMatnr()));
-            if (checkManLocDetl == null) {
-                ManLocDetl manLocDetl = new ManLocDetl();
-                Synchro.Copy(orderDetl, manLocDetl);
-                manLocDetl.setLocNo(node.getName());
-                manLocDetl.setNodeId(node.getId());
-                manLocDetl.setMatnr(orderDetl.getMatnr());
-                manLocDetl.setMaktx(orderDetl.getMaktx());
-                manLocDetl.setAnfme(orderDetl.getAnfme());
-                manLocDetl.setModiTime(date);
-                manLocDetl.setCreateTime(date);
-                manLocDetlService.insert(manLocDetl);
-            } else {
-                checkManLocDetl.setAnfme(checkManLocDetl.getAnfme() + orderDetl.getAnfme());
-                checkManLocDetl.setModiTime(date);
-                manLocDetlService.update(checkManLocDetl, new EntityWrapper<ManLocDetl>()
-                        .eq("loc_no", jsonLocNo)
-                        .eq("matnr", orderDetl.getMatnr()));
-            }
-
-            orderDetl.setQty(orderDetl.getQty() + jsonOrderDetl.getAnfme());
-            orderDetl.setUpdateTime(date);
-            orderDetlService.updateById(orderDetl);
-
-        }
-        orderService.checkComplete(order.getOrderNo());
-
-
-        return R.ok("涓婃灦瀹屾垚");
-    }
-
-    @Transactional
-    @Override
-    public R manDetlOut(JSONObject json) {
-        Date date = new Date();
-        String jsonLocNo = (String) json.get("locNo");
-        Node node = nodeService.selectOne(new EntityWrapper<Node>()
-                .eq("name", jsonLocNo));
-        String jsonOrderNo = (String) json.get("orderNo");
-        Order order = orderService.selectOne(new EntityWrapper<Order>()
-                .eq("order_no", jsonOrderNo));
-        if (Cools.isEmpty(node, order)) {
-            return R.error("鍙傛暟涓虹┖");
-        }
-
-        JSONArray combMats = json.getJSONArray("combMats");
-        for (int i = 0; i < combMats.size(); i++) {
-            OrderDetl jsonOrderDetl = combMats.getObject(i, OrderDetl.class);
-            OrderDetl orderDetl = orderDetlService.selectOne(new EntityWrapper<OrderDetl>()
-                    .eq("order_no", jsonOrderNo));
-            if (Cools.isEmpty(orderDetl)) {
-                return R.error("鍗曟嵁鏄庣粏鏈夎,璇锋鏌�");
-            }
-            EntityWrapper<ManPakOut> manPakOutEntityWrapper = new EntityWrapper<>();
-            manPakOutEntityWrapper.eq("loc_no",jsonLocNo);
-            manPakOutEntityWrapper.eq("matnr",jsonOrderDetl.getMatnr());
-            ManPakOut manPakOut = manPakOutService.selectOne(manPakOutEntityWrapper); //鑾峰彇鎷h揣鍗曚腑鐨勫搴旂殑璁㈠崟
-            if (jsonOrderDetl.getAnfme() > (manPakOut.getAnfme()-manPakOut.getCount())) { //鍒ゆ柇宸ヤ綔鏁伴噺鏄惁澶т簬鎷h揣鍗曞墿浣欏彲鍑虹殑鏁伴噺
-                return R.error("鍑哄簱鏁伴噺澶т簬鎷h揣鍗曞墿浣欏彲鍑烘暟閲�");
-            }
-            ManLocDetl manLocDetl = manLocDetlService.selectOne(new EntityWrapper<ManLocDetl>()
-                    .eq("loc_no", jsonLocNo)
-                    .eq("matnr", orderDetl.getMatnr()));
-            if (manLocDetl == null) {
-                return R.error("璇ュ簱浣嶆病鏈夊嚭搴撶殑鐗╂枡淇℃伅");
-            }
-            if (jsonOrderDetl.getAnfme() > manLocDetl.getAnfme()) {
-                return R.error("鍑哄簱鏁伴噺澶т簬鍙嚭鏁伴噺");
-            }
-            Double finalQty = manLocDetl.getAnfme() - jsonOrderDetl.getAnfme();
-            if (finalQty <= 0){
-                manLocDetlService.delete(new EntityWrapper<ManLocDetl>()
-                        .eq("loc_no", jsonLocNo)
-                        .eq("matnr", orderDetl.getMatnr()));
-            }else {
-                manLocDetl.setAnfme(finalQty);
-                manLocDetl.setModiTime(date);
-                manLocDetlService.update(manLocDetl,new EntityWrapper<ManLocDetl>()
-                        .eq("loc_no", jsonLocNo)
-                        .eq("matnr", orderDetl.getMatnr()));
-            }
-            orderDetl.setQty(orderDetl.getQty() + jsonOrderDetl.getAnfme());
-            orderDetl.setUpdateTime(date);
-            orderDetlService.updateById(orderDetl);
-
-            orderService.checkComplete(order.getOrderNo());
-        }
-        return R.ok("涓嬫灦瀹屾垚");
     }
 
 }
diff --git a/src/main/resources/mapper/ManLocDetlMapper.xml b/src/main/resources/mapper/ManLocDetlMapper.xml
index 125456a..121d2d0 100644
--- a/src/main/resources/mapper/ManLocDetlMapper.xml
+++ b/src/main/resources/mapper/ManLocDetlMapper.xml
@@ -325,4 +325,49 @@
         where node_id = #{nodeId} ;
     </update>
 
+    <select id="selectInventory" resultMap="BaseResultMap">
+        select top 1 * from man_loc_detl
+        where loc_no=#{LocNo}
+        and 1=1
+        and matnr=#{Matnr}
+        <choose>
+            <when test="batch != null and batch != ''">
+                and batch = #{batch}
+            </when>
+            <otherwise>
+                and (batch IS NULL OR batch = '')
+            </otherwise>
+        </choose>
+    </select>
+    <delete id="deleteDatailed">
+        delete from man_loc_detl
+        where loc_no = #{locNo}
+        and matnr = #{matnr}
+        <choose>
+            <when test="batch != null and batch != ''">
+                and batch = #{batch}
+            </when>
+            <otherwise>
+                and (batch IS NULL OR batch = '')
+            </otherwise>
+        </choose>
+    </delete>
+
+    <update id="increase">
+        update man_loc_detl
+        set  anfme= #{anfme}
+        , modi_time = getdate()
+        where 1=1
+        and loc_no = #{locNo}
+        and matnr = #{matnr}
+        <choose>
+            <when test="batch != null and batch!=''  ">
+                and maktx = #{batch}
+            </when>
+            <otherwise>
+                and (batch IS NULL OR batch = '')
+            </otherwise>
+        </choose>
+    </update>
+
 </mapper>
diff --git a/src/main/webapp/static/js/order/order.js b/src/main/webapp/static/js/order/order.js
index 3a7bc90..201c3ca 100644
--- a/src/main/webapp/static/js/order/order.js
+++ b/src/main/webapp/static/js/order/order.js
@@ -193,7 +193,7 @@
                             {field: 'maktx', title: '鍟嗗搧鍚嶇О', width: 160},
                             {field: 'batch', title: '鎵瑰彿'},
                             {field: 'anfme', title: '鏁伴噺'},
-                            // {field: 'workQty', title: '浣滀笟鏁伴噺'},
+                            {field: 'workQty', title: '浣滀笟鏁伴噺'},
                             {field: 'qty', title: '瀹屾垚鏁伴噺', style: 'font-weight: bold'},
                             // {field: 'unit', title: '鍗曚綅'},
                             // {

--
Gitblit v1.9.1