From 5a0dbf5c84f677c9f20252ccc63221dc7ba68d6c Mon Sep 17 00:00:00 2001
From: Lius <Lius2225@163.com>
Date: 星期四, 15 五月 2025 08:48:07 +0800
Subject: [PATCH] 修改项

---
 lxzn-module-mdc/src/main/java/org/jeecg/modules/screen/service/impl/MdcLargeScreenServiceImpl.java |   44 +++++++++++++++++++++++++++-----------------
 1 files changed, 27 insertions(+), 17 deletions(-)

diff --git a/lxzn-module-mdc/src/main/java/org/jeecg/modules/screen/service/impl/MdcLargeScreenServiceImpl.java b/lxzn-module-mdc/src/main/java/org/jeecg/modules/screen/service/impl/MdcLargeScreenServiceImpl.java
index 175df00..98d6757 100644
--- a/lxzn-module-mdc/src/main/java/org/jeecg/modules/screen/service/impl/MdcLargeScreenServiceImpl.java
+++ b/lxzn-module-mdc/src/main/java/org/jeecg/modules/screen/service/impl/MdcLargeScreenServiceImpl.java
@@ -3,8 +3,10 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import org.jeecg.common.constant.CommonConstant;
 import org.jeecg.common.system.vo.DictModel;
+import org.jeecg.modules.mdc.entity.MdcEquipmentDaySummary;
 import org.jeecg.modules.mdc.entity.MdcEquipmentMonitor;
 import org.jeecg.modules.mdc.service.IEquipmentAlarmService;
+import org.jeecg.modules.mdc.service.IMdcEquipmentDaySummaryService;
 import org.jeecg.modules.mdc.service.IMdcEquipmentService;
 import org.jeecg.modules.mdc.service.IMdcEquipmentStatisticalInfoService;
 import org.jeecg.modules.mdc.util.DateUtils;
@@ -18,7 +20,10 @@
 import javax.annotation.Resource;
 import java.math.BigDecimal;
 import java.time.LocalDate;
-import java.util.*;
+import java.util.Date;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
 import java.util.stream.Collectors;
 
 /**
@@ -44,6 +49,9 @@
     @Resource
     private IEquipmentAlarmService equipmentAlarmService;
 
+    @Resource
+    private IMdcEquipmentDaySummaryService mdcEquipmentDaySummaryService;
+
     /**
      * 璁惧鐘舵�佹儏鍐�
      *
@@ -53,6 +61,7 @@
     @Override
     public EquipmentStatusOverview equipmentStatusOverview(String productionId) {
         EquipmentStatusOverview equipmentStatusOverview = new EquipmentStatusOverview();
+        // 璁惧鐘舵��
         List<MdcEquipmentMonitor> equipmentMonitorList = mdcEquipmentService.getEquipmentMonitorList(productionId);
         if (equipmentMonitorList != null && !equipmentMonitorList.isEmpty()) {
             equipmentStatusOverview.setEquipmentCount(equipmentMonitorList.size());
@@ -65,7 +74,7 @@
                                 equipmentStatusOverview.setWaitCount(equipmentStatusOverview.getWaitCount() + 1);
                                 break;
                             case 3:
-                                equipmentStatusOverview.setRunCount(equipmentStatusOverview.getRunCount());
+                                equipmentStatusOverview.setRunCount(equipmentStatusOverview.getRunCount() + 1);
                                 break;
                             case 22:
                                 equipmentStatusOverview.setErrorCount(equipmentStatusOverview.getErrorCount() + 1);
@@ -87,6 +96,12 @@
                     }
                 }
             }
+        }
+        // mes浜ч噺
+        MdcEquipmentDaySummary mdcEquipmentDaySummary = mdcEquipmentDaySummaryService.statisticsQty(productionId);
+        if (mdcEquipmentDaySummary != null) {
+            equipmentStatusOverview.setQualifiedQty(mdcEquipmentDaySummary.getQualifiedQty());
+            equipmentStatusOverview.setPlanQty(mdcEquipmentDaySummary.getPlanQty());
         }
         return equipmentStatusOverview;
     }
@@ -141,9 +156,7 @@
         Map<String, Object> result = new HashMap<>();
 
         // 鑾峰彇瀛愮敓浜у垪琛�
-        List<MdcProduction> mdcProductionList = mdcProductionService.list(
-                new LambdaQueryWrapper<MdcProduction>().eq(MdcProduction::getParentId, productionId)
-        );
+        List<MdcProduction> mdcProductionList = mdcProductionService.list(new LambdaQueryWrapper<MdcProduction>().eq(MdcProduction::getParentId, productionId));
 
         if (mdcProductionList == null || mdcProductionList.isEmpty()) {
             return result;
@@ -152,8 +165,7 @@
         List<String> dateList = DateUtils.getNearWeek();
         result.put("dateList", dateList);
         // 璁$畻姣忎釜宸ユ鐨勫埄鐢ㄧ巼
-        List<UtilizationRateDto> utilizationMonthDtoList = new ArrayList<>();
-        for (MdcProduction mdcProduction : mdcProductionList) {
+        List<UtilizationRateDto> utilizationMonthDtoList = mdcProductionList.stream().map(mdcProduction -> {
             UtilizationRateDto utilizationRateDto = new UtilizationRateDto();
             utilizationRateDto.setProductionId(mdcProduction.getId());
             utilizationRateDto.setProductionName(mdcProduction.getProductionName());
@@ -161,14 +173,13 @@
                     .map(date -> {
                         UtilizationRate utilizationMonth = new UtilizationRate();
                         utilizationMonth.setDate(date);
-                        BigDecimal utilizationRate = mdcEquipmentStatisticalInfoService.computeUtilizationWeek(productionId, date.replaceAll("-", ""));
+                        BigDecimal utilizationRate = mdcEquipmentStatisticalInfoService.computeUtilizationWeek(mdcProduction.getId(), date.replaceAll("-", ""));
                         utilizationMonth.setUtilizationRate(utilizationRate);
                         return utilizationMonth;
-                    })
-                    .collect(Collectors.toList());
+                    }).collect(Collectors.toList());
             utilizationRateDto.setUtilizationRateList(utilizationRates);
-            utilizationMonthDtoList.add(utilizationRateDto);
-        }
+            return utilizationRateDto;
+        }).collect(Collectors.toList());
         //璁$畻鎬诲巶鐨勫埄鐢ㄧ巼
         UtilizationRateDto utilizationRateDto = new UtilizationRateDto();
         utilizationRateDto.setProductionName("鎬诲巶");
@@ -208,14 +219,13 @@
         result.put("productionList", productionList);
 
         String date = LocalDate.now().minusDays(1).toString().replaceAll("-", "");
-        List<UtilizationDayDto> utilizationDayDtos = new ArrayList<>();
-        for (MdcProduction mdcProduction : mdcProductionList) {
+        List<UtilizationDayDto> utilizationDayDtos = mdcProductionList.stream().map(mdcProduction -> {
             UtilizationDayDto utilizationDayDto = new UtilizationDayDto();
             utilizationDayDto.setProductionName(mdcProduction.getProductionName());
-            BigDecimal utilizationRate = mdcEquipmentStatisticalInfoService.computeUtilizationWeekTotal(mdcProduction.getId(), date);
+            BigDecimal utilizationRate = mdcEquipmentStatisticalInfoService.computeUtilizationWeek(mdcProduction.getId(), date);
             utilizationDayDto.setUtilizationRate(utilizationRate);
-            utilizationDayDtos.add(utilizationDayDto);
-        }
+            return utilizationDayDto;
+        }).collect(Collectors.toList());
         result.put("dataList", utilizationDayDtos);
         return result;
     }

--
Gitblit v1.9.3