From c18fecddd8c9a165c6a1026c5573f864e1713718 Mon Sep 17 00:00:00 2001
From: guoyujie <guoyujie@ng.com>
Date: 星期三, 06 八月 2025 16:56:29 +0800
Subject: [PATCH] Merge branch 'master' of http://10.153.19.25:10101/r/ERP_override

---
 north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java |  108 +++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 86 insertions(+), 22 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 c6b4230..f6e1d5e 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
@@ -304,22 +304,68 @@
     public Map<String, Object> selectOptimizeResult(String processId) {
         Map<String, Object> map = new HashMap<>();
         map.put("data", glassOptimizeMapper.selectOptimizeResult(processId));
+        map.put("optimizeUse", glassOptimizeMapper.materialStoreOptimizeUse(processId));
         return map;
     }
 
     //宸ョ▼淇℃伅
-    public Map<String, Object> projectInfoSv(String projectNo) {
+    public Map<String, Object> projectInfoSv(String projectNo,String username) {
         Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNo);
         Map<String, Object> map = new HashMap<>();
-        if(Integer.parseInt(stringObjectMap.get("optimize_state").toString())==1||Integer.parseInt(stringObjectMap.get("tempering_state").toString())==1){
-            map.put("optimizeState", Integer.parseInt(stringObjectMap.get("optimize_state").toString()));
-            map.put("data", glassOptimizeMapper.analogComputationOptimization(projectNo));
-            map.put("grindingTrimming", glassOptimizeMapper.getGrindingTrimming());
-        }else{
-            map.put("optimizeState", Integer.parseInt(stringObjectMap.get("optimize_state").toString()));
-            map.put("data", glassOptimizeMapper.firstOptimization(projectNo));
-            map.put("grindingTrimming", glassOptimizeMapper.getGrindingTrimming());
+//        if(Integer.parseInt(stringObjectMap.get("optimize_state").toString())==1){
+//            map.put("optimizeState", Integer.parseInt(stringObjectMap.get("optimize_state").toString()));
+//            map.put("data", glassOptimizeMapper.getOptimizeDetail(projectNo));
+//            map.put("project", glassOptimizeMapper.selectProjectCount(projectNo));
+//            map.put("grindingTrimming", null);
+//        } else if (Integer.parseInt(stringObjectMap.get("tempering_state").toString())==1) {
+//            map.put("optimizeState", Integer.parseInt(stringObjectMap.get("optimize_state").toString()));
+//            map.put("data", glassOptimizeMapper.analogComputationOptimization(projectNo));
+//            map.put("project", glassOptimizeMapper.selectProjectCount(projectNo));
+//            map.put("grindingTrimming", glassOptimizeMapper.getGrindingTrimming(username));
+//        } else{
+//            map.put("optimizeState", Integer.parseInt(stringObjectMap.get("optimize_state").toString()));
+//            map.put("data", glassOptimizeMapper.firstOptimization(projectNo));
+//            map.put("project", glassOptimizeMapper.selectProjectCount(projectNo));
+//            map.put("grindingTrimming", glassOptimizeMapper.getGrindingTrimming(username));
+//        }
+        map.put("optimizeState", Integer.parseInt(stringObjectMap.get("optimize_state").toString()));
+        map.put("data", glassOptimizeMapper.firstOptimization(projectNo));
+        map.put("project", glassOptimizeMapper.selectProjectCount(projectNo));
+        map.put("grindingTrimming", glassOptimizeMapper.getGrindingTrimming(username));
+        return map;
+    }
+
+
+
+
+    public Object optimizeInfoSv(String projectNo, String username) {
+        Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNo);
+        Map<String, Object> map = new HashMap<>();
+        List<Map<String, Object>> dataList = null;
+        if (Integer.parseInt(stringObjectMap.get("tempering_state").toString())==1){
+            dataList = glassOptimizeMapper.computeAndOptimization(projectNo);
+        } else {
+            dataList = glassOptimizeMapper.directOptimization(projectNo);
         }
+
+        // 鑾峰彇纾ㄩ噺閰嶇疆鏁版嵁
+        List<Map<String, Object>> grindingTrimmingList = glassOptimizeMapper.getGrindingOptimize(username);
+        // 灏嗙(閲忛厤缃暟鎹嫾鎺ュ埌姣忔潯涓绘暟鎹悗闈�
+        if (dataList != null && !dataList.isEmpty() && grindingTrimmingList != null && !grindingTrimmingList.isEmpty()) {
+            // 鑾峰彇绗竴鏉$(閲忛厤缃暟鎹紙閫氬父鍙湁涓�鏉¤褰曪級
+            Map<String, Object> grindingConfig = grindingTrimmingList.get(0);
+            // 灏嗙(閲忛厤缃坊鍔犲埌姣忔潯涓绘暟鎹腑
+            for (Map<String, Object> dataItem : dataList) {
+                // 灏嗙(閲忛厤缃殑瀛楁娣诲姞鍒版瘡鏉℃暟鎹腑
+                for (Map.Entry<String, Object> entry : grindingConfig.entrySet()) {
+                    // 閬垮厤瑕嗙洊鍘熸湁瀛楁
+                    if (!dataItem.containsKey(entry.getKey())) {
+                        dataItem.put(entry.getKey(), entry.getValue());
+                    }
+                }
+            }
+        }
+        map.put("data", dataList);
         return map;
     }
 
@@ -332,7 +378,7 @@
     }
 
     //搴撳瓨淇℃伅
-    public Map<String, Object> materialStoreSv(String thickness, String model, String projectNumber,Integer type) {
+    public Map<String, Object> materialStoreSv(String thickness, String model, String projectNumber,Integer type,String username) {
         Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNumber);
         Map<String, Object> map = new HashMap<>();
         if(Integer.parseInt(stringObjectMap.get("optimize_state").toString())==0){
@@ -343,12 +389,13 @@
             }else{
                 map.put("data", glassOptimizeMapper.materialStoreSurplusMp(thickness,model));
             }
-            map.put("edgeTrimming", glassOptimizeMapper.getEdgeTrimming());
+            map.put("edgeTrimming", glassOptimizeMapper.getEdgeTrimming(username));
         }else{
             map.put("data", glassOptimizeMapper.materialStoreOptimizeUse(projectNumber));
             map.put("edgeTrimming", null);
         }
         map.put("state", Integer.parseInt(stringObjectMap.get("state").toString()));
+
         return map;
     }
 
@@ -543,11 +590,25 @@
                 if(projectType.equals("2")){
                     deleteProject(projectId,2);
                 }
+
+                // 鍒涘缓涓�涓槧灏勬潵瀛樺偍 (processId-technologyNumber) 缁勫悎鍒� rack 缂栧彿鐨勬槧灏�
+                Map<String, Integer> rackMap = new HashMap<>();
+                int rackCounter = 1;
+
                 for (FlowCard flowCard : flowCardList) {
+                    // 涓烘瘡涓敮涓�鐨� processId-technologyNumber 缁勫悎鍒嗛厤 rack 缂栧彿
+                    String key = flowCard.getProcessId() + "-" + flowCard.getTechnologyNumber();
+                    if (!rackMap.containsKey(key)) {
+                        rackMap.put(key, rackCounter++);
+                    }
+                    int rackValue = rackMap.get(key);
+
                     if(flowCard.getPatchState().equals(0)){
                         state1=1;
                         //缁欐祦绋嬪崱琛ㄦ坊鍔犲搴旂殑宸ョ▼鍙�
-                        Boolean a=glassOptimizeMapper.updateFlowCardProject(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectId);
+                        Boolean a = glassOptimizeMapper.updateFlowCardProject(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectId);
+                        // 鏇存柊娴佺▼鍗$殑rack瀛楁
+                        glassOptimizeMapper.updateFlowCardRack(flowCard.getProcessId(), flowCard.getTechnologyNumber(), rackValue);
                         area = glassOptimizeMapper.getSelectArea(flowCard.getProcessId(),flowCard.getTechnologyNumber()).doubleValue();
                         sumArea = sumArea.add(BigDecimal.valueOf(area));
                         sumQuantity +=flowCard.getQuantity();
@@ -602,30 +663,30 @@
 
     }
 
-    public Map<String, Object> getConfiguration(String type) {
+    public Map<String, Object> getConfiguration(String type,String username) {
         Map<String, Object> map = new HashMap<>();
         if(type.equals("閽㈠寲")){
-            map.put("data", glassOptimizeMapper.getTemperedConfiguration());
+            map.put("data", glassOptimizeMapper.getTemperedConfiguration(username));
         }else if(type.equals("纾ㄩ噺")){
-            map.put("data", glassOptimizeMapper.getGrindingTrimming());
+            map.put("data", glassOptimizeMapper.getGrindingTrimming(username));
         }else if(type.equals("淇竟")){
-            map.put("data", glassOptimizeMapper.getEdgeTrimming());
+            map.put("data", glassOptimizeMapper.getEdgeTrimming(username));
         }
 
         return map;
     }
 
-    public Boolean saveConfiguration(Map<String,Object> object,String type) {
+    public Boolean saveConfiguration(Map<String,Object> object,String type,String username) {
         String json = "";
         if (object.get("json") != null) {
             json = object.get("json").toString();
         }
         if(type.equals("閽㈠寲")){
-            glassOptimizeMapper.updateOptimizeConfig(json,1);
+            glassOptimizeMapper.updateOptimizeConfig(json,1,username);
         } else if (type.equals("淇竟")) {
-            glassOptimizeMapper.updateOptimizeConfig(json,5);
+            glassOptimizeMapper.updateOptimizeConfig(json,5,username);
         }else if (type.equals("纾ㄩ噺")) {
-            glassOptimizeMapper.updateOptimizeConfig(json,4);
+            glassOptimizeMapper.updateOptimizeConfig(json,4,username);
         }
         return true;
 
@@ -825,7 +886,10 @@
     }
 
 
-
-
+    public Map<String, Object> getProjectByProjectNoSv(String projectNo) {
+        Map<String, Object> map = new HashMap<>();
+        map.put("data", glassOptimizeMapper.getProjectByProjectNoSv(projectNo));
+        return map;
+    }
 
 }

--
Gitblit v1.8.0