From 9cf6783836fcee8afd5519b7bde82e10eadec4df Mon Sep 17 00:00:00 2001
From: guoyujie <guoyujie@ng.com>
Date: 星期五, 08 八月 2025 13:05:16 +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 |   72 +++++++++++++++++++++++++++++++++++
 1 files changed, 71 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 42d0dc3..9535a46 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
@@ -14,7 +14,9 @@
 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.core.JsonProcessingException;
 import com.fasterxml.jackson.databind.ObjectMapper;
+import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -590,11 +592,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();
@@ -878,4 +894,58 @@
         return map;
     }
 
+
+    public Boolean issuingProjects(String projectNo) throws JsonProcessingException {
+        boolean  saveState=false;
+        try {
+            // 1. 鍒涘缓URL瀵硅薄
+            URL url = new URL("http://localhost:88/api/loadGlass/engineering/importEngineer");
+
+            // 2. 鎵撳紑杩炴帴
+            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
+            conn.setRequestMethod("POST");
+            conn.setRequestProperty("Content-Type", "application/json");
+            conn.setRequestProperty("Accept", "application/json");
+            conn.setDoOutput(true);
+
+            // 3. 鍑嗗璇锋眰浣�
+            Map<String, Object> optimizeProject=glassOptimizeMapper.selectOptimizeProject(projectNo);
+            optimizeProject.put("engineeringRawQueueList", glassOptimizeMapper.selectOptimizeLayout(projectNo));
+            optimizeProject.put("glassInfolList", glassOptimizeMapper.selectOptimizeDetail(projectNo));
+            optimizeProject.put("flowCardInfoList", glassOptimizeMapper.selectFlowCardInfoList(projectNo));
+            ObjectMapper mapper = new ObjectMapper();
+            mapper.registerModule(new JavaTimeModule());
+            String jsonInputString = mapper.writeValueAsString(optimizeProject);
+
+            //鍙戦�佽姹�
+            try(OutputStream os = conn.getOutputStream()) {
+                byte[] input = jsonInputString.getBytes(StandardCharsets.UTF_8);
+                os.write(input, 0, input.length);
+            }
+
+            // 鑾峰彇鍝嶅簲
+            try(BufferedReader br = new BufferedReader(
+                    new InputStreamReader(conn.getInputStream(), StandardCharsets.UTF_8))) {
+                StringBuilder response = new StringBuilder();
+                String responseLine;
+                while ((responseLine = br.readLine()) != null) {
+                    response.append(responseLine.trim());
+                }
+                System.out.println("Response: " + response.toString());
+                JSONObject obj = JSONObject.parseObject(response.toString());
+                if(obj.get("code").equals(200)&&obj.get("data").equals(true)){
+                    saveState=true;
+                }
+
+            }
+
+            //鍏抽棴杩炴帴
+            conn.disconnect();
+        } catch (Exception e) {
+            e.printStackTrace();
+            saveState= false;
+        }
+        return saveState;
+    }
+
 }

--
Gitblit v1.8.0