From eb6c8328231985b96ad11b38b38ae1ec926beb9a Mon Sep 17 00:00:00 2001 From: chenlu <1320612696@qq.com> Date: 星期一, 19 五月 2025 22:51:46 +0800 Subject: [PATCH] Merge branch 'master' of http://bore.pub:10439/r/ERP_override --- north-glass-erp/src/main/java/com/example/erp/service/pp/GlassOptimizeService.java | 179 +++++++++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 148 insertions(+), 31 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 f79fbea..c6b4230 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 @@ -4,6 +4,8 @@ import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.baomidou.dynamic.datasource.annotation.DS; +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; @@ -28,6 +30,7 @@ import java.nio.charset.StandardCharsets; import java.sql.Date; import java.text.DecimalFormat; +import java.time.LocalDate; import java.util.*; import java.util.concurrent.TimeoutException; import java.util.stream.Collectors; @@ -123,10 +126,108 @@ 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); - glassOptimizeMapper.addSimulation(object); - glassOptimizeMapper.addratioResult(object); - glassOptimizeMapper.addratioProjectResult(object); + + 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) { @@ -137,12 +238,12 @@ //浼樺寲璁剧疆淇濆瓨 - public Boolean optimizeParmsSave(Map<String, Object> object) { + public Boolean optimizeParmsSave(Map<String, Object> object,String username) { try { ObjectMapper mapper = new ObjectMapper(); String jsonString = mapper.writeValueAsString(object); - glassOptimizeMapper.optimizeParmsSave(jsonString); + glassOptimizeMapper.optimizeParmsSave(jsonString,username); return true; } catch (Exception e) { e.printStackTrace(); @@ -153,11 +254,32 @@ //浼樺寲璋冩暣缁撴灉淇濆瓨 - public Boolean saveOptimizeResult(Map<String, Object> object) { + 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 jsonString = mapper.writeValueAsString(object); - glassOptimizeMapper.optimizeResultSave(jsonString); + 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(); @@ -189,14 +311,13 @@ public Map<String, Object> projectInfoSv(String projectNo) { Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNo); Map<String, Object> map = new HashMap<>(); - if(Integer.parseInt(stringObjectMap.get("state").toString())<10){ - map.put("data", glassOptimizeMapper.firstOptimization(projectNo)); - map.put("grindingTrimming", glassOptimizeMapper.getGrindingTrimming()); - }else if(stringObjectMap.get("state").equals(10)){ + 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("data", glassOptimizeMapper.analogComputationOptimization(projectNo)); + map.put("optimizeState", Integer.parseInt(stringObjectMap.get("optimize_state").toString())); + map.put("data", glassOptimizeMapper.firstOptimization(projectNo)); map.put("grindingTrimming", glassOptimizeMapper.getGrindingTrimming()); } return map; @@ -214,16 +335,7 @@ public Map<String, Object> materialStoreSv(String thickness, String model, String projectNumber,Integer type) { Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNumber); Map<String, Object> map = new HashMap<>(); - if(Integer.parseInt(stringObjectMap.get("state").toString())<10){ - 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()); - }else if(Integer.parseInt(stringObjectMap.get("state").toString())==10){ + if(Integer.parseInt(stringObjectMap.get("optimize_state").toString())==0){ if(type==1){ map.put("data", glassOptimizeMapper.materialStoreMp(thickness,model)); }else if(type==2){ @@ -278,20 +390,21 @@ } //淇敼鎺掔増鐘舵�� - public Boolean updateProjectState(String projectNumber, Integer state, Integer code) { + public Boolean updateProjectState(String projectNumber, Integer state,Integer states, Integer code) { if (!projectNumber.isEmpty()) { //鎾ら攢妯℃嫙璁$畻 if(code==1){ glassOptimizeMapper.deleteOptimizeHeatDetail(projectNumber); glassOptimizeMapper.deleteOptimizeHeatLayout(projectNumber); - glassOptimizeMapper.updateProjectStateMp(projectNumber, state); + glassOptimizeMapper.updateProjectTemperingStateMp(projectNumber, states); } //鎾ら攢浼樺寲鎺掔増 else if(code==2){ - glassOptimizeMapper.deleteOptimizeHeatDetail(projectNumber); - glassOptimizeMapper.deleteOptimizeHeatDetail(projectNumber); - glassOptimizeMapper.deleteOptimizeHeatLayout(projectNumber); - glassOptimizeMapper.updateProjectStateMp(projectNumber, state); + glassOptimizeMapper.deleteOptimizeDetail(projectNumber); + glassOptimizeMapper.deleteOptimizeLayout(projectNumber); + glassOptimizeMapper.deleteOptimizeProjectFile(projectNumber); + glassOptimizeMapper.updateOptimizeUse(projectNumber); + glassOptimizeMapper.updateProjectOptimizeStateMp(projectNumber, states); } //鍏佽鐢熶骇 else if(code==3){ @@ -314,11 +427,15 @@ //鍒犻櫎宸ョ▼ public boolean deleteProject(String projectNumber,Integer type) { Map<String, Object> stringObjectMap = glassOptimizeMapper.selectProjectCount(projectNumber); - if(stringObjectMap.get("state").equals(10)){ + if(stringObjectMap.get("tempering_state").equals(1)){ glassOptimizeMapper.deleteOptimizeHeatDetail(projectNumber); glassOptimizeMapper.deleteOptimizeHeatLayout(projectNumber); - }else if(stringObjectMap.get("state").equals(20)){ + } + 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); } -- Gitblit v1.8.0