From 0916bb4ea987c0599b6af6bb8dd251a071770e05 Mon Sep 17 00:00:00 2001
From: pang.jiabao <pang_jiabao@163.com>
Date: 星期四, 23 十月 2025 14:32:15 +0800
Subject: [PATCH] 通用下拉选择框值从视图获取
---
src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java | 155 ++++++++++++++++++++++++++++++++++++---------------
1 files changed, 109 insertions(+), 46 deletions(-)
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 a460f79..080b2f9 100644
--- a/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/OpenServiceImpl.java
@@ -33,6 +33,8 @@
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
+import java.util.Map;
+import java.util.concurrent.TimeUnit;
/**
* Created by vincent on 2022/4/9
@@ -50,6 +52,8 @@
@Autowired
private OrderService orderService;
+ @Autowired
+ private OrderLogService orderLogService;
@Autowired
private OrderDetlService orderDetlService;
@Autowired
@@ -93,12 +97,12 @@
throw new CoolException(param.getOrderNo() + "鍗曟嵁宸插瓨鍦紝璇峰嬁閲嶅鎻愪氦");
}
- for (DetlDto detlDto : param.getOrderDetails()){
- if (Cools.isEmpty(detlDto) || Cools.isEmpty(detlDto.getOwnerName(),detlDto.getPayment())){
+ for (DetlDto detlDto : param.getOrderDetails()) {
+ if (Cools.isEmpty(detlDto) || Cools.isEmpty(detlDto.getOwnerName(), detlDto.getPayment())) {
throw new CoolException(param.getOrderNo() + "缂哄皯璐т富鎴栬揣鐗╁舰鎬�");
- }else {
+ } else {
LocOwner locOwner = locOwnerService.selectOne(new EntityWrapper<LocOwner>().eq("owner", detlDto.getOwnerName()));
- if (Cools.isEmpty(locOwner)){
+ if (Cools.isEmpty(locOwner)) {
LocOwner locOwner1 = new LocOwner();
locOwner1.setOwner(detlDto.getOwnerName());
locOwnerService.insert(locOwner1);
@@ -151,7 +155,7 @@
List<DetlDto> list = new ArrayList<>();
List<DetlDto> orderDetails = param.getOrderDetails();
for (DetlDto detail : orderDetails) {
- DetlDto dto = new DetlDto(detail.getMatnr(), detail.getBatch(), detail.getAnfme(),detail.getOwnerName(),detail.getPayment());
+ DetlDto dto = new DetlDto(detail.getMatnr(), detail.getBatch(), detail.getAnfme(), detail.getOwnerName(), detail.getPayment());
if (DetlDto.has(list, dto)) {
DetlDto detlDto = DetlDto.find(list, dto.getMatnr(), dto.getBatch());
assert detlDto != null;
@@ -184,9 +188,9 @@
orderDetl.setUpdateBy(9527L);
orderDetl.setUpdateTime(now);
LocOwner locOwner = locOwnerService.selectOne(new EntityWrapper<LocOwner>().eq("owner", detlDto.getOwnerName()));
- if (Cools.isEmpty(locOwner)){
+ if (Cools.isEmpty(locOwner)) {
throw new CoolException("鐢熸垚鍗曟嵁鏄庣粏澶辫触锛岃鑱旂郴绠$悊鍛�");
- }else {
+ } else {
orderDetl.setOwner(locOwner.getId().intValue());
}
orderDetl.setPayment(detlDto.getPayment());
@@ -210,12 +214,17 @@
}
orderService.remove(order.getId());
}
+ OrderLog orderLog = orderLogService.selectByNo(param.getCCode());
+ if (!Cools.isEmpty(orderLog)) {
+ throw new CoolException(param.getCCode() + "鍗曟嵁宸茬粡瀹屾垚锛屼笉闇�瑕佸啀浼犻��");
+ }
+
DocType docType = docTypeService.selectOrAdd(param.getType(), Boolean.FALSE);
Date now = new Date();
//鏌ユ壘鍋氬崟鐢ㄦ埛
User user = userService.selectOne(new EntityWrapper<User>().eq("username", param.getCMaker()));
- if(Cools.isEmpty(user)){
+ if (Cools.isEmpty(user)) {
throw new CoolException("鏈煡璇㈠埌璇ョ敤鎴�");
}
@@ -229,9 +238,9 @@
null, //
null, // 璋冩嫧椤圭洰缂栧彿
null, // 鍒濆绁ㄦ嵁鍙�
- null, // 绁ㄦ嵁鍙�
+ param.getCAccount(), // 涓讳綋
null, // 瀹㈡埛缂栧彿
- param.getCAccount(), // 瀹㈡埛
+ param.getCCusName(), // 瀹㈡埛
null, // 鑱旂郴鏂瑰紡
param.getCMaker(), // 鎿嶄綔浜哄憳
null, // 鍚堣閲戦
@@ -260,7 +269,7 @@
throw new CoolException("鐢熸垚鍗曟嵁涓绘。澶辫触锛岃鑱旂郴绠$悊鍛�");
}
// 鍗曟嵁鏄庣粏妗�
- for (OpenOrderPakoutParam.Body body : param.getADDBody()){
+ for (OpenOrderPakoutParam.Body body : param.getADDBody()) {
Mat mat = matService.selectByMatnr(body.getCInvCode());
if (Cools.isEmpty(mat)) {
throw new CoolException(body.getCInvCode() + "缂栧彿鍟嗗搧妫�绱㈠け璐ワ紝璇峰厛娣诲姞鍟嗗搧");
@@ -408,8 +417,18 @@
@Override
@Transactional
public void syncMat(MatSyncParam param) {
+
if (Cools.isEmpty(param.getMatDetails()) || param.getMatDetails().size() <= 0) {
throw new CoolException("鍟嗗搧鏁版嵁涓虹┖");
+ }
+
+ //鍒犻櫎瀛樿揣妗f
+ if (param.deleteFlag == 1) {
+ for (MatSyncParam.MatParam matParam : param.getMatDetails()) {
+ matService.delete(new EntityWrapper<Mat>().eq("matnr", matParam.getMatnr()));
+ }
+
+ return;
}
for (MatSyncParam.MatParam matParam : param.getMatDetails()) {
@@ -525,30 +544,30 @@
}
/*
- * 閫熻吘鏁板瓧瀛敓璋冪敤鎺ュ彛
- * */
+ * 閫熻吘鏁板瓧瀛敓璋冪敤鎺ュ彛
+ * */
@Override
public DigitalTwin inventoryQuantity() {
DigitalTwin digitalTwin = new DigitalTwin();
LocChartPie locUseRate = reportQueryMapper.getLocUseRate();
LocChartPie locUseRateL = reportQueryMapper.getLocUseRateL();
LocChartPie locUseRateP = reportQueryMapper.getLocUseRateP();
- if(locUseRate!=null) {
- digitalTwin.setCount(locUseRate.getOqty()+locUseRate.getFqty()+locUseRate.getUqty()+locUseRate.getXqty());
+ if (locUseRate != null) {
+ digitalTwin.setCount(locUseRate.getOqty() + locUseRate.getFqty() + locUseRate.getUqty() + locUseRate.getXqty());
digitalTwin.setOqty(locUseRate.getOqty());
digitalTwin.setFqty(locUseRate.getFqty());
digitalTwin.setUqty(locUseRate.getUqty());
digitalTwin.setXqty(locUseRate.getXqty());
}
- if(locUseRateL!=null) {
- digitalTwin.setCountL(locUseRateL.getOqty()+locUseRateL.getFqty()+locUseRateL.getUqty()+locUseRateL.getXqty());
+ if (locUseRateL != null) {
+ digitalTwin.setCountL(locUseRateL.getOqty() + locUseRateL.getFqty() + locUseRateL.getUqty() + locUseRateL.getXqty());
digitalTwin.setOqtyL(locUseRateL.getOqty());
digitalTwin.setFqtyL(locUseRateL.getFqty());
digitalTwin.setUqtyL(locUseRateL.getUqty());
digitalTwin.setXqtyL(locUseRateL.getXqty());
}
- if (locUseRateP!=null){
- digitalTwin.setCountP(locUseRateP.getOqty()+locUseRateP.getFqty()+locUseRateP.getUqty()+locUseRateP.getXqty());
+ if (locUseRateP != null) {
+ digitalTwin.setCountP(locUseRateP.getOqty() + locUseRateP.getFqty() + locUseRateP.getUqty() + locUseRateP.getXqty());
digitalTwin.setOqtyP(locUseRateP.getOqty());
digitalTwin.setFqtyP(locUseRateP.getFqty());
digitalTwin.setUqtyP(locUseRateP.getUqty());
@@ -563,9 +582,8 @@
List<OpenOrderPakoutParam> list = new ArrayList<>();
-
- for (Object o : jsonArray){
- JSONObject jsonObject = (JSONObject)o;
+ for (Object o : jsonArray) {
+ JSONObject jsonObject = (JSONObject) o;
String brand = jsonObject.get("brand").toString();
String batch = jsonObject.get("batch").toString();
Integer packageNo = Integer.parseInt(jsonObject.get("packageNo").toString());
@@ -573,11 +591,12 @@
Pla pla = plaService.selectByBatchAndPackageNo(batch, packageNo, brand);
Mat mat = matService.selectByMaktx(pla.getBrand());
//褰撶敓浜у崟鍙蜂笉涓�鑷存椂锛岄渶瑕佹柊寤轰竴涓猵aram
- if(list.size() == 0 || checkOrder(list,pla.getProOrderNo()) == null){
+ if (list.isEmpty() || (!Cools.isEmpty(pla.getProOrderNo()) && checkOrder(list, pla.getProOrderNo()) == null)) {
OpenOrderPakoutParam param = new OpenOrderPakoutParam();
- String type = Cools.isEmpty(pla.getProOrderNo()) ? "璋冩嫧鍏ュ簱鍗�" : "鐢熶骇鍏ュ簱鍗�";
- param.setcCode(pla.getProOrderNo());
- param.setcAccount(pla.getOwner());
+ param.setcMaker(json.get("user").toString());
+ String type = Cools.isEmpty(pla.getProOrderNo()) ? "璋冩嫧鍏ュ簱鍗�" : "浜ф垚鍝佸叆搴�";
+ param.setcCode(Cools.isEmpty(pla.getProOrderNo()) ? (new Date().getTime()) + "" : pla.getProOrderNo());
+ param.setcAccount(pla.getWorkshop());
param.setdDate(Utils.getDateStr(new Date()));
param.setType(type);
@@ -585,38 +604,78 @@
OpenOrderPakoutParam.Body body = new OpenOrderPakoutParam.Body();
body.setcInvCode(mat.getMatnr());
body.setiQuantity(pla.getWeightAnfme());
+ body.setcBatch(pla.getBatch());
+ body.setCPackage(pla.getPackageNo()+"");
body.setCbMemo(pla.getMemo());
bodyList.add(body);
param.setaDDBody(bodyList);
list.add(param);
- }else {
+ } else {
OpenOrderPakoutParam param = checkOrder(list, pla.getProOrderNo());
List<OpenOrderPakoutParam.Body> bodyList = param.getADDBody();
OpenOrderPakoutParam.Body body = checkOrderDetl(bodyList, mat.getMatnr());
//鏈夋柊鐨勭墝鍙峰垯娣诲姞鏂扮殑orderDetl锛屽惁鍒欑疮鍔�
- if(body == null){
+ if (body == null) {
body = new OpenOrderPakoutParam.Body();
body.setcInvCode(mat.getMatnr());
body.setiQuantity(pla.getWeightAnfme());
+ body.setcBatch(pla.getBatch());
+ body.setCPackage(pla.getPackageNo()+"");
body.setCbMemo(pla.getMemo());
bodyList.add(body);
- }else {
+ } else {
body.setiQuantity(body.getIQuantity() + pla.getWeightAnfme());
+ body.setcBatch(pla.getBatch());
+ body.setCPackage(pla.getPackageNo()+"");
}
}
}
- return doHttpRequest(list, "鍏ュ簱鍗曚笂鎶�", url, orderReportPath, null, "127.0.0.1");
+ for (OpenOrderPakoutParam param : list) {
+ doHttpRequest(param, "鍏ュ簱鍗曚笂鎶�", url, orderReportPath, null, "127.0.0.1");
+ }
+ return 200;
+ //return doHttpRequest(list, "鍏ュ簱鍗曚笂鎶�", url, orderReportPath, null, "127.0.0.1");
}
- private OpenOrderPakoutParam checkOrder(List<OpenOrderPakoutParam> list, String orderNo){
- for (OpenOrderPakoutParam param : list){
+
+ @Override
+ public List<Order> selectOrderInformation(Map<String, String> param) {
+ List<Order> list = new ArrayList<>();
+ String name = param.get("name");
+ User user = userService.selectOne(new EntityWrapper<User>().eq("username", name));
+ if (Cools.isEmpty(user)) {
+ return list;
+ }
+ List<Order> orderList = orderService.selectList(new EntityWrapper<Order>().eq("create_by", user.getId()));
+ if (Cools.isEmpty(orderList)) {
+ return list;
+ }
+ for (Order order : orderList) {
+ if (order.getSettle() == 1 || order.getSettle() == 2) {
+ List<OrderDetl> detlList = orderDetlService.selectByOrderId(order.getId());
+ order.setOrderDetls(detlList);
+ list.add(order);
+ }
+ }
+
+ return list;
+ }
+
+ private OpenOrderPakoutParam checkOrder(List<OpenOrderPakoutParam> list, String orderNo) {
+
+ for (OpenOrderPakoutParam param : list) {
+
+ if (Cools.eq("璋冩嫧鍏ュ簱鍗�", param.getType()) && Cools.isEmpty(orderNo)) {
+ return param;
+ }
+
//鍒ゆ柇鏄惁鍖呭惈閲嶅鐨勮鍗曞彿
- if(Cools.eq(param.getCCode(),orderNo)){
+ if (Cools.eq(param.getCCode(), orderNo)) {
return param;
}
}
@@ -625,11 +684,11 @@
}
- private OpenOrderPakoutParam.Body checkOrderDetl(List<OpenOrderPakoutParam.Body> bodyList, String matnr){
+ private OpenOrderPakoutParam.Body checkOrderDetl(List<OpenOrderPakoutParam.Body> bodyList, String matnr) {
- for (OpenOrderPakoutParam.Body param : bodyList){
+ for (OpenOrderPakoutParam.Body param : bodyList) {
//鍒ゆ柇鏄惁鍖呭惈閲嶅鐨勮鍗曞彿
- if(Cools.eq(param.getCInvCode(),matnr)){
+ if (Cools.eq(param.getCInvCode(), matnr)) {
return param;
}
}
@@ -638,33 +697,36 @@
}
- private int doHttpRequest(Object requestParam, String namespace, String url, String path, String appkey, String ip){
+ private int doHttpRequest(Object requestParam, String namespace, String url, String path, String appkey, String ip) {
String response = "";
boolean success = false;
try {
+ log.info("璇锋眰鍙傛暟锛歿}", requestParam);
response = new HttpHandler.Builder()
.setUri(url)
+ .setTimeout(30, TimeUnit.SECONDS)
.setPath(path)
.setJson(JSONObject.toJSONString(requestParam))
.build()
.doPost();
- JSONObject jsonObject = JSON.parseObject(response);
+ log.info("鍏ュ簱鍗曚笂鎶ヨ姹傝繑鍥炴姤鏂囷細{}", response);
- if(Cools.isEmpty(jsonObject.get("errCode"))){
- throw new CoolException(jsonObject.get("Message").toString());
+ JSONObject jsonObject = JSON.parseObject(response);
+ if (Cools.isEmpty(jsonObject.get("ErrorCode"))) {
+ throw new CoolException(jsonObject.get("ErrorMsg").toString());
}
- int code = (int) jsonObject.get("errCode");
- if(code != 0){
- throw new CoolException(jsonObject.get("errMsg").toString());
+ int code = Integer.parseInt(jsonObject.get("ErrorCode").toString());
+ if (code == 0) {
+ throw new CoolException(jsonObject.get("ErrorMsg").toString());
}
success = true;
return code;
- }catch (Exception e){
+ } catch (Exception e) {
log.error(e.getMessage());
- throw new CoolException("璋冪敤鎺ュ彛鍝嶅簲閿欒");
- }finally {
+ throw new CoolException(e.getMessage());
+ } finally {
apiLogService.save(
namespace,
url + path,
@@ -678,4 +740,5 @@
}
+
}
--
Gitblit v1.9.1