From d5bb894f9be2e0a3b62d475b60b44f2ab138528c Mon Sep 17 00:00:00 2001 From: guoyujie <guoyujie@ng.com> Date: 星期四, 12 六月 2025 16:48:35 +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 | 793 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 783 insertions(+), 10 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 32e97d8..c890126 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 @@ -1,27 +1,392 @@ package com.example.erp.service.pp; +import com.alibaba.fastjson.JSONArray; +import com.alibaba.fastjson.JSONObject; import com.baomidou.dynamic.datasource.annotation.DS; -import com.example.erp.entity.pp.OptimizeProjectMange; +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.example.erp.common.RabbitMQUtil; +import com.example.erp.entity.pp.*; +import com.example.erp.entity.sd.Delivery; +import com.example.erp.entity.sd.OrderDetail; +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; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.transaction.interceptor.TransactionAspectSupport; +import java.io.BufferedReader; +import java.io.IOException; +import java.io.InputStreamReader; +import java.io.OutputStream; +import java.math.BigDecimal; +import java.net.HttpURLConnection; +import java.net.URL; +import java.nio.charset.StandardCharsets; import java.sql.Date; -import java.util.HashMap; -import java.util.Map; +import java.text.DecimalFormat; +import java.time.LocalDate; +import java.util.*; +import java.util.concurrent.TimeoutException; +import java.util.stream.Collectors; @Service +@Transactional(rollbackFor = Exception.class) @DS("sd") public class GlassOptimizeService { @Autowired GlassOptimizeMapper glassOptimizeMapper; + @Autowired + SysErrorService sysErrorService; + + RabbitMQUtil rabbitMQUtil; + //妯℃嫙璁$畻 + + /*public Map<String, Object> SimulationCalculation(Map<String,Object> message) { + Map<String, Object> map = new HashMap<>(); + try { + rabbitMQUtil = new RabbitMQUtil(); + // 鍙戦�佹秷鎭� + + + // 鑾峰彇 computeData 鍜� cardData + *//*Object computeData = message.get("computeData"); + Object cardData = message.get("cardData");*//* + + rabbitMQUtil.sendMessage(message.toString()); + System.out.println("send message: " + message); + String date = rabbitMQUtil.receiveMessages(); + System.out.println("Received message: " + date); + + // 鍏抽棴杩炴帴 + rabbitMQUtil.close(); + map.put("data", date); + + } catch (IOException e) { + e.printStackTrace(); + } catch (TimeoutException | InterruptedException e) { + e.printStackTrace(); + } + + return map; + }*/ + + public Map<String, Object> SimulationCalculation(Map<String,Object> message) { + Map<String, Object> map = new HashMap<>(); + try { + URL url = new URL("https://example.com"); // 鏇挎崲涓轰綘鐨勭洰鏍� URL + HttpURLConnection conn = (HttpURLConnection) url.openConnection(); + + conn.setRequestMethod("POST"); + conn.setDoOutput(true); // 鍏佽鍐欏叆璇锋眰浣� + conn.setConnectTimeout(5000); + // 璇诲彇瓒呮椂锛堢瓑寰呮湇鍔″櫒鍝嶅簲鐨勬渶澶ф椂闂达級 + conn.setReadTimeout(108000); + + // 鍐欏叆璇锋眰浣撴暟鎹� + String postData = message.toString(); + try (OutputStream os = conn.getOutputStream()) { + byte[] input = postData.getBytes(StandardCharsets.UTF_8); + os.write(input, 0, input.length); + } + + // 3. 鑾峰彇鐘舵�佺爜 + int statusCode = conn.getResponseCode(); + System.out.println("鐘舵�佺爜: " + statusCode); + + // 4. 璇诲彇鍝嶅簲鍐呭 + BufferedReader reader = new BufferedReader( + new InputStreamReader(conn.getInputStream()) + ); + String line; + StringBuilder response = new StringBuilder(); + while ((line = reader.readLine()) != null) { + response.append(line); + } + reader.close(); + + // 杈撳嚭鍝嶅簲鍐呭 + System.out.println("鍝嶅簲鍐呭:\n" + response.toString()); + + }catch (Exception e) { + e.printStackTrace(); + } + + return map; + } + + +//妯℃嫙璁$畻淇濆瓨 + public Boolean addSimulation(Map<String, Object> object) { + try { + Map<String, Object> objectMap = (Map<String, Object>) object.get("inputValues"); + String projectNo = objectMap.get("project_no").toString(); + String userName = object.get("userName").toString(); + Map<String, Object> optimizeProjectMap = glassOptimizeMapper.selectProjectCount(projectNo); + + if(Integer.valueOf(object.get("state").toString())==3){ + List<Map<String, Object>> flowCardList = glassOptimizeMapper.selectProjectComputeMp(projectNo); + int index=0; + for (Map<String, Object> flowCard:flowCardList){ + List<Map<String, Object>> glassDetailList=new ArrayList<>(); + if(Integer.valueOf(flowCard.get("patch_state").toString())==0){ + glassDetailList = glassOptimizeMapper.selectComputeDetailMp(flowCard.get("processId").toString(), + Integer.valueOf(flowCard.get("technologyNumber").toString())); + + }else{ + glassDetailList = glassOptimizeMapper.selectComputeDetailMpPatchState(flowCard.get("processId").toString(), + Integer.valueOf(flowCard.get("technologyNumber").toString())); + } + for (Map<String, Object> glassDetail:glassDetailList){ + for(int i=0;i<Integer.valueOf(glassDetail.get("quantity").toString());i++){ + index+=1; + glassOptimizeMapper.insertOptimizeHeatDetail( + projectNo,flowCard.get("processId").toString(), + Integer.valueOf(flowCard.get("technologyNumber").toString()), + Integer.valueOf(flowCard.get("patch_state").toString()), + Integer.valueOf(glassDetail.get("order_number").toString()), + Double.valueOf(glassDetail.get("width").toString()), + Double.valueOf(glassDetail.get("height").toString()),index,userName + ); + + } + } + glassOptimizeMapper.updateProjectTemperingStateMp(projectNo,1); + } + }else{ + List<Map<String, Object>> objectList = (List<Map<String, Object>>) object.get("projectdetail"); + for (Map<String, Object> objectMap1:objectList){ + Integer count = glassOptimizeMapper.selectPatchLogState(objectMap1.get("process_id").toString(), + Integer.valueOf(objectMap1.get("layers_number").toString()),Integer.valueOf(objectMap1.get("order_number").toString()),projectNo); + if(count>0){ + objectMap1.put("patchState",1); + }else { + objectMap1.put("patchState",0); + } + } + glassOptimizeMapper.addSimulation(object); + glassOptimizeMapper.addratioResult(object); + glassOptimizeMapper.addratioProjectResult(object); + + + if(Integer.valueOf(object.get("state").toString())==2){ + List<Map<String, Object>> flowCardList = glassOptimizeMapper.selectProjectComputeMp(projectNo); + List<String> rackinfosList = (List<String>) object.get("rackinfos"); + Iterator<Map<String, Object>> iterator = flowCardList.iterator(); + while (iterator.hasNext()) { + Map<String, Object> map = iterator.next(); + for(String rackinfos:rackinfosList){ + String processId=rackinfos.substring(0,14); + String processId1=map.get("processId").toString(); + Integer technologyNumber= Integer.valueOf(rackinfos.substring(15)); + Integer technologyNumber1= Integer.valueOf(map.get("technologyNumber").toString()); + if(map.get("processId").toString().equals(processId) && Integer.valueOf(map.get("technologyNumber").toString())==technologyNumber){ + iterator.remove(); + } + } + } + + int index=0; + for (Map<String, Object> flowCard:flowCardList){ + List<Map<String, Object>> glassDetailList=new ArrayList<>(); + if(flowCard.get("patch_state").toString()=="0"){ + glassDetailList = glassOptimizeMapper.selectComputeDetailMp(flowCard.get("processId").toString(), + Integer.valueOf(flowCard.get("technologyNumber").toString())); + + }else{ + glassDetailList = glassOptimizeMapper.selectComputeDetailMp(flowCard.get("processId").toString(), + Integer.valueOf(flowCard.get("technologyNumber").toString())); + } + for (Map<String, Object> glassDetail:glassDetailList){ + for(int i=0;i<Integer.valueOf(glassDetail.get("quantity").toString());i++){ + index+=1; + glassOptimizeMapper.insertOptimizeHeatDetail( + projectNo,flowCard.get("processId").toString(), + Integer.valueOf(flowCard.get("technologyNumber").toString()), + Integer.valueOf(flowCard.get("patch_state").toString()), + Integer.valueOf(glassDetail.get("order_number").toString()), + Double.valueOf(glassDetail.get("width").toString()), + Double.valueOf(glassDetail.get("height").toString()),index,userName + ); + + } + } + } + } + + } + if(Integer.valueOf(optimizeProjectMap.get("optimize_state").toString())==1){ + List<OptimizeHeatDetail> optimizeHeatDetail = glassOptimizeMapper.selectOptimizeHeatDetail(projectNo); + for (OptimizeHeatDetail projectdetail:optimizeHeatDetail){ + OptimizeDetail optimizeDetail=glassOptimizeMapper.selectOptimizeDetailById(projectNo,projectdetail.getProcessId(), + projectdetail.getOrderSort(),projectdetail.getLayer()); + glassOptimizeMapper.updateOptimizeDetail(optimizeDetail.getId(),projectdetail.getLayoutId(),projectdetail.getSort()); + } + } + + return true; + } catch (Exception e) { + e.printStackTrace(); + return false; + } + } + + + //浼樺寲璁剧疆淇濆瓨 + public Boolean optimizeParmsSave(Map<String, Object> object,String username) { + try { + ObjectMapper mapper = new ObjectMapper(); + String jsonString = mapper.writeValueAsString(object); + + glassOptimizeMapper.optimizeParmsSave(jsonString,username); + return true; + } catch (Exception e) { + e.printStackTrace(); + return false; + } + } + + + + //浼樺寲璋冩暣缁撴灉淇濆瓨 + public Boolean saveOptimizeResult(Map<String, Object> object,String projectId) { + try { + Map<String, Object> optimalResults = (Map<String, Object>) object.get("optimalResults"); + List<Map<String, Object>> originalFilm = (List<Map<String, Object>>) object.get("originalFilm"); + glassOptimizeMapper.addOptimizeUse(originalFilm,projectId,"admin"); + + ObjectMapper mapper = new ObjectMapper(); + String json = mapper.writeValueAsString(optimalResults); + glassOptimizeMapper.addOptimizeProjectFile(json,projectId,"admin"); + + List<Map<String, Object>> objectMapList = (List<Map<String, Object>>) optimalResults.get("layouts"); + glassOptimizeMapper.addOptimizeLayout(objectMapList,projectId); + for(Map<String, Object> objectMap:objectMapList){ + List<Map<String, Object>> objectMap2 = (List<Map<String, Object>>) objectMap.get("glassDetails"); + //杩唬鐜荤拑鏄庣粏闆嗗悎鍒犻櫎浣欐枡 + Iterator<Map<String, Object>> iterator = objectMap2.iterator(); + while (iterator.hasNext()) { + Map<String, Object> map = iterator.next(); + if (map.get("isRemain").toString()=="true") { + iterator.remove(); + } + } + + glassOptimizeMapper.addOptimizeDetail(objectMap2,projectId); + } + glassOptimizeMapper.updateProjectOptimizeStateMp(projectId,1); + return true; + } catch (Exception e) { + e.printStackTrace(); + return false; + } + } + + + public Boolean updateOptimizeResult(Map<String, Object> object,String processId){ + try { + ObjectMapper mapper = new ObjectMapper(); + String jsonString = mapper.writeValueAsString(object); + glassOptimizeMapper.updateOptimizeResult(jsonString,processId); + return true; + } catch (Exception e) { + e.printStackTrace(); + return false; + } + } + + //浼樺寲璋冩暣缁撴灉鏌ヨ + 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,String username) { + Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNo); + Map<String, Object> map = new HashMap<>(); + 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)); + } + return map; + } + + + //宸ョ▼淇℃伅娴佺▼鍗� + public Map<String, Object> getProcessCardSv(String projectNo) { + Map<String, Object> map = new HashMap<>(); + map.put("data", glassOptimizeMapper.getProcessCardMp(projectNo)); + return map; + } + + //搴撳瓨淇℃伅 + 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){ + if(type==1){ + map.put("data", glassOptimizeMapper.materialStoreMp(thickness,model)); + }else if(type==2){ + map.put("data", glassOptimizeMapper.surplusMaterialsMp(thickness,model)); + }else{ + map.put("data", glassOptimizeMapper.materialStoreSurplusMp(thickness,model)); + } + 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; + } //宸ョ▼鏌ヨ娴佺▼鍗� public Map<String, Object> getFlowCardList(String optionVal, Integer radio) { Map<String, Object> map = new HashMap<>(); - map.put("data", glassOptimizeMapper.getFlowCardListMp(optionVal, radio)); + if(radio==1){ + map.put("data", glassOptimizeMapper.getFlowCardListWhole(optionVal)); + }else if(radio==2){ + map.put("data", glassOptimizeMapper.getFlowCardListNormal(optionVal)); + }else{ + map.put("data", glassOptimizeMapper.getFlowCardListPatch(optionVal)); + } + + + return map; + } + + public Map<String, Object> getUpdateFlowCardList(String type,String thickness, Integer radio,String projectNo) { + Map<String, Object> map = new HashMap<>(); + if(radio==1){ + map.put("data", glassOptimizeMapper.getFlowCardListModify(type,thickness,projectNo)); + }else if(radio==2){ + map.put("data", glassOptimizeMapper.getFlowCardListNormal(type)); + }else{ + map.put("data", glassOptimizeMapper.getFlowCardListPatch(type)); + } + return map; } @@ -34,9 +399,34 @@ } //淇敼鎺掔増鐘舵�� - public Boolean updateProjectState(String projectNumber, Integer state) { + public Boolean updateProjectState(String projectNumber, Integer state,Integer states, Integer code) { if (!projectNumber.isEmpty()) { - glassOptimizeMapper.updateProjectStateMp(projectNumber, state); + //鎾ら攢妯℃嫙璁$畻 + if(code==1){ + glassOptimizeMapper.deleteOptimizeHeatDetail(projectNumber); + glassOptimizeMapper.deleteOptimizeHeatLayout(projectNumber); + glassOptimizeMapper.updateProjectTemperingStateMp(projectNumber, states); + } + //鎾ら攢浼樺寲鎺掔増 + else if(code==2){ + glassOptimizeMapper.deleteOptimizeDetail(projectNumber); + glassOptimizeMapper.deleteOptimizeLayout(projectNumber); + glassOptimizeMapper.deleteOptimizeProjectFile(projectNumber); + glassOptimizeMapper.updateOptimizeUse(projectNumber); + glassOptimizeMapper.updateProjectOptimizeStateMp(projectNumber, states); + } + //鍏佽鐢熶骇 + else if(code==3){ + glassOptimizeMapper.updateProjectStateMp(projectNumber, state); + } + //鐢熶骇涓嶅彲瑙� + else if(code==4){ + glassOptimizeMapper.updateProjectStateMp(projectNumber, state); + } + //鍒濆鍖栧伐绋� + else if(code==5){ + glassOptimizeMapper.updateProjectStateMp(projectNumber, state); + } return true; } else { return false; @@ -44,10 +434,37 @@ } //鍒犻櫎宸ョ▼ - public Map<String, Object> deleteProject(String projectNumber) { - Map<String, Object> map = new HashMap<>(); - map.put("data", glassOptimizeMapper.deleteProjectMp(projectNumber)); - return map; + public boolean deleteProject(String projectNumber,Integer type) { + Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNumber); + if(stringObjectMap.get("tempering_state").equals(1)){ + glassOptimizeMapper.deleteOptimizeHeatDetail(projectNumber); + glassOptimizeMapper.deleteOptimizeHeatLayout(projectNumber); + } + if(stringObjectMap.get("optimize_state").equals(1)){ + glassOptimizeMapper.deleteOptimizeDetail(projectNumber); + glassOptimizeMapper.deleteOptimizeLayout(projectNumber); + glassOptimizeMapper.deleteOptimizeLayout(projectNumber); + glassOptimizeMapper.updateOptimizeUse(projectNumber); + glassOptimizeMapper.deleteOptimizeHeatDetail(projectNumber); + glassOptimizeMapper.deleteOptimizeHeatLayout(projectNumber); + } + List<FlowCard> flowCardList =glassOptimizeMapper.getFlowCardList(projectNumber); + List<PatchLog> patchLogList =glassOptimizeMapper.getPatchLogList(projectNumber); + if(flowCardList!=null){ + for (FlowCard flowCard:flowCardList){ + glassOptimizeMapper.updateFlowCardProjectReturn(flowCard.getProcessId(),flowCard.getTechnologyNumber(),projectNumber); + } + } + if(patchLogList!=null){ + for (PatchLog patchLog:patchLogList){ + glassOptimizeMapper.updatePatchLogProjectReturn(patchLog.getProcessId(),patchLog.getTechnologyNumber(),projectNumber); + } + } + //鍒ゆ柇鏄惁鏄慨鏀瑰伐绋� + if(type.equals(1)){ + glassOptimizeMapper.deleteProjectMp(projectNumber); + } + return true; } @@ -61,7 +478,363 @@ public Map<String, Object>selectProjectComputeSv(String projectNumber) { Map<String, Object> map = new HashMap<>(); map.put("data", glassOptimizeMapper.selectProjectComputeMp(projectNumber)); + //map.put("project", glassOptimizeMapper.selectProjectCount(projectNumber)); return map; } + public Map<String, Object>selectProjectComputeAll(String projectNumber) { + Map<String, Object> map = new HashMap<>(); + List<Map<String, Object>> projectComputeMpList=glassOptimizeMapper.selectProjectComputeMp(projectNumber); + for (Map<String, Object> stringObjectMap : projectComputeMpList) { + stringObjectMap.get("process_id"); + stringObjectMap.get("technology_number"); + } + map.put("data", glassOptimizeMapper.selectProjectComputeMp(projectNumber)); + //map.put("project", glassOptimizeMapper.selectProjectCount(projectNumber)); + return map; + } + + //妯℃嫙璁$畻娴佺▼鍗¤鎯� + public Map<String, Object>selectComputeDetailSv(String processId,Integer technologyNumber,String patchState) { + Map<String, Object> map = new HashMap<>(); + if(patchState.equals("0")){ + map.put("data", glassOptimizeMapper.selectComputeDetailMp(processId,technologyNumber)); + }else{ + map.put("data", glassOptimizeMapper.selectComputeDetailMpPatchState(processId,technologyNumber)); + } + return map; + } + + public Map<String, Object> getProcessCardDetailSv(String processId, Integer technologyNumber) { + Map<String, Object> map = new HashMap<>(); + map.put("data", glassOptimizeMapper.getProcessCardDetailmMp(processId,technologyNumber)); + return map; + } + + public Map<String, Object> selectGlassTypeSv() { + Map<String, Object> map = new HashMap<>(); + map.put("data", glassOptimizeMapper.selectGlassTypeMp()); + return map; + } + + + public Map<String, Object> getProjectIdSv() { + Map<String, Object> map = new HashMap<>(); + map.put("data", glassOptimizeMapper.getProjectIdSv()); + return map; + } + + 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(); + } + 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"; + + } + } 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,String username) { + Map<String, Object> map = new HashMap<>(); + if(type.equals("閽㈠寲")){ + map.put("data", glassOptimizeMapper.getTemperedConfiguration(username)); + }else if(type.equals("纾ㄩ噺")){ + map.put("data", glassOptimizeMapper.getGrindingTrimming(username)); + }else if(type.equals("淇竟")){ + map.put("data", glassOptimizeMapper.getEdgeTrimming(username)); + } + + return map; + } + + 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,username); + } else if (type.equals("淇竟")) { + glassOptimizeMapper.updateOptimizeConfig(json,5,username); + }else if (type.equals("纾ㄩ噺")) { + glassOptimizeMapper.updateOptimizeConfig(json,4,username); + } + return true; + + } + + + + + public String simulatedTypesetting1(Map<String, Object> object) { + + String optionVal = ""; + int quantity; + Double area; + if (object.get("optionVal") != null) { + optionVal = object.get("optionVal").toString(); + } + if (object.get("quantity") != null) { + quantity = Integer.valueOf(object.get("quantity").toString()); + } else { + quantity = 0; + } + if (object.get("area") != null) { + area = Double.valueOf(object.get("area").toString()); + } else { + area = 0.0; + } + + JSONArray materialStore = JSONArray.parseArray(JSONObject.toJSONString(object.get("materialStore"))); + + + List<Map<String, Object>> flowCardListNormal = glassOptimizeMapper.getFlowCardListSimulated(optionVal); + + + Queue<Map<String, Object>> queue = flowCardListNormal.stream() + .filter(item -> { + if ((quantity>0 ? (Integer.valueOf(item.get("quantity").toString()) > quantity):false) || (area>0 ? (Double.valueOf(item.get("area").toString()) > area):false)) { + return false; + } + return true; + }) + .collect(Collectors.toCollection(LinkedList::new)); + + List<Map<String, Object>> result = new ArrayList<>(); + + while (!queue.isEmpty()) { + List<Map<String, Object>> currentGroup = new ArrayList<>(); + Map<String, Object> currentGroupMap = new HashMap<>(); + int currentCount = 0; + double currentArea = 0; + + // 澶勭悊褰撳墠杞闃熷垪涓殑鎵�鏈夊厓绱� + int queueSize = queue.size(); + boolean addedAny = false; + + String processId=""; + for (int i = 0; i < queueSize; i++) { + Map<String, Object> item = queue.poll(); + if ((quantity>0?currentCount + Integer.valueOf(item.get("quantity").toString()) <= quantity:true) + && (area>0?currentArea + Double.valueOf(item.get("area").toString()) <= area:true)) { + if(i+1==queueSize){ + processId=processId+item.get("process_id").toString()+"/"+item.get("technology_number").toString(); + }else{ + processId=processId+item.get("process_id").toString()+"/"+item.get("technology_number").toString()+";"; + } + currentGroup.add(item); + currentCount += Integer.valueOf(item.get("quantity").toString()); + currentArea += Double.valueOf(item.get("area").toString()); + addedAny = true; + } else { + queue.offer(item); // 鏀惧洖闃熷垪绛夊緟涓嬫澶勭悊 + } + } + + if (currentGroup.isEmpty()) { + throw new RuntimeException("鏃犳硶缁х画鍒嗙粍锛屽墿浣欐暟鎹棤娉曟斁鍏ヤ换浣曞垎缁�"); + } + currentGroupMap.put("processId",processId); + currentGroupMap.put("count",currentCount); + currentGroupMap.put("area",Math.round(currentArea * 100) / 100.0); + result.add(currentGroupMap); + //System.out.println("娴佺▼鍗�:"+processId+"鏁伴噺:"+currentCount+"闈㈢Н:"+Math.round(currentArea * 100) / 100.0); + } + + for (Map<String, Object> objectMap:result){ + Map<String,Object> map = new HashMap<>(); + String[] substrings = objectMap.get("processId").toString().split(";"); + List<Map<String, Object>> flowCardMap = new ArrayList<>(); + List<String> processIdList=new ArrayList<>(); + List<Integer> technologyNumberList=new ArrayList<>(); + for(String substring : substrings) { + String processId = substring.substring(0, 14); + Integer technologyNumber = Integer.valueOf(substring.substring(15)); + processIdList.add(processId); + technologyNumberList.add(technologyNumber); + } + map.put("data",glassOptimizeMapper.simulatedTypesettingUsingOpt(processIdList,technologyNumberList)); + objectMap.put("cuttingRate",90); + } + System.out.println(result); + + return ""; + + } + + + + + + + + + + + //妯℃嫙璁$畻宸ョ▼鍙锋煡璇� + public Map<String, Object>selectProjectComputeMpThirdParty(String projectNumber) { + Map<String, Object> map = new HashMap<>(); + map.put("data", glassOptimizeMapper.selectProjectComputeMpThirdParty(projectNumber)); + return map; + } + + //妯℃嫙璁$畻娴佺▼鍗¤鎯� + public Map<String, Object>selectComputeDetailThirdParty(String processId,Integer technologyNumber) { + Map<String, Object> map = new HashMap<>(); + map.put("data", glassOptimizeMapper.selectComputeDetailMpThirdParty(processId,technologyNumber)); + return map; + } + + public Boolean simulationSaveThirdParty(Map<String, Object> object) { + try { + Map<String, Object> objectMap = (Map<String, Object>) object.get("inputValues"); + String projectNo = objectMap.get("project_no").toString(); + Map<String, Object> optimizeProjectMap = glassOptimizeMapper.selectProjectCount(projectNo); + glassOptimizeMapper.addSimulation(object); + glassOptimizeMapper.addratioResult(object); + glassOptimizeMapper.addratioProjectResult(object); + + List<OptimizeHeatDetail> optimizeHeatDetail = glassOptimizeMapper.selectOptimizeHeatDetail(projectNo); + for (OptimizeHeatDetail projectdetail:optimizeHeatDetail){ + OptimizeDetail optimizeDetail=glassOptimizeMapper.selectOptimizeDetailById(projectNo,projectdetail.getProcessId(), + projectdetail.getOrderSort(),projectdetail.getLayer()); + glassOptimizeMapper.updateOptimizeDetail(optimizeDetail.getId(),projectdetail.getLayoutId(),projectdetail.getSort()); + } + + + return true; + } catch (Exception e) { + e.printStackTrace(); + return false; + } + } + + //鍒犻櫎宸ョ▼ + public boolean deleteProjectThirdParty(String projectNumber) { + Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNumber); + if(stringObjectMap.get("state").equals(2)){ + glassOptimizeMapper.deleteOptimizeDetailThirdParty(projectNumber); + glassOptimizeMapper.deleteOptimizeDetail(projectNumber); + }else if(stringObjectMap.get("state").equals(10)){ + glassOptimizeMapper.deleteOptimizeDetailThirdParty(projectNumber); + glassOptimizeMapper.deleteOptimizeHeatDetail(projectNumber); + glassOptimizeMapper.deleteOptimizeHeatLayout(projectNumber); + } + glassOptimizeMapper.deleteProjectMp(projectNumber); + + return true; + } + + //宸ョ▼淇℃伅 + public Map<String, Object> projectInfoThirdParty(String projectNo) { + Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNo); + Map<String, Object> map = new HashMap<>(); + if(stringObjectMap.get("state").equals(2)){ + map.put("data", glassOptimizeMapper.firstOptimizationThirdParty(projectNo)); + map.put("grindingTrimming", null); + }else{ + map.put("data", glassOptimizeMapper.firstOptimizationThirdParty(projectNo)); + map.put("grindingTrimming", null); + } + return map; + } + + //搴撳瓨淇℃伅 + public Map<String, Object> materialStoreSvThirdParty(String projectNumber) { + Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNumber); + Map<String, Object> map = new HashMap<>(); + map.put("data", glassOptimizeMapper.materialStoreOptimizeUse(projectNumber)); + map.put("edgeTrimming", null); + map.put("state", Integer.parseInt(stringObjectMap.get("state").toString())); + return map; + } + + //宸ョ▼淇℃伅娴佺▼鍗� + public Map<String, Object> getProcessCardMpThirdParty(String projectNo) { + Map<String, Object> map = new HashMap<>(); + map.put("data", glassOptimizeMapper.getProcessCardMpThirdParty(projectNo)); + return map; + } + + + + + } -- Gitblit v1.8.0