From 9c26dd4a96753898fb5eca6bd3bdbaf300fbe30b Mon Sep 17 00:00:00 2001 From: LSH Date: 星期五, 15 十二月 2023 09:40:38 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java | 133 ++++++++++++++++++++++++++++++++++---------- 1 files changed, 103 insertions(+), 30 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 bb73f24..2c7e32a 100644 --- a/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/MobileServiceImpl.java @@ -958,33 +958,42 @@ @Override public R manDetlOrigin(JSONObject json, User user) { String jsonLocNo = (String) json.get("locNo"); //鑾峰彇搴撲綅鐮� + String jsonCode = (String) json.get("code"); //鑾峰彇鏉$爜 + String jsonOrigin = (String) json.get("origin"); //鑾峰彇鏉ユ簮鍦� + OriginRule originRule = originRuleService.selectOne(new EntityWrapper<OriginRule>() + .eq("origin_address", jsonOrigin)); + + String code = "0"; + String weight = "0"; + String date = "0"; + try{ + if (originRule.getStartCode() != 0 && originRule.getEndCode() !=0){ + code = jsonCode.substring(originRule.getStartCode() - 1, originRule.getEndCode()); + } + if (originRule.getStartWeight() != 0 && originRule.getEndWeight() !=0){ + weight = jsonCode.substring(originRule.getStartWeight() - 1, originRule.getEndWeight()); + } + if (originRule.getStartDate() != 0 && originRule.getEndDate() !=0){ + date = jsonCode.substring(originRule.getStartDate() - 1, originRule.getEndDate()); + } + }catch (Exception e){ + return R.error("鏉$爜浣嶇疆鏈夎"); + } + Node node = nodeService.selectOne(new EntityWrapper<Node>().eq("name", jsonLocNo)); //鑾峰彇瀵瑰簲搴撲綅淇℃伅 + if (Cools.isEmpty(node)){ + return R.error("鏈煡璇㈠埌搴撲綅淇℃伅"); + } JSONArray combMats = json.getJSONArray("combMats"); for (int i = 0; i < combMats.size(); i++) { - DetlOriginDTO jsonOriginDetl = combMats.getObject(i, DetlOriginDTO.class); - OriginRule originRule = originRuleService.selectOne(new EntityWrapper<OriginRule>() - .eq("origin_address", jsonOriginDetl.getOrigin())); - String code = "0"; - String weight = "0"; - String date = "0"; - try{ - if (originRule.getStartCode() != 0 && originRule.getEndCode() !=0){ - code = jsonOriginDetl.getMatnr().substring(originRule.getStartCode() - 1, originRule.getEndCode()); - } - if (originRule.getStartWeight() != 0 && originRule.getEndWeight() !=0){ - weight = jsonOriginDetl.getMatnr().substring(originRule.getStartWeight() - 1, originRule.getEndWeight()); - } - if (originRule.getStartDate() != 0 && originRule.getEndDate() !=0){ - date = jsonOriginDetl.getMatnr().substring(originRule.getStartDate() - 1, originRule.getEndDate()); - } - }catch (Exception e){ - return R.error("鏉$爜浣嶇疆鏈夎"); + OrderDetl jsonOriginDetl = combMats.getObject(i, OrderDetl.class); + + Mat mat = matService.selectByMatnr(jsonOriginDetl.getMatnr()); + if (Cools.isEmpty(mat)){ + return R.error("鏈煡璇㈠埌鍟嗗搧淇℃伅"); } - Node node = nodeService.selectOne(new EntityWrapper<Node>().eq("name", jsonLocNo)); //鑾峰彇瀵瑰簲搴撲綅淇℃伅 - if (Cools.isEmpty(node)){ - return R.error("鏈煡璇㈠埌搴撲綅淇℃伅"); - } - Wrapper<ManLocDetl> manLocDetlWrapper = new EntityWrapper<ManLocDetl>().eq("loc_no", jsonLocNo).eq("matnr", jsonOriginDetl.getMatnr()); + + Wrapper<ManLocDetl> manLocDetlWrapper = new EntityWrapper<ManLocDetl>().eq("loc_no", jsonLocNo).eq("matnr", jsonOriginDetl.getMatnr()).eq("batch",date); ManLocDetl manLocDetl1 = manLocDetlService.selectOne(manLocDetlWrapper); if(!Cools.isEmpty(manLocDetl1)){ BigDecimal inAnfme = BigDecimal.valueOf(jsonOriginDetl.getAnfme()); @@ -999,14 +1008,75 @@ }else { Date now = new Date(); ManLocDetl manLocDetl = new ManLocDetl(); //鍒濆鍖栧簱瀛樺疄浣撶被 - manLocDetl.setLocNo(node.getName()); + manLocDetl.sync(mat); + manLocDetl.setLocNo(node.getUuid()); manLocDetl.setNodeId(node.getId()); // manLocDetl.setZpallet(waitPakin.getZpallet()); manLocDetl.setAnfme(jsonOriginDetl.getAnfme()); - manLocDetl.setMatnr(jsonOriginDetl.getMatnr()); - manLocDetl.setMaktx(code); - manLocDetl.setWeight(Double.valueOf( weight)); - manLocDetl.setUnit(date); + manLocDetl.setName(jsonCode); + manLocDetl.setModel(code); + manLocDetl.setWeight(Double.valueOf(weight)); + manLocDetl.setBatch(date); + manLocDetl.setCustName(jsonOriginDetl.getOrigin()); + manLocDetl.setStatus(1); + manLocDetl.setCreateBy(user.getId()); + manLocDetl.setCreateTime(now); + manLocDetl.setUpdateBy(user.getId()); + manLocDetl.setModiTime(now); + // manLocDetl.setOrderNo(waitPakin.getOrderNo()); + manLocDetl.setStockFreeze(1); + + if (!manLocDetlService.insert(manLocDetl)){ //鏁版嵁搴撴彃鍏ュ疄浣撶被淇℃伅 + return R.error("鐗╂枡淇℃伅鍏ュ簱澶辫触"); + } + } + + } + return R.ok(); + } + + @Override + public R manDetlOrigInNo(JSONObject json, User user) { + String jsonLocNo = (String) json.get("locNo"); //鑾峰彇搴撲綅鐮� + + Node node = nodeService.selectOne(new EntityWrapper<Node>().eq("name", jsonLocNo)); //鑾峰彇瀵瑰簲搴撲綅淇℃伅 + if (Cools.isEmpty(node)){ + return R.error("鏈煡璇㈠埌搴撲綅淇℃伅"); + } + + JSONArray combMats = json.getJSONArray("combMats"); + for (int i = 0; i < combMats.size(); i++) { + OrderDetl jsonOriginDetl = combMats.getObject(i, OrderDetl.class); + + Mat mat = matService.selectByMatnr(jsonOriginDetl.getMatnr()); + if (Cools.isEmpty(mat)){ + return R.error("鏈煡璇㈠埌鍟嗗搧淇℃伅"); + } + + Wrapper<ManLocDetl> manLocDetlWrapper = new EntityWrapper<ManLocDetl>().eq("loc_no", jsonLocNo).eq("matnr", jsonOriginDetl.getMatnr()).eq("batch",jsonOriginDetl.getBatch()); + ManLocDetl manLocDetl1 = manLocDetlService.selectOne(manLocDetlWrapper); + if(!Cools.isEmpty(manLocDetl1)){ + BigDecimal inAnfme = BigDecimal.valueOf(jsonOriginDetl.getAnfme()); + BigDecimal anfme = BigDecimal.valueOf(manLocDetl1.getAnfme()); + + BigDecimal sum = anfme.add(inAnfme); + manLocDetl1.setAnfme(sum.doubleValue()); + if (!manLocDetlService.update(manLocDetl1,manLocDetlWrapper)) { + return R.error("鐗╂枡淇℃伅涓婃灦澶辫触"); + } + + }else { + Date now = new Date(); + ManLocDetl manLocDetl = new ManLocDetl(); //鍒濆鍖栧簱瀛樺疄浣撶被 + manLocDetl.sync(mat); + manLocDetl.setLocNo(node.getUuid()); + manLocDetl.setNodeId(node.getId()); +// manLocDetl.setZpallet(waitPakin.getZpallet()); + manLocDetl.setAnfme(jsonOriginDetl.getAnfme()); + manLocDetl.setName(""); + manLocDetl.setModel(""); + manLocDetl.setWeight(jsonOriginDetl.getAnfme()); + manLocDetl.setBatch(jsonOriginDetl.getBatch()); manLocDetl.setCustName(jsonOriginDetl.getOrigin()); manLocDetl.setStatus(1); manLocDetl.setCreateBy(user.getId()); @@ -1031,9 +1101,12 @@ JSONArray combMats = json.getJSONArray("combMats"); for (int i = 0; i < combMats.size(); i++) { - DetlOriginDTO jsonOriginDetl = combMats.getObject(i, DetlOriginDTO.class); - Wrapper<ManLocDetl> manLocDetlWrapper = new EntityWrapper<ManLocDetl>().eq("loc_no", jsonLocNo).eq("matnr", jsonOriginDetl.getMatnr()); + OrderDetl jsonOriginDetl = combMats.getObject(i, OrderDetl.class); + Wrapper<ManLocDetl> manLocDetlWrapper = new EntityWrapper<ManLocDetl>().eq("loc_no", jsonLocNo).eq("matnr", jsonOriginDetl.getMatnr()).eq("batch", jsonOriginDetl.getBatch()); ManLocDetl manLocDetl = manLocDetlService.selectOne(manLocDetlWrapper); + if (Cools.isEmpty(manLocDetl)){ + return R.error("鏈晢鍝佹槑缁嗕俊鎭�!搴撲綅鍙凤細"+jsonLocNo+";鍟嗗搧缂栧彿锛�"+jsonOriginDetl.getMatnr()+"鎵规锛�"+jsonOriginDetl.getBatch()); + } BigDecimal outAnfme = BigDecimal.valueOf(jsonOriginDetl.getAnfme()); BigDecimal anfme = BigDecimal.valueOf(manLocDetl.getAnfme()); -- Gitblit v1.9.1