From 6841d191ba9631b1e73486ccfc8d78529ee86c32 Mon Sep 17 00:00:00 2001
From: chenlu <1320612696@qq.com>
Date: 星期一, 11 八月 2025 18:19:47 +0800
Subject: [PATCH] 更新

---
 north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java |  131 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 130 insertions(+), 1 deletions(-)

diff --git a/north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java b/north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java
index b6adbf0..1ed6e64 100644
--- a/north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java
+++ b/north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java
@@ -323,7 +323,29 @@
                         }
                     }
                 }
-
+                // 鍦ㄤ繚瀛樹箣鍓嶅鐞� glassPoint 鏁版嵁
+                for (Map<String, Object> detail : objectMap2) {
+                    if (detail.containsKey("glassPoint")) {
+                        Object glassPointObj = detail.get("glassPoint");
+                        if (glassPointObj != null) {
+                            try {
+                                // 濡傛灉 glassPointObj 宸茬粡鏄瓧绗︿覆锛屽垯涓嶉渶瑕佽浆鎹�
+                                if (!(glassPointObj instanceof String)) {
+                                    // 灏嗗璞¤浆鎹负 JSON 瀛楃涓�
+                                    String glassPointStr = mapper.writeValueAsString(glassPointObj);
+                                    detail.put("glassPoint", glassPointStr);
+                                }
+                            } catch (Exception e) {
+                                // 濡傛灉杞崲澶辫触锛岃褰曢敊璇苟绉婚櫎璇ュ瓧娈�
+                                System.err.println("杞崲 glassPoint 澶辫触: " + e.getMessage());
+                                detail.remove("glassPoint");
+                            }
+                        } else {
+                            // 濡傛灉 glassPointObj 涓� null锛岀Щ闄よ瀛楁
+                            detail.remove("glassPoint");
+                        }
+                    }
+                }
                 glassOptimizeMapper.addOptimizeDetail(objectMap2,projectId);
             }
             glassOptimizeMapper.updateProjectOptimizeStateMp(projectId,1);
@@ -354,6 +376,111 @@
         map.put("optimizeUse", glassOptimizeMapper.materialStoreOptimizeUse(processId));
         return map;
     }
+
+
+
+    public Object getOptimizeInfoSv(String processId) {
+        // 鑾峰彇甯冨眬淇℃伅
+        List<Map<String, Object>> layouts = glassOptimizeMapper.getOptimizeLayoutsInfo(processId);
+        // 鑾峰彇鐜荤拑鏄庣粏淇℃伅
+        List<Map<String, Object>> glassDetails = glassOptimizeMapper.getOptimizeDetailsInfo(processId);
+        // 鑾峰彇浣欐枡淇℃伅
+        List<Map<String, Object>> offsets = glassOptimizeMapper.getOptimizeOffsetsInfo(processId);
+        // 灏嗙幓鐠冩槑缁嗗拰浣欐枡鍚堝苟鍒颁竴涓垪琛ㄤ腑
+        List<Map<String, Object>> allDetails = new ArrayList<>();
+        if (glassDetails != null) {
+            allDetails.addAll(glassDetails);
+        }
+        if (offsets != null) {
+            allDetails.addAll(offsets);
+        }
+
+        // 瑙f瀽 glassPoint 瀛楃涓�
+        ObjectMapper mapper = new ObjectMapper();
+        for (Map<String, Object> detail : allDetails) {
+            if (detail.containsKey("glassPoint")) {
+                Object glassPointObj = detail.get("glassPoint");
+                if (glassPointObj instanceof String) {
+                    String glassPointStr = (String) glassPointObj;
+                    if (glassPointStr != null && !glassPointStr.isEmpty() && !glassPointStr.equals("null")) {
+                        try {
+                            // 瑙f瀽 JSON 瀛楃涓蹭负瀵硅薄
+                            Object parsedGlassPoint = mapper.readValue(glassPointStr, Object.class);
+                            detail.put("glassPoint", parsedGlassPoint);
+                        } catch (Exception e) {
+                            System.err.println("瑙f瀽 glassPoint 澶辫触: " + e.getMessage());
+                            // 瑙f瀽澶辫触鏃朵繚鐣欏師瀛楃涓叉垨璁剧疆榛樿鍊�
+                            detail.put("glassPoint", new ArrayList<>());
+                        }
+                    } else {
+                        // 绌哄瓧绗︿覆鎴� null 鏃惰缃粯璁ゅ��
+                        detail.put("glassPoint", new ArrayList<>());
+                    }
+                }
+            }
+        }
+
+        // 鎸夌収stockId灏嗘槑缁嗗垎缁勫苟娣诲姞鍒板搴旂殑甯冨眬涓�
+        if (layouts != null && !layouts.isEmpty()) {
+            for (Map<String, Object> layout : layouts) {
+                Object stockIdObj = layout.get("stockId");
+                if (stockIdObj != null) {
+                    Integer stockId = null;
+                    if (stockIdObj instanceof Number) {
+                        stockId = ((Number) stockIdObj).intValue();
+                    } else {
+                        try {
+                            stockId = Integer.valueOf(stockIdObj.toString());
+                        } catch (NumberFormatException e) {
+                            // 濡傛灉鏃犳硶杞崲涓烘暟瀛楋紝鍒欒烦杩囪甯冨眬
+                            continue;
+                        }
+                    }
+                    List<Map<String, Object>> matchedDetails = new ArrayList<>();
+                    for (Map<String, Object> detail : allDetails) {
+                        Object layoutIdObj = detail.get("layoutId");
+                        Object stockSortObj = detail.get("stockSort");
+                        Integer detailStockId = null;
+                        if (layoutIdObj != null) {
+                            if (layoutIdObj instanceof Number) {
+                                detailStockId = ((Number) layoutIdObj).intValue();
+                            } else {
+                                try {
+                                    detailStockId = Integer.valueOf(layoutIdObj.toString());
+                                } catch (NumberFormatException e) {
+                                    // 璺宠繃鏃犳晥鐨刲ayoutId
+                                    continue;
+                                }
+                            }
+                        } else if (stockSortObj != null) {
+                            if (stockSortObj instanceof Number) {
+                                detailStockId = ((Number) stockSortObj).intValue();
+                            } else {
+                                try {
+                                    detailStockId = Integer.valueOf(stockSortObj.toString());
+                                } catch (NumberFormatException e) {
+                                    // 璺宠繃鏃犳晥鐨剆tockSort
+                                    continue;
+                                }
+                            }
+                        }
+                        // 濡傛灉detail鐨剆tockId涓巐ayout鐨剆tockId鍖归厤锛屽垯娣诲姞鍒板尮閰嶅垪琛ㄤ腑
+                        if (detailStockId != null && detailStockId.equals(stockId)) {
+                            matchedDetails.add(detail);
+                        }
+                    }
+                    // 灏嗗尮閰嶇殑鏄庣粏娣诲姞鍒板竷灞�鐨刧lassDetails瀛楁涓�
+                    layout.put("glassDetails", matchedDetails);
+                }
+            }
+        }
+//        Map<String, Object> result = new HashMap<>();
+        Map<String, Object> result = new LinkedHashMap<>();
+        result.put("layouts", layouts);
+        result.put("optimizeUse", glassOptimizeMapper.materialStoreOptimizeUse(processId));
+        return result;
+    }
+
 
     //宸ョ▼淇℃伅
     public Map<String, Object> projectInfoSv(String projectNo,String username) {
@@ -496,6 +623,7 @@
             else if(code==2){
                 glassOptimizeMapper.deleteOptimizeDetail(projectNumber);
                 glassOptimizeMapper.deleteOptimizeLayout(projectNumber);
+                glassOptimizeMapper.deleteOptimizeOffcut(projectNumber);
                 glassOptimizeMapper.deleteOptimizeProjectFile(projectNumber);
                 glassOptimizeMapper.updateOptimizeUse(projectNumber);
                 glassOptimizeMapper.updateProjectOptimizeStateMp(projectNumber, states);
@@ -993,4 +1121,5 @@
         return saveState;
     }
 
+
 }

--
Gitblit v1.8.0