From e046dba174365eb8934ee1e4206f09821145e876 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期四, 21 八月 2025 13:23:22 +0800 Subject: [PATCH] no message --- zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/Impl/WcsApiServiceImpl.java | 258 +++++++++++++++++++++++---------------------------- 1 files changed, 117 insertions(+), 141 deletions(-) diff --git a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/Impl/WcsApiServiceImpl.java b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/Impl/WcsApiServiceImpl.java index 91532e1..eb14276 100644 --- a/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/Impl/WcsApiServiceImpl.java +++ b/zy-asrs-wms/src/main/java/com/zy/asrs/wms/apis/wcs/services/Impl/WcsApiServiceImpl.java @@ -4,10 +4,7 @@ import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; -import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; -import com.fasterxml.jackson.databind.cfg.CoercionAction; -import com.fasterxml.jackson.databind.cfg.CoercionInputShape; +import com.zy.asrs.framework.common.Cools; import com.zy.asrs.framework.common.R; import com.zy.asrs.framework.exception.CoolException; import com.zy.asrs.wms.apis.wcs.entity.domain.SystemProperties; @@ -23,8 +20,6 @@ import com.zy.asrs.wms.asrs.service.*; import io.jsonwebtoken.lang.Collections; import lombok.extern.slf4j.Slf4j; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.HttpEntity; import org.springframework.http.HttpHeaders; @@ -37,9 +32,9 @@ import org.springframework.web.client.RestTemplate; import javax.annotation.Resource; -import java.math.BigDecimal; import java.util.*; import java.util.stream.Collectors; +import java.util.stream.DoubleStream; @Slf4j @Service @@ -67,9 +62,10 @@ @Autowired private PlatformService platformService; - @Resource private SystemProperties systemProperties; + @Autowired + private MobileService mobileService; /** @@ -86,20 +82,20 @@ */ @Override @Transactional(rollbackFor = Exception.class) - public R containerArrivedNotify(ContainerArrivedParam arrivedParam, String taskType, Long hostId){ + public R containerArrivedNotify(ContainerArrivedParam arrivedParam, String taskType, Long hostId) { Task task = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getBarcode, arrivedParam.getContainerCode())); if (task == null) { return R.error("浠诲姟涓嶅瓨鍦紒锛�"); } - log.info("瀹瑰櫒鍒拌揪鎺ユ敹锛屼换鍔″彿锛歿}锛屽綋鍓嶇姸鎬侊細{}锛屼笂鎶ョ姸鎬侊細{}",task.getTaskNo(),task.getTaskSts$(),TaskStsType.WCS_CONTAINER_RECEIVE.desc); + log.info("瀹瑰櫒鍒拌揪鎺ユ敹锛屼换鍔″彿锛歿}锛屽綋鍓嶇姸鎬侊細{}锛屼笂鎶ョ姸鎬侊細{}, 鎺ユ敹鍙傛暟锛歿}", task.getTaskNo(), task.getTaskSts$(), TaskStsType.WCS_CONTAINER_RECEIVE.desc, JSONObject.toJSONString(arrivedParam)); - taskType = task.getTaskType() > 100 ? "outStock":"inStock"; + taskType = task.getTaskType() > 100 ? "outStock" : "inStock"; if (taskType.equals("inStock")) { if (task.getTaskSts() == 198) { return R.error("鎾涓紒锛�"); } - if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_IN.id ) { + if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_IN.id) { //DONE 鏍规嵁ESS杩斿洖鐨勫鍣ㄧ紪鐮佷慨鏀逛换鍔℃。涓殑杈撻�佺嚎璧峰浣嶇疆鑺傜偣锛屽強浠诲姟妗e鍣ㄥ埌杈剧姸鎬� taskService.update(new LambdaUpdateWrapper<Task>() .set(Task::getTaskSts, TaskStsType.WCS_CONTAINER_RECEIVE.id) @@ -107,33 +103,13 @@ .set(Task::getOriginSite, arrivedParam.getSlotCode()) .eq(Task::getBarcode, arrivedParam.getContainerCode())); } else { - log.warn("{}娌℃湁涓嬪彂浠诲姟",task.getTaskNo()); - R.error(task.getTaskNo()+"娌℃湁涓嬪彂浠诲姟"); + log.warn("{}娌℃湁涓嬪彂浠诲姟", task.getTaskNo()); + R.error(task.getTaskNo() + "娌℃湁涓嬪彂浠诲姟"); } } else { if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_ARRIVED.id - || task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_TASK_DONE.id ) { - // 鍒拌揪鎷i�変綅锛屾帶鍒舵挱绉嶅浜伅 - List<CacheSite> cacheSites = cacheSiteService.list(new LambdaQueryWrapper<CacheSite>().eq(CacheSite::getBarcode, task.getBarcode())); - if(cacheSites.size() == 0) { - log.error("鏉$爜锛歿}锛屾湭鎵惧埌鎾澧欎寒鐏�",task.getBarcode()); - throw new CoolException("鏈壘鍒版挱绉嶅"); - } - for (CacheSite cacheSite:cacheSites) { - // 鑾峰彇浠诲姟鏄庣粏鏁伴噺 - List<TaskDetl> taskDetlByTaskId = taskDetlService.getTaskDetlByTaskId(task.getId()); - double sum = taskDetlByTaskId.stream().mapToDouble(TaskDetl::getAnfme).sum(); - SlapLightControlParam slapLightControlParam = new SlapLightControlParam(); - slapLightControlParam.setControllerCode(cacheSite.getMemo()).setTagCode(cacheSite.getSiteNo()) - .setColor("GREEN").setMode("LIGHT").setDisplay(String.valueOf(sum)); - // 鍙戣捣浜伅璇锋眰 - CommonReponse response = HttpEssUtils.post("鍒拌揪鎷i�変綅锛屾挱绉嶅浜伅", HttpEssUtils.PLT_SEND_COMMAND, slapLightControlParam); - if (response.getCode().equals(0)) { - log.info("浠诲姟{}鍒拌揪鎷i�変綅锛屾挱绉嶅{}浜伅鎴愬姛",task.getTaskNo(),cacheSite.getSiteNo()); - } else { - log.info("浠诲姟{}鍒拌揪鎷i�変綅锛屾挱绉嶅{}浜伅澶辫触",task.getTaskNo(),cacheSite.getSiteNo()); - } - } + || task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_TASK_DONE.id) { + boolean update = taskService.update(new LambdaUpdateWrapper<Task>() .set(Task::getTaskSts, TaskStsType.WAVE_SEED.id) .set(Task::getOriginSite, arrivedParam.getSlotCode()) @@ -141,17 +117,16 @@ if (!update) { throw new CoolException("瀹瑰櫒鍒拌揪浠诲姟鏇存柊澶辫触锛侊紒"); } - - } else if(task.getTaskSts().equals(TaskStsType.UPDATED_OUT.id)) { + } else if (task.getTaskSts().equals(TaskStsType.UPDATED_OUT.id)) { ConveyorStarParam conveyorStarParam = new ConveyorStarParam(); conveyorStarParam.setSlotCode(task.getOriginSite()) .setContainerCode(task.getBarcode()) .setDirection("200"); // 鍑哄簱瀹屾垚锛屾竻闄よ緭閫佺嚎鏉$爜锛屽彇涓嬬瀛� - CommonReponse response = HttpEssUtils.post("娓呴櫎杈撻�佺嚎鏉$爜", HttpEssUtils.CONVEYOR_START, conveyorStarParam); - if (response.getCode().equals(200)) { - log.info("{}鍑哄簱瀹屾垚锛屾竻闄}杈撻�佺嚎鏉$爜{}鎴愬姛",task.getTaskNo(),task.getOriginSite(),task.getBarcode()); - } + CommonReponse response = HttpEssUtils.post("娓呴櫎杈撻�佺嚎鏉$爜", HttpEssUtils.CONVEYOR_START, conveyorStarParam); + if (response.getCode().equals(200)) { + log.info("{}鍑哄簱瀹屾垚锛屾竻闄}杈撻�佺嚎鏉$爜{}鎴愬姛", task.getTaskNo(), task.getOriginSite(), task.getBarcode()); + } } } @@ -173,17 +148,17 @@ .eq(Task::getTaskNo, callbackParam.getTaskCode())); if (!Collections.isEmpty(list)) { list.forEach(task -> { - log.info("瀹瑰櫒鎵ц鐘舵�佷笂鎶ワ紝浠诲姟鍙凤細{}锛屽綋鍓嶇姸鎬侊細{}锛屼笂鎶ョ姸鎬侊細{}",task.getTaskNo(),task.getTaskSts$(),callbackParam.getEventType()); + log.info("瀹瑰櫒鎵ц鐘舵�佷笂鎶ワ紝浠诲姟鍙凤細{}锛屽綋鍓嶇姸鎬侊細{}锛屼笂鎶ョ姸鎬侊細{}", task.getTaskNo(), task.getTaskSts$(), callbackParam.getEventType()); if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_ALLOCATED.event)) { return; } // ESS鍙兘閰嶇疆涓�涓姸鎬佷笂鎶ユ帴鍙o紝鏍规嵁浠诲姟鍙峰垽鏂槸鍏ュ簱浠诲姟鎴栧嚭搴撲换鍔� - String taskType = task.getTaskType() > 100 ? "outStock":"inStock"; + String taskType = task.getTaskType() > 100 ? "outStock" : "inStock"; TaskStsType taskStsType = null; if (taskType.equals("inStock")) { //鍏ュ簱浠诲姟 if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_TOTE_LOAD.event)) { //涓婃姤鍙栫鐘舵�� // if (task.getTaskSts() == TaskStsType.WCS_CONVEYOR_START.id) { - taskStsType = TaskStsType.WCS_TOTE_LOAD; + taskStsType = TaskStsType.WCS_TOTE_LOAD; // } else { // String errMsg = "浠诲姟缂栧彿锛�" + task.getTaskNo() + "鐘舵�佷负涓嶅尮閰嶏紝" + "涓嶈兘鎵ц锛�" + TaskStsType.WCS_TOTE_LOAD.desc + "浠诲姟"; // log.error(errMsg); @@ -191,7 +166,7 @@ // } } else if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_TOTE_UNLOAD.event)) { //涓婃姤鏀剧鐘舵�� // if (task.getTaskSts() == TaskStsType.WCS_TOTE_LOAD.id) { - taskStsType = TaskStsType.WCS_TOTE_UNLOAD; + taskStsType = TaskStsType.WCS_TOTE_UNLOAD; // } else { // String errMsg = "浠诲姟缂栧彿锛�" + task.getTaskNo() + "鐘舵�佷负涓嶅尮閰嶏紝" + "涓嶈兘鎵ц锛�" + TaskStsType.WCS_TOTE_UNLOAD.desc + "浠诲姟"; // log.error(errMsg); @@ -199,7 +174,7 @@ // } } else if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_STATUS.event)) { //TODO 闇�纭涓婃姤浠诲姟涓紝浠诲姟瀹屾垚鏄摢涓簨浠讹紝鐩墠鏆傚畾task浜嬩欢 // if (task.getTaskSts() == TaskStsType.WCS_TOTE_UNLOAD.id) { - taskStsType = TaskStsType.WCS_PUTAWAY_SUCESS; + taskStsType = TaskStsType.WCS_PUTAWAY_SUCESS; // } else { // String errMsg = "浠诲姟缂栧彿锛�" + task.getTaskNo() + "鐘舵�佷负涓嶅尮閰嶏紝" + "涓嶈兘鎵ц锛�" + TaskStsType.WCS_PUTAWAY_SUCESS.desc + "浠诲姟"; // log.error(errMsg); @@ -223,7 +198,7 @@ } else { //鍑哄簱浠诲姟 if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_TOTE_LOAD.event)) { //涓婃姤鍙栫鐘舵�� // if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT.id ) { - taskStsType = TaskStsType.WCS_EXECUTE_OUT_TOTE_LOAD; + taskStsType = TaskStsType.WCS_EXECUTE_OUT_TOTE_LOAD; // } else { // String errMsg = "浠诲姟缂栧彿锛�" + task.getTaskNo() + "鐘舵�佷负涓嶅尮閰嶏紝" + "涓嶈兘鎵ц锛�" + TaskStsType.WCS_EXECUTE_OUT_TOTE_LOAD.desc + "浠诲姟"; // log.error(errMsg); @@ -231,7 +206,7 @@ // } } else if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_TOTE_UNLOAD.event)) { //涓婃姤鏀剧鐘舵�� // if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_TOTE_LOAD.id) { - taskStsType = TaskStsType.WCS_EXECUTE_OUT_TOTE_UNLOAD; + taskStsType = TaskStsType.WCS_EXECUTE_OUT_TOTE_UNLOAD; // } else { // String errMsg = "浠诲姟缂栧彿锛�" + task.getTaskNo() + "鐘舵�佷负涓嶅尮閰嶏紝" + "涓嶈兘鎵ц锛�" + TaskStsType.WCS_EXECUTE_OUT_TOTE_UNLOAD.desc + "浠诲姟"; // log.error(errMsg); @@ -239,8 +214,8 @@ // } } else if (callbackParam.getEventType().equals(EssTaskStatus.TASK_EVENT_STATUS.event)) { //涓婃姤瀹屾垚鐘舵�� // if (task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_TOTE_UNLOAD.id || task.getTaskSts() == TaskStsType.WCS_EXECUTE_OUT_TASK_DONE.id) { - //鍑哄簱浠诲姟瀹屾垚锛屼慨鏀圭姸鎬佷负瀹瑰櫒鍒拌揪锛屽畾鏃朵换鍔$敓鎴愭挱绉嶆尝娆� - taskStsType = TaskStsType.WCS_EXECUTE_OUT_TASK_DONE; + //鍑哄簱浠诲姟瀹屾垚锛屼慨鏀圭姸鎬佷负瀹瑰櫒鍒拌揪锛屽畾鏃朵换鍔$敓鎴愭挱绉嶆尝娆� + taskStsType = TaskStsType.WCS_EXECUTE_OUT_TASK_DONE; // } else { // String errMsg = "浠诲姟缂栧彿锛�" + task.getTaskNo() + "鐘舵�佷负涓嶅尮閰嶏紝" + "涓嶈兘鎵ц锛�" + TaskStsType.WCS_EXECUTE_OUT_TASK_DONE.desc + "浠诲姟"; // log.error(errMsg); @@ -276,58 +251,53 @@ * @return */ @Override - public synchronized R containerConveryor(String code) { - List<Task> tasks = taskService.list(new LambdaQueryWrapper<Task>().eq(Task::getBarcode, code)); - if (tasks.isEmpty()) { - return R.error("瀹瑰櫒鐮佷换鍔′笉瀛樺湪锛侊紒"); - } else if (tasks.size() > 1) { - return R.error("瀹瑰櫒鐮佷换鍔¢敊璇紒锛�"); + @Transactional(rollbackFor = Exception.class) + public synchronized R containerConveryor(String code) throws Exception { + Task task = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getBarcode, code)); + if (Objects.isNull(task)) { + throw new CoolException("瀹瑰櫒鐮佷换鍔′笉瀛樺湪锛侊紒"); } - tasks.forEach(task -> { - try { - ConveyorStarParam conveyorStarParam = new ConveyorStarParam(); - conveyorStarParam.setSlotCode(task.getOriginLoc()) - .setContainerCode(task.getBarcode()); - if (task.getTaskType() == 101) { //浠诲姟绫诲瀷涓�101鍏ㄧ洏鍑哄簱锛岀洿鎺ュ彇涓嬪鍣紝浼�200 - conveyorStarParam.setDirection("200"); - } else if (task.getTaskType() == 103 || task.getTaskType() == 107) { //濡傛灉涓轰换鍔$被鍨嬩负103锛岄渶璧板洖搴撴搷浣滐紝浼�100 - conveyorStarParam.setDirection("100"); - } - //璋冪敤涓夋柟鎺ュ彛锛屽皢浠诲姟鎺ㄩ�佽嚦ESS骞冲彴 - MultiValueMap<String, Object> params = new LinkedMultiValueMap<>(); - // 璁剧疆璇锋眰鍙傛暟 - params.add("params", JSONObject.toJSONString(conveyorStarParam)); - log.info("璇锋眰鍦板潃锛歿}锛岃姹傚弬鏁帮細{}", HttpEssUtils.CONVEYOR_START, JSONObject.toJSONString(conveyorStarParam)); - HttpHeaders headers = new HttpHeaders(); - headers.add("Content-Type", "application/json"); - HttpEntity httpEntity = new HttpEntity<>(params, headers); - // 璇锋眰 - ResponseEntity<String> exchange = restTemplate.exchange(HttpEssUtils.CONVEYOR_START, HttpMethod.POST, httpEntity, String.class); - log.info("涓嬪彂娴佸姩閫氱煡 杩斿洖缁撴灉锛歿}", exchange); - if (exchange.getBody() == null) { - throw new CoolException("涓嬪彂娴佸姩閫氱煡澶辫触锛侊紒"); - } else { - CommonReponse commonReponse = JSON.toJavaObject(JSON.parseObject(exchange.getBody()), CommonReponse.class); - if (commonReponse.getCode() == 0) { - //娴佸姩閫氱煡涓嬪彂瀹屾垚鍚庯紝淇敼浠诲姟鐘舵�佷负杈撻�佺嚎娴佸姩涓�傘�� - if (task.getTaskType() == 103 || task.getTaskType() == 107) { - //鏇存柊搴撳瓨淇℃伅,淇敼浠诲姟鐘舵�佷负4 锛圧CS瀹瑰櫒娴佸姩浠诲姟宸蹭笅鍙戯級 - workService.pickTask(task.getId()); - // taskService.update(new LambdaUpdateWrapper<Task>().eq(Task::getId, task.getId()).set(Task::getTaskSts, TaskStsType.WCS_CONVEYOR_START)) - } else { - taskService.update(new LambdaUpdateWrapper<Task>() - .eq(Task::getId, task.getId()) - .set(Task::getTaskSts, TaskStsType.COMPLETE_OUT.id)); - } - log.info(task.getTaskNo() + "涓嬪彂娴佸姩閫氱煡" + commonReponse.getMsg()); - } else { - throw new CoolException("涓嬪彂娴佸姩閫氱煡澶辫触锛侊紒"); - } - } - } catch (Exception ex) { - log.error(ex.getMessage()); + try { + ConveyorStarParam conveyorStarParam = new ConveyorStarParam(); + conveyorStarParam.setSlotCode(task.getOriginSite()) + .setContainerCode(task.getBarcode()); + if (task.getTaskType() == 101) { //浠诲姟绫诲瀷涓�101鍏ㄧ洏鍑哄簱锛岀洿鎺ュ彇涓嬪鍣紝浼�200 + conveyorStarParam.setDirection("200"); + } else if (task.getTaskType() == 103 || task.getTaskType() == 107) { //濡傛灉涓轰换鍔$被鍨嬩负103锛岄渶璧板洖搴撴搷浣滐紝浼�100 + conveyorStarParam.setDirection("100"); } - }); + //璋冪敤涓夋柟鎺ュ彛锛屽皢浠诲姟鎺ㄩ�佽嚦ESS骞冲彴 + MultiValueMap<String, Object> params = new LinkedMultiValueMap<>(); + // 璁剧疆璇锋眰鍙傛暟 + HttpHeaders headers = new HttpHeaders(); + headers.add("Content-Type", "application/json"); + headers.add("api-version", "v2.0"); + HttpEntity httpEntity = new HttpEntity<>(conveyorStarParam, headers); + log.info("璇锋眰鍦板潃锛歿}锛岃姹傚弬鏁帮細{}", HttpEssUtils.CONVEYOR_START, JSONObject.toJSONString(conveyorStarParam)); + ResponseEntity<String> exchange = restTemplate.exchange("http://192.168.2.200:9046/conveyor/moveContainer", HttpMethod.POST, httpEntity, String.class); + log.info("涓嬪彂娴佸姩閫氱煡 杩斿洖缁撴灉锛歿}", exchange); + if (exchange.getBody() == null) { + throw new CoolException("涓嬪彂娴佸姩閫氱煡澶辫触锛侊紒"); + } else { + CommonReponse commonReponse = JSON.toJavaObject(JSON.parseObject(exchange.getBody()), CommonReponse.class); + if (commonReponse.getCode() == 0) { + //娴佸姩閫氱煡涓嬪彂瀹屾垚鍚庯紝淇敼浠诲姟鐘舵�佷负杈撻�佺嚎娴佸姩涓�傘�� + if (task.getTaskType() == 103 || task.getTaskType() == 107) { + //鏇存柊搴撳瓨淇℃伅,淇敼浠诲姟鐘舵�佷负4 锛圧CS瀹瑰櫒娴佸姩浠诲姟宸蹭笅鍙戯級 + workService.pickTask(task.getId()); + } else { + taskService.update(new LambdaUpdateWrapper<Task>() + .eq(Task::getId, task.getId()) + .set(Task::getTaskSts, TaskStsType.COMPLETE_OUT.id)); + } + log.info(task.getTaskNo() + "涓嬪彂娴佸姩閫氱煡" + commonReponse.getMsg()); + } else { + throw new CoolException("涓嬪彂娴佸姩閫氱煡澶辫触锛侊紒"); + } + } + } catch (Exception ex) { + log.error("UNK", ex); + } return R.ok(); } @@ -346,46 +316,59 @@ * 鎷嶇伅鎷f枡閫昏緫锛岃缁嗚鏄庤鎺ュ彛璋冪敤璇存槑 * * @param request + * @return */ @Override @Transactional(rollbackFor = Exception.class) - public void slapLightLogic(Map<String, Object> request) { + public R slapLightLogic(Map<String, Object> request) { String taskNo = request.get("taskNo").toString(); String orderNo = request.get("orderNo").toString(); - + String siteNo = Objects.isNull(request.get("siteNo")) ? null : request.get("siteNo").toString(); List<CacheSite> performs = cacheSiteService.list(new LambdaQueryWrapper<CacheSite>().eq(CacheSite::getOrderNo, orderNo)); if (Objects.isNull(performs.stream().findFirst().get().getPlatformId())) { throw new CoolException("璇锋墦鍗版槑缁嗭紝骞剁粦瀹氱洰鏍囬泦璐у尯"); } - //* 1. 鍒ゆ柇褰撳墠瀹瑰櫒鏄惁杩樻湁鐗╂枡鏈嫞锛屾湭鎷e畬闂伅锛屾嫞瀹岄�氱煡瀹瑰櫒娴佸姩锛屽苟鐏伅 SlapLightControlParam slapParam = new SlapLightControlParam(); MultiValueMap<String, Object> params = new LinkedMultiValueMap<>(); - //榛樿娴佸姩 - boolean converyor = false; + Order one = orderService.getOne(new LambdaQueryWrapper<Order>().eq(Order::getOrderNo, orderNo)); + if (Objects.isNull(one)) { + throw new CoolException("褰撳墠璁㈠崟鏄庣粏涓嶅瓨鍦紒锛�"); + } + + if (Cools.isEmpty(slapParam)) { + return null; + } + //鍒ゆ柇褰撳墠浠诲姟鏄惁杩樻湁鐗╂枡鏈嫞 if (!checked(orderNo, taskNo)) { + log.info("鏈畬鎴愰棯鐏姹傚湴鍧�锛歿}锛岃姹傚弬鏁帮細{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam)); //璋冪敤涓夋柟鎺ュ彛,闂伅涓嶅仛鎿嶄綔 // 璁剧疆璇锋眰鍙傛暟 - params.add("params", JSONObject.toJSONString(slapParam)); - log.info("鏈畬鎴愰棯鐏姹傚湴鍧�锛歿}锛岃姹傚弬鏁帮細{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam)); + mobileService.sowLightMange(siteNo, one, "LIGHT"); +// throw new CoolException("褰撳墠浠诲姟鏈畬鎴愶紝涓嶈兘鎵ц姝ゆ搷浣滐紒锛�"); +// params.add("params", JSONObject.toJSONString(slapParam)); } else { //璋冪敤涓夋柟鎺ュ彛,鐏伅閫氱煡瀹瑰櫒娴佸姩锛� 浼犵伃鐏弬鏁� //todo 鍒ゆ柇褰撳墠璁㈠崟鏄惁瀹屾垚锛屽畬鎴愮伃鐏紝鏈畬鎴愪繚鎸佹嫞璐х姸鎬佷寒鐏� - Order one = orderService.getOne(new LambdaQueryWrapper<Order>().eq(Order::getOrderNo, orderNo)); - if (Objects.isNull(one)) { - throw new CoolException("褰撳墠璁㈠崟鏄庣粏涓嶅瓨鍦紒锛�"); - } // //鑾峰彇鎾宸插畬鎴愮殑璁㈠崟鏄庣粏 // List<OrderDetl> detlList = orderDetls.stream().filter(detl -> { // return detl.getPickStatus() == OrderPickStatus.ORDER_PICK_STATUS_DONE.val; // }).collect(Collectors.toList()); - //鍒ゆ柇鏁伴噺鏄惁涓庤鍗曟槑缁嗙殑闇�姹傞噺鐩稿悓锛岀浉鍚屽垯璁㈠崟瀹屾垚 - if (one.getPickStatus() == OrderPickStatus.ORDER_PICK_STATUS_DONE.val) { + + List<WaveSeed> seeds = waveSeedService.list(new LambdaQueryWrapper<WaveSeed>().eq(WaveSeed::getOrderNo, orderNo)); + if (Objects.isNull(seeds)) { + throw new CoolException("鏁版嵁閿欒锛氭挱绉嶆暟鎹笉瀛樺湪锛侊紒"); + } + Double tolAnfme = seeds.stream().mapToDouble(WaveSeed::getAnfme).sum(); + Double toDouble = seeds.stream().mapToDouble(WaveSeed::getWorkQty).sum(); + if (toDouble.compareTo(tolAnfme) >= 0) { //鎾瀹屾垚锛岄噴鏀剧粦瀹氱珯鐐� - List<CacheSite> cacheSites = cacheSiteService.list(new LambdaQueryWrapper<CacheSite>().eq(CacheSite::getOrderNo, orderNo)); + List<CacheSite> cacheSites = cacheSiteService.list(new LambdaQueryWrapper<CacheSite>() + .eq(!Objects.isNull(siteNo), CacheSite::getSiteNo, siteNo) + .eq(CacheSite::getOrderNo, orderNo)); for (CacheSite cacheSite : cacheSites) { if (!cacheSite.getSiteStatus().equals(CacheSiteStatusType.O.id)) { cacheSite.setSiteStatus(CacheSiteStatusType.O.id); @@ -400,37 +383,30 @@ } } } + //璁㈠崟瀹屾垚锛岀伃鐏� + mobileService.sowLightMange(siteNo, one, "DARK"); + log.info("瀹屾垚鐏伅璇锋眰鍦板潃锛歿}锛岃姹傚弬鏁帮細{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam)); + } else { + //璁㈠崟鏈畬鎴愶紝缁х画浜伅 + mobileService.sowLightMange(siteNo, one, "LIGHT"); + log.info("缁х画浜伅璇锋眰鍦板潃锛歿}锛岃姹傚弬鏁帮細{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam)); + } - converyor = true; params.add("params", JSONObject.toJSONString(slapParam)); log.info("瀹屾垚鐏伅璇锋眰鍦板潃锛歿}锛岃姹傚弬鏁帮細{}", SystemProperties.SLAP_LIGHT, JSONObject.toJSONString(slapParam)); } - if (converyor) { - Task task = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getTaskNo, request.get("taskNo"))); - if (Objects.isNull(task)) { - throw new CoolException("浠诲姟涓嶅瓨鍦紒锛�"); - } - containerConveryor(task.getBarcode()); + Task task = taskService.getOne(new LambdaQueryWrapper<Task>().eq(Task::getTaskNo, request.get("taskNo"))); + if (Objects.isNull(task)) { + throw new CoolException("浠诲姟涓嶅瓨鍦紒锛�"); } - -// HttpHeaders headers = new HttpHeaders(); -// headers.add("Content-Type", "application/json"); -// HttpEntity httpEntity = new HttpEntity<>(params, headers); -// // 璇锋眰 -// ResponseEntity<CommonReponse> exchange = restTemplate.exchange(SystemProperties.CONVEYOR_START, HttpMethod.POST, httpEntity, CommonReponse.class); -// log.info("涓嬪彂娴佸姩閫氱煡 杩斿洖缁撴灉锛歿}", exchange); -// if (exchange.getBody() == null) { -// throw new CoolException("涓嬪彂娴佸姩閫氱煡澶辫触锛侊紒"); -// } else { -// CommonReponse response = exchange.getBody(); -// if (response.getCode() == 0) { -// if (!converyor) { -// //* 2. 瀹瑰櫒娴佸姩鍒ゆ柇锛屽鏋滄枡绠辨病鏈夌墿鏂� code浼�200锛� 鏈夌墿鏂欎紶100 鎵ц鍥炲簱浠诲姟,淇敼浠诲姟鐘舵�佷负 璋冪敤containerConveryor锛坱askNo锛夋柟娉� -// containerConveryor(request.get("taskNo").toString()); -// } -// } -// } + try { + containerConveryor(task.getBarcode()); + } catch (Exception e) { + log.error("鎵ц寮傚父:UNK", e); + throw new CoolException(e.getMessage()); + } + return R.ok(); } /** @@ -465,7 +441,7 @@ //鍒ゆ柇浠诲姟闇�姹傛�婚噺鏄惁绛夋挱绉嶆�绘暟閲� if (taskNum == seedNum) { return true; - } else { + } else { return false; } } -- Gitblit v1.9.1