From 519f42d527a1dd4917455609855f732b1eb0f7a0 Mon Sep 17 00:00:00 2001
From: zwl <1051256694@qq.com>
Date: 星期五, 20 三月 2026 11:08:11 +0800
Subject: [PATCH] 新增接口: 给mes提供机台及对应机台工位的冻结情况

---
 src/main/java/com/zy/api/service/impl/HmesApiServiceImpl.java |  147 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 146 insertions(+), 1 deletions(-)

diff --git a/src/main/java/com/zy/api/service/impl/HmesApiServiceImpl.java b/src/main/java/com/zy/api/service/impl/HmesApiServiceImpl.java
index 968cd42..045807b 100644
--- a/src/main/java/com/zy/api/service/impl/HmesApiServiceImpl.java
+++ b/src/main/java/com/zy/api/service/impl/HmesApiServiceImpl.java
@@ -6,6 +6,9 @@
 import com.core.common.R;
 import com.core.common.SnowflakeIdWorker;
 import com.core.exception.CoolException;
+import com.zy.api.controller.params.HmesBackLocParams;
+import com.zy.api.entity.dto.HmesDeviceFreezeStatusDto;
+import com.zy.api.entity.dto.HmesStationFreezeStatusDto;
 import com.zy.api.controller.params.ReceviceTaskParams;
 import com.zy.api.service.HmesApiService;
 import com.zy.api.service.WcsApiService;
@@ -28,6 +31,8 @@
 @Service
 @Slf4j
 public class HmesApiServiceImpl implements HmesApiService {
+
+    private static final Long HMES_USER_ID = 9995L;
 
     @Autowired
     private BasDeviceService basDeviceService;
@@ -61,6 +66,12 @@
     private OrderDetlPakoutServiceImpl orderDetlPakoutService;
     @Autowired
     private LocDetlServiceImpl locDetlService;
+
+    @Autowired
+    private WrkMastService wrkMastService;
+
+    @Autowired
+    private WorkService workService;
 
 
     /**
@@ -100,8 +111,9 @@
                 list.add(dto);
             }
         }
+
         //涓嬪彂鐨勮鍗曟槑缁嗭紝鏌ョ湅搴撳瓨鏄惁鏈夎冻澶熺殑搴撳瓨锛屾帓闄ゆ満鍙扮殑搴撲綅
-        for (DetlDto detail : list) {
+         for (DetlDto detail : list) {
             List<LocDetl> matnr = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("matnr", detail.getMatnr()));
             Double count=0.0;
             for (LocDetl detl : matnr) {
@@ -115,6 +127,19 @@
             }
             if (count<detail.getAnfme()) {
                 return R.error("鐗╂枡="+detail.getMatnr()+"搴撳瓨涓嶈冻鏃犳硶鐢熸垚璁㈠崟");
+            }
+            //鏈哄彴鏈夊喕缁撴椂绂佹鍛煎彨鐗╂枡
+            BasDevice basDevice = basDeviceService.selectOne(new EntityWrapper<BasDevice>()
+                    .eq("status", 1)
+                    .eq("dev_no", detail.getStandby1()));
+            if (Objects.isNull(basDevice)) {
+                return R.error(detail.getStandby1()+"鏈哄彴淇℃伅涓嶅瓨鍦ㄦ垨宸茬鐢紒锛�");
+            }
+            List<LocAroundBind> binds = locAroundBindService.selectList(new EntityWrapper<LocAroundBind>()
+                    .eq("dev_no", basDevice.getType())
+                    .eq("freeze", 1));
+            if (!Cools.isEmpty(binds)) {
+                return  R.error(detail.getStandby1()+"鏈哄彴琚喕缁撴棤娉曞懠鍙墿鏂�");
             }
         }
         // 鍗曟嵁涓绘。
@@ -224,4 +249,124 @@
         });
         return R.ok(s+"鎴愬姛 锛侊紒");
     }
+
+    @Override
+    public R getDeviceFreezeStatus() {
+        List<BasDevice> devices = basDeviceService.selectList(new EntityWrapper<BasDevice>()
+                .eq("status", 1)
+                .orderBy("dev_no", true));
+        if (Cools.isEmpty(devices)) {
+            return R.ok(Collections.emptyList());
+        }
+
+        List<LocAroundBind> binds = locAroundBindService.selectList(new EntityWrapper<LocAroundBind>()
+                .orderBy("dev_no", true)
+                .orderBy("order_no", true)
+                .orderBy("id", true));
+        Map<String, List<LocAroundBind>> bindMap = new HashMap<>();
+        if (!Cools.isEmpty(binds)) {
+            bindMap = binds.stream()
+                    .filter(bind -> !Cools.isEmpty(bind.getDevNo()))
+                    .collect(Collectors.groupingBy(LocAroundBind::getDevNo, LinkedHashMap::new, Collectors.toList()));
+        }
+
+        List<HmesDeviceFreezeStatusDto> result = new ArrayList<>();
+        for (BasDevice device : devices) {
+            List<LocAroundBind> deviceBinds = bindMap.getOrDefault(device.getType(), Collections.emptyList());
+            List<HmesStationFreezeStatusDto> stationList = deviceBinds.stream()
+                    .sorted(Comparator.comparing(LocAroundBind::getOrderNo, Comparator.nullsLast(Integer::compareTo))
+                            .thenComparing(LocAroundBind::getId, Comparator.nullsLast(Long::compareTo)))
+                    .map(this::buildStationFreezeStatus)
+                    .collect(Collectors.toList());
+            boolean frozen = stationList.stream().anyMatch(station -> "Y".equals(station.getFreeze()));
+            result.add(new HmesDeviceFreezeStatusDto()
+                    .setDevNo(device.getDevNo())
+                    .setDevType(device.getType())
+                    .setFreeze(toFreezeFlag(frozen ? 1 : 0))
+                    .setStationList(stationList));
+        }
+        return R.ok(result);
+    }
+
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public R backLoc(HmesBackLocParams params) {
+        Integer backType = parseBackType(params.getBackType());
+        if (backType == null) {
+            return R.error("鍥炲簱绫诲瀷[backType]浠呮敮鎸� EMPTY/4/绌烘《/绌烘澘 鎴� SURPLUS/5/浣欐枡");
+        }
+
+        WrkMast mast = findBackLocWrkMast(params);
+        if (Objects.isNull(mast)) {
+            return R.error("鏈煡璇㈠埌鍙洖搴撶殑浠诲姟妗�");
+        }
+        if (!Objects.equals(mast.getWrkSts(), 15L)) {
+            return R.error("褰撳墠浠诲姟鐘舵�佷笉鑳芥墽琛屽洖搴擄紒");
+        }
+
+        workService.updateWrkIsSuplus(String.valueOf(mast.getWrkNo()), HMES_USER_ID, backType);
+        return workService.backLocOperation(String.valueOf(mast.getWrkNo()), HMES_USER_ID);
+    }
+
+    private HmesStationFreezeStatusDto buildStationFreezeStatus(LocAroundBind bind) {
+        return new HmesStationFreezeStatusDto()
+                .setLocNo(bind.getBlocNo())
+                .setOrderNo(bind.getOrderNo())
+                .setLocType(bind.getLocType())
+                .setFreeze(toFreezeFlag(bind.getFreeze()));
+    }
+
+    private String toFreezeFlag(Integer freeze) {
+        return Objects.equals(freeze, 1) ? "Y" : "N";
+    }
+
+    private Integer parseBackType(String backType) {
+        if (Cools.isEmpty(backType)) {
+            return null;
+        }
+        String normalized = backType.trim().toUpperCase(Locale.ROOT);
+        if ("4".equals(normalized) || "EMPTY".equals(normalized) || "EMPTY_BUCKET".equals(normalized)
+                || "EMPTY_PLATE".equals(normalized) || "绌烘《".equals(backType.trim())
+                || "绌烘澘".equals(backType.trim())) {
+            return 4;
+        }
+        if ("5".equals(normalized) || "SURPLUS".equals(normalized) || "SUPLUS".equals(normalized)
+                || "LEFTOVER".equals(normalized) || "浣欐枡".equals(backType.trim())) {
+            return 5;
+        }
+        return null;
+    }
+
+    private WrkMast findBackLocWrkMast(HmesBackLocParams params) {
+        if (!Cools.isEmpty(params.getLocNo())) {
+            List<WrkMast> wrkMasts = wrkMastService.selectList(new EntityWrapper<WrkMast>()
+                    .eq("loc_no", params.getLocNo())
+                    .orderBy("appe_time", false)
+                    .orderBy("wrk_no", false));
+            WrkMast matched = pickLatestCompletedWrkMast(wrkMasts);
+            if (matched != null) {
+                return matched;
+            }
+        }
+        if (!Cools.isEmpty(params.getWorkNo())) {
+            return wrkMastService.selectById(params.getWorkNo());
+        }
+        List<WrkMast> wrkMasts = wrkMastService.selectList(new EntityWrapper<WrkMast>()
+                .eq("barcode", params.getBarcode())
+                .orderBy("appe_time", false)
+                .orderBy("wrk_no", false));
+        return pickLatestCompletedWrkMast(wrkMasts);
+    }
+
+    private WrkMast pickLatestCompletedWrkMast(List<WrkMast> wrkMasts) {
+        if (Cools.isEmpty(wrkMasts)) {
+            return null;
+        }
+        for (WrkMast wrkMast : wrkMasts) {
+            if (Objects.equals(wrkMast.getWrkSts(), 15L)) {
+                return wrkMast;
+            }
+        }
+        return wrkMasts.get(0);
+    }
 }

--
Gitblit v1.9.1