From afc1bebb2eafc87ba81fb9fe39ef0386d1fb3d17 Mon Sep 17 00:00:00 2001
From: Junjie <DELL@qq.com>
Date: 星期四, 22 一月 2026 08:43:31 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/controller/OpenController.java |   61 +++++++++++++++++++++++-------
 1 files changed, 47 insertions(+), 14 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java
index 83f5d5c..98b40ca 100644
--- a/src/main/java/com/zy/asrs/controller/OpenController.java
+++ b/src/main/java/com/zy/asrs/controller/OpenController.java
@@ -3,10 +3,14 @@
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.core.common.Cools;
 import com.core.common.R;
-import com.zy.asrs.entity.BasStation;
 import com.zy.asrs.entity.BasStationTv;
 import com.zy.asrs.entity.TvDevice;
 
+import com.zy.asrs.entity.dto.TvDataDto;
+import com.zy.asrs.entity.dto.WcsStationDto;
+import com.zy.asrs.service.BasStationTvService;
+import com.zy.asrs.service.TvDeviceService;
+import com.zy.asrs.utils.StationUtils;
 import com.zy.asrs.utils.Utils;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Value;
@@ -16,7 +20,6 @@
 import javax.servlet.http.HttpServletRequest;
 
 import java.util.*;
-import java.util.stream.Collectors;
 
 @Slf4j
 @RestController
@@ -26,11 +29,11 @@
     private static final String[] WEEK = {"鏄熸湡鏃�","鏄熸湡涓�","鏄熸湡浜�","鏄熸湡涓�","鏄熸湡鍥�","鏄熸湡浜�","鏄熸湡鍏�"};
 
     @Autowired
-    private com.zy.asrs.service.TvDeviceService tvDeviceService;
+    private TvDeviceService tvDeviceService;
     @Autowired
-    private com.zy.asrs.service.BasStationTvService basStationTvService;
+    private BasStationTvService basStationTvService;
     @Autowired
-    private com.zy.asrs.service.BasStationService basStationService;
+    private StationUtils stationUtils;
 
     @Value("${app.version:1.0.0}")
     private String appVersion;
@@ -53,14 +56,12 @@
     @GetMapping("/getLedInfos")
     public R getLedInfos(HttpServletRequest request) {
         String remoteAddr = request.getRemoteAddr();
-        // 1. 鏍规嵁IP鏌ヨ鐢佃鏈�
         TvDevice tvDevice = tvDeviceService.selectOne(
                 new EntityWrapper<TvDevice>().eq("ip", remoteAddr));
         if (tvDevice == null) {
             return R.error("鏈壘鍒癐P瀵瑰簲鐨勭數瑙嗘満璁惧: " + remoteAddr);
         }
 
-        // 2. 鏌ヨ缁戝畾鐨勭珯鍙癐D
         List<BasStationTv> relations = basStationTvService
                 .selectList(new EntityWrapper<BasStationTv>().eq("tv_id", tvDevice.getId()));
         if (relations == null || relations.isEmpty()) {
@@ -69,14 +70,46 @@
             return r;
         }
 
-        // 3. 鑾峰彇绔欏彴璇︽儏
-        List<Integer> stationIds = relations.stream().map(BasStationTv::getStationId)
-                .collect(Collectors.toList());
-        List<BasStation> stations = basStationService.selectBatchIds(stationIds);
 
-        R r = R.ok();
-        r.put("data", stations);
-        return r;
+        List<TvDataDto> list = new ArrayList<>();
+        for (BasStationTv relation : relations) {
+            WcsStationDto wcsStationDto = stationUtils.stationMap.get(relation.getStationId());
+
+            if (wcsStationDto == null) {
+                continue;
+            }
+
+            if (wcsStationDto.getLoading() != 1) {
+                continue;
+            }
+
+            String errorMsg = "";
+            if (!Cools.isEmpty(wcsStationDto.getErrorMsg())) {
+                errorMsg +=  wcsStationDto.getErrorMsg();
+            }
+
+            if (!Cools.isEmpty(wcsStationDto.getSystemWarning())) {
+                errorMsg +=  wcsStationDto.getSystemWarning();
+            }
+
+            TvDataDto tvDataDto = new TvDataDto();
+            tvDataDto.setStationId(wcsStationDto.getStationId());
+            tvDataDto.setTaskNo(wcsStationDto.getTaskNo());
+            tvDataDto.setBarcode(wcsStationDto.getBarcode());
+            tvDataDto.setErrorMsg(errorMsg);
+            tvDataDto.setIoType(wcsStationDto.getIoType());
+            tvDataDto.setWrkDetls(wcsStationDto.getWrkDetls());
+
+            if (Cools.isEmpty(errorMsg)) {
+                tvDataDto.setErrorCode(0);
+            }else {
+                tvDataDto.setErrorCode(1);
+            }
+
+            list.add(tvDataDto);
+        }
+
+        return R.ok().add(list);
     }
 
     /**

--
Gitblit v1.9.1