From 250bf364710321e064cbc06e310965a79a619983 Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期二, 07 四月 2026 13:17:09 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master' into master-jxthTV

---
 src/main/java/com/zy/asrs/controller/OpenController.java |   58 +++++++++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 45 insertions(+), 13 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java
index 41b3835..ff16ea1 100644
--- a/src/main/java/com/zy/asrs/controller/OpenController.java
+++ b/src/main/java/com/zy/asrs/controller/OpenController.java
@@ -2,7 +2,7 @@
 
 import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONObject;
-import com.baomidou.mybatisplus.mapper.EntityWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.core.annotations.ManagerAuth;
 import com.core.common.Cools;
 import com.core.common.R;
@@ -11,10 +11,12 @@
 
 import com.zy.asrs.entity.dto.TvDataDto;
 import com.zy.asrs.entity.dto.TvLocDataDto;
+import com.zy.asrs.entity.dto.WcsCrnDto;
 import com.zy.asrs.entity.dto.WcsStationDto;
 import com.zy.asrs.enums.RedisKeyType;
 import com.zy.asrs.service.BasStationTvService;
 import com.zy.asrs.service.TvDeviceService;
+import com.zy.asrs.utils.CrnUtils;
 import com.zy.asrs.utils.StationUtils;
 import com.zy.asrs.utils.Utils;
 import com.zy.common.utils.RedisUtil;
@@ -26,8 +28,8 @@
 import org.springframework.web.multipart.MultipartFile;
 import org.springframework.beans.factory.annotation.Autowired;
 
-import javax.servlet.http.HttpServletRequest;
-import javax.servlet.http.HttpServletResponse;
+import jakarta.servlet.http.HttpServletRequest;
+import jakarta.servlet.http.HttpServletResponse;
 
 import java.io.File;
 import java.io.FileInputStream;
@@ -51,6 +53,8 @@
     private BasStationTvService basStationTvService;
     @Autowired
     private StationUtils stationUtils;
+    @Autowired
+    private CrnUtils crnUtils;
     @Autowired
     private RedisUtil redisUtil;
     @Autowired
@@ -156,15 +160,15 @@
     public R getLedInfos(HttpServletRequest request) {
         HashMap<String, Object> map = new HashMap<>();
         String remoteAddr = request.getRemoteAddr();
-        TvDevice tvDevice = tvDeviceService.selectOne(
-                new EntityWrapper<TvDevice>().eq("ip", remoteAddr));
+        TvDevice tvDevice = tvDeviceService.getOne(
+                new QueryWrapper<TvDevice>().eq("ip", remoteAddr));
         if (tvDevice == null) {
             return R.error("鏈壘鍒癐P瀵瑰簲鐨勭數瑙嗘満璁惧: " + remoteAddr);
         }
         map.put("deviceName", tvDevice.getName());
 
         List<BasStationTv> relations = basStationTvService
-                .selectList(new EntityWrapper<BasStationTv>().eq("tv_id", tvDevice.getId()));
+                .list(new QueryWrapper<BasStationTv>().eq("tv_id", tvDevice.getId()));
         if (relations == null || relations.isEmpty()) {
             map.put("data", new ArrayList<>());
             return R.ok().add(map);
@@ -189,6 +193,14 @@
                 continue;
             }
 
+            if(Cools.isEmpty(wcsStationDto.getTaskNo())||wcsStationDto.getTaskNo().equals("0")) {
+                continue;
+            }
+
+            if (Cools.isEmpty(wcsStationDto.getWrkDetls())) {
+                continue;
+            }
+
             String errorMsg = "";
             if (!Cools.isEmpty(wcsStationDto.getErrorMsg())) {
                 errorMsg +=  wcsStationDto.getErrorMsg();
@@ -210,6 +222,7 @@
             tvDataDto.setBarcode(wcsStationDto.getBarcode());
             tvDataDto.setErrorMsg(errorMsg);
             tvDataDto.setIoType(wcsStationDto.getIoType());
+            tvDataDto.setOrderNo(wcsStationDto.getOrderNo());
             tvDataDto.setWrkDetls(wcsStationDto.getWrkDetls());
 
             if (Cools.isEmpty(errorMsg)) {
@@ -223,6 +236,7 @@
 
 
         map.put("data", list);
+        System.out.println(map);
         return R.ok().add(map);
     }
 
@@ -236,11 +250,11 @@
         }
 
         String remoteAddr = request.getRemoteAddr();
-        TvDevice tvDevice = tvDeviceService.selectOne(
-                new EntityWrapper<TvDevice>().eq("ip", remoteAddr));
+        TvDevice tvDevice = tvDeviceService.getOne(
+                new QueryWrapper<TvDevice>().eq("ip", remoteAddr));
         if (tvDevice != null) {
             List<BasStationTv> relations = basStationTvService
-                    .selectList(new EntityWrapper<BasStationTv>().eq("tv_id", tvDevice.getId()));
+                    .list(new QueryWrapper<BasStationTv>().eq("tv_id", tvDevice.getId()));
             if (relations != null && !relations.isEmpty()) {
                 for (BasStationTv relation : relations) {
                     WcsStationDto wcsStationDto = stationUtils.stationMap.get(relation.getStationId());
@@ -264,6 +278,25 @@
                         errors.add(deviceError);
                     }
                 }
+            }
+        }
+
+        List<WcsCrnDto> crnList = new ArrayList<>(crnUtils.crnMap.values());
+        crnList.sort(Comparator.comparing(WcsCrnDto::getCrnNo, Comparator.nullsLast(Integer::compareTo)));
+        for (WcsCrnDto wcsCrnDto : crnList) {
+            if (wcsCrnDto == null || wcsCrnDto.getCrnNo() == null) {
+                continue;
+            }
+            if (wcsCrnDto.getOnline() == null || wcsCrnDto.getOnline() != 1) {
+                errors.add("鍫嗗灈鏈�#" + wcsCrnDto.getCrnNo() + "绂荤嚎");
+                continue;
+            }
+            if (wcsCrnDto.getAlarm() != null && wcsCrnDto.getAlarm() != 0) {
+                errors.add("鍫嗗灈鏈�#" + wcsCrnDto.getCrnNo() + "鎶ヨ锛屾姤璀︾爜锛�" + wcsCrnDto.getAlarm());
+            }
+            if (wcsCrnDto.getMode() == null || wcsCrnDto.getMode() != 3) {
+                String modeDesc = Cools.isEmpty(wcsCrnDto.getModeDesc()) ? "鏈煡" : wcsCrnDto.getModeDesc();
+                errors.add("鍫嗗灈鏈�#" + wcsCrnDto.getCrnNo() + "闈炶嚜鍔ㄦā寮忥紝褰撳墠妯″紡锛�" + modeDesc);
             }
         }
 
@@ -297,11 +330,11 @@
 
     @GetMapping("/announcement")
     public R top5(){
-        EntityWrapper<Announcement> wrapper = new EntityWrapper<>();
+        QueryWrapper<Announcement> wrapper = new QueryWrapper<>();
         wrapper.eq("status", 1);
-        wrapper.orderBy("create_time", false);
+        wrapper.orderBy(true, false, "create_time");
         wrapper.last("limit 5");
-        return R.ok(announcementService.selectList(wrapper));
+        return R.ok(announcementService.list(wrapper));
     }
 
     /**
@@ -347,7 +380,6 @@
         if(o == null){
             return R.error();
         }
-
         return R.ok().add(JSON.parseObject(o.toString()));
     }
 

--
Gitblit v1.9.1