From 57b86c98aeecb6e4cec9bec7bd57040109d479e3 Mon Sep 17 00:00:00 2001
From: 廖井涛 <2265517004@qq.com>
Date: 星期四, 10 四月 2025 16:50:31 +0800
Subject: [PATCH] 工程修改功能完善,模拟计算流程卡查询明细完善,第一次优化右键添加原片功能

---
 north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java |  161 +++++++++++++++++++++++++++++++++--------------------
 1 files changed, 99 insertions(+), 62 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 9892b34..843db1b 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
@@ -11,6 +11,7 @@
 import com.example.erp.entity.userInfo.Log;
 import com.example.erp.entity.userInfo.SysError;
 import com.example.erp.mapper.pp.GlassOptimizeMapper;
+import com.example.erp.service.userInfo.SysErrorService;
 import com.fasterxml.jackson.databind.ObjectMapper;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
@@ -25,10 +26,13 @@
 import java.util.concurrent.TimeoutException;
 
 @Service
+@Transactional(rollbackFor = Exception.class)
 @DS("sd")
 public class GlassOptimizeService {
     @Autowired
     GlassOptimizeMapper glassOptimizeMapper;
+    @Autowired
+    SysErrorService sysErrorService;
 
     RabbitMQUtil rabbitMQUtil;
     //妯℃嫙璁$畻
@@ -156,14 +160,17 @@
     public Map<String, Object> materialStoreSv(String thickness, String model, String projectNumber) {
         Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNumber);
         Map<String, Object> map = new HashMap<>();
-        if(Integer.parseInt(stringObjectMap.get("state").toString())<=10){
+        if(Integer.parseInt(stringObjectMap.get("state").toString())<10){
+            map.put("data", glassOptimizeMapper.materialStoreMp(thickness,model));
+            map.put("edgeTrimming", glassOptimizeMapper.getEdgeTrimming());
+        }else if(Integer.parseInt(stringObjectMap.get("state").toString())==10){
             map.put("data", glassOptimizeMapper.materialStoreMp(thickness,model));
             map.put("edgeTrimming", glassOptimizeMapper.getEdgeTrimming());
         }else{
             map.put("data", glassOptimizeMapper.materialStoreOptimizeUse(projectNumber));
             map.put("edgeTrimming", null);
         }
-
+        map.put("state", Integer.parseInt(stringObjectMap.get("state").toString()));
         return map;
     }
 
@@ -239,7 +246,7 @@
     }
 
     //鍒犻櫎宸ョ▼
-    public boolean deleteProject(String projectNumber) {
+    public boolean deleteProject(String projectNumber,Integer type) {
         Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNumber);
         if(stringObjectMap.get("state").equals(10)){
             glassOptimizeMapper.deleteOptimizeHeatDetail(projectNumber);
@@ -261,8 +268,10 @@
                 glassOptimizeMapper.updatePatchLogProjectReturn(patchLog.getProcessId(),patchLog.getTechnologyNumber(),projectNumber);
             }
         }
-
-        glassOptimizeMapper.deleteProjectMp(projectNumber);
+        //鍒ゆ柇鏄惁鏄慨鏀瑰伐绋�
+        if(type.equals(1)){
+            glassOptimizeMapper.deleteProjectMp(projectNumber);
+        }
         return true;
     }
 
@@ -282,9 +291,13 @@
     }
 
     //妯℃嫙璁$畻娴佺▼鍗¤鎯�
-    public Map<String, Object>selectComputeDetailSv(String processId) {
+    public Map<String, Object>selectComputeDetailSv(String processId,Integer technologyNumber,String patchState) {
         Map<String, Object> map = new HashMap<>();
-        map.put("data", glassOptimizeMapper.selectComputeDetailMp(processId));
+        if(patchState.equals("0")){
+            map.put("data", glassOptimizeMapper.selectComputeDetailMp(processId,technologyNumber));
+        }else{
+            map.put("data", glassOptimizeMapper.selectComputeDetailMpPatchState(processId,technologyNumber));
+        }
         return map;
     }
 
@@ -307,67 +320,91 @@
         return map;
     }
 
-    public Boolean addProjectSv(String optionVal, String projectId, String projectNmae, Map<String, Object> object) {
-        String userName = "";
-        if (object.get("userName") != null) {
-            userName = object.get("userName").toString();
-        }
-        String projectType = "";
-        if (object.get("projectType") != null) {
-            projectType = object.get("projectType").toString();
-        }
-        if ("null".equals(projectNmae)) {
-            projectNmae = "";
-        }
-        BigDecimal sumArea = new BigDecimal(0);
-        double area = 0;
-        Integer sumQuantity = 0;
-        Integer type = 0;
-        int state1 = 0;
-        int state2 = 0;
-        StringBuilder processId= new StringBuilder();
-        List<FlowCard> flowCardList = JSONArray.parseArray(JSONObject.toJSONString(object.get("projectdetail")), FlowCard.class);
-        if (!flowCardList.isEmpty()) {
-            if(projectType.equals("2")){
-                deleteProject(projectId);
+    public String addProjectSv(String optionVal, String projectId, String projectNmae, Map<String, Object> object) {
+        String saveState = "true";
+        //璁剧疆鍥炴粴鐐�
+        Object savePoint = TransactionAspectSupport.currentTransactionStatus().createSavepoint();
+        try {
+            String userName = "";
+            if (object.get("userName") != null) {
+                userName = object.get("userName").toString();
             }
-            for (FlowCard flowCard : flowCardList) {
-                if(flowCard.getPatchState().equals(0)){
-                    state1=1;
-                    //缁欐祦绋嬪崱琛ㄦ坊鍔犲搴旂殑宸ョ▼鍙�
-                    Boolean a=glassOptimizeMapper.updateFlowCardProject(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectId);
-                    area = glassOptimizeMapper.getSelectArea(flowCard.getProcessId(),flowCard.getTechnologyNumber()).doubleValue();
-                    sumArea = sumArea.add(BigDecimal.valueOf(area));
-                    sumQuantity +=flowCard.getQuantity();
-                    processId.append(flowCard.getProcessId()).append("-").append(flowCard.getTechnologyNumber()).append(";");
-                }else{
-                    state2=1;
-                    Boolean a=glassOptimizeMapper.updatePatchLogProject(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectId);
-                    area = glassOptimizeMapper.getSelectAreaPatchLog(flowCard.getProcessId(),flowCard.getTechnologyNumber()).doubleValue();
-                    sumArea = sumArea.add(BigDecimal.valueOf(area));
-                    sumQuantity +=flowCard.getQuantity();
-                    processId.append(flowCard.getProcessId()).append("-").append(flowCard.getTechnologyNumber()).append(";");
+            String projectType = "";
+            if (object.get("projectType") != null) {
+                projectType = object.get("projectType").toString();
+            }
+            if ("null".equals(projectNmae)) {
+                projectNmae = "";
+            }
+            BigDecimal sumArea = new BigDecimal(0);
+            double area = 0;
+            Integer sumQuantity = 0;
+            Integer type = 0;
+            int state1 = 0;
+            int state2 = 0;
+            StringBuilder processId= new StringBuilder();
+            List<FlowCard> flowCardList = JSONArray.parseArray(JSONObject.toJSONString(object.get("projectdetail")), FlowCard.class);
+            if (!flowCardList.isEmpty()) {
+                if(projectType.equals("2")){
+                    deleteProject(projectId,2);
                 }
+                for (FlowCard flowCard : flowCardList) {
+                    if(flowCard.getPatchState().equals(0)){
+                        state1=1;
+                        //缁欐祦绋嬪崱琛ㄦ坊鍔犲搴旂殑宸ョ▼鍙�
+                        Boolean a=glassOptimizeMapper.updateFlowCardProject(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectId);
+                        area = glassOptimizeMapper.getSelectArea(flowCard.getProcessId(),flowCard.getTechnologyNumber()).doubleValue();
+                        sumArea = sumArea.add(BigDecimal.valueOf(area));
+                        sumQuantity +=flowCard.getQuantity();
+                        processId.append(flowCard.getProcessId()).append("-").append(flowCard.getTechnologyNumber()).append(";");
+                    }else{
+                        state2=1;
+                        Boolean a=glassOptimizeMapper.updatePatchLogProject(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectId);
+                        area = glassOptimizeMapper.getSelectAreaPatchLog(flowCard.getProcessId(),flowCard.getTechnologyNumber()).doubleValue();
+                        sumArea = sumArea.add(BigDecimal.valueOf(area));
+                        sumQuantity +=flowCard.getQuantity();
+                        processId.append(flowCard.getProcessId()).append("-").append(flowCard.getTechnologyNumber()).append(";");
+                    }
+
+                }
+                if(state1==1&&state2==0){
+                    type=1;
+                }else if(state1==1&&state2==1){
+                    type=2;
+                }
+                int index = optionVal.indexOf("mm");
+                // 鑾峰彇 "mm" 鍓嶉潰鐨勯儴鍒�
+                String glass_thickness = optionVal.substring(0, index);
+                // 鑾峰彇 "mm" 鍚庨潰鐨勯儴鍒�
+                String glass_type = optionVal.substring(index + 2);
+                if(projectType.equals("2")){
+                    glassOptimizeMapper.updateProjectMp(projectId,projectNmae,glass_thickness,glass_type,sumQuantity,sumArea.doubleValue(),userName,
+                            flowCardList.size(), String.valueOf(processId),type);
+                }else{
+                    if(glassOptimizeMapper.selectProjectCount(projectId)==null){
+                        glassOptimizeMapper.addProjectMp(projectId,projectNmae,glass_thickness,glass_type,sumQuantity,sumArea.doubleValue(),userName,
+                                flowCardList.size(), String.valueOf(processId),type);
+                    }else{
+                        TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(savePoint);
+                        return "false1";
+                    }
+                }
+            }else {
+                return "false2";
 
             }
-            if(state1==1&&state2==0){
-                type=1;
-            }else if(state1==1&&state2==1){
-                type=2;
-            }
-            int index = optionVal.indexOf("mm");
-            // 鑾峰彇 "mm" 鍓嶉潰鐨勯儴鍒�
-            String glass_thickness = optionVal.substring(0, index);
-            // 鑾峰彇 "mm" 鍚庨潰鐨勯儴鍒�
-            String glass_type = optionVal.substring(index + 2);
-            glassOptimizeMapper.addProjectMp(projectId,projectNmae,glass_thickness,glass_type,sumQuantity,sumArea.doubleValue(),userName,
-                    flowCardList.size(), String.valueOf(processId),type);
-            return true;
-        }
-        else {
-            return false;
+        } catch (Exception e) {
+            TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(savePoint);
+            //灏嗗紓甯镐紶鍏ユ暟鎹簱
+            SysError sysError = new SysError();
+            sysError.setError(e+Arrays.toString(e.getStackTrace()));
+            sysError.setFunc("addProjectSv");
+            sysErrorService.insert(sysError);
+            saveState = "false";
 
         }
+        return saveState;
+
     }
 
     public Map<String, Object> getConfiguration(String type) {

--
Gitblit v1.8.0