From ba11a11662a027e89f3e86d063b3234aeeb76d83 Mon Sep 17 00:00:00 2001
From: lyh <925863403@qq.com>
Date: 星期五, 22 八月 2025 17:22:56 +0800
Subject: [PATCH] 设备管理首页

---
 lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceOrderServiceImpl.java |  125 ++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 120 insertions(+), 5 deletions(-)

diff --git a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceOrderServiceImpl.java b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceOrderServiceImpl.java
index 641593a..f7736ea 100644
--- a/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceOrderServiceImpl.java
+++ b/lxzn-module-eam/src/main/java/org/jeecg/modules/eam/service/impl/EamThirdMaintenanceOrderServiceImpl.java
@@ -26,6 +26,8 @@
 import org.jeecg.modules.eam.constant.*;
 import org.jeecg.modules.eam.dto.EamThirdMaintenanceOrderExport;
 import org.jeecg.modules.eam.dto.EamThirdMaintenanceOrderExport;
+import org.jeecg.modules.eam.dto.EamThirdMaintenanceOrderExportYj;
+import org.jeecg.modules.eam.dto.EchartsDto;
 import org.jeecg.modules.eam.entity.*;
 import org.jeecg.modules.eam.mapper.EamThirdMaintenanceOrderMapper;
 import org.jeecg.modules.eam.request.EamThirdMaintenanceBaseResponse;
@@ -53,6 +55,7 @@
 
 import javax.annotation.Resource;
 import java.time.LocalDate;
+import java.time.format.DateTimeFormatter;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -598,7 +601,7 @@
      * @return
      */
     @Override
-    public List<EamThirdMaintenanceOrderExport> export(String ids){
+    public List<EamThirdMaintenanceOrderExportYj> export(String ids){
         QueryWrapper<EamThirdMaintenanceOrderExport> queryWrapper = new QueryWrapper<>();
         queryWrapper.eq("wmo.del_flag",CommonConstant.DEL_FLAG_0.toString());
         queryWrapper.eq("wmo.maintenance_status",SecondMaintenanceStatusEnum.COMPLETE.name());
@@ -631,15 +634,23 @@
             queryWrapper.orderByDesc("wmo.create_time");
         }
         List<EamThirdMaintenanceOrderExport> eamThirdMaintenanceOrderExports=this.baseMapper.queryList(queryWrapper);
+        List<EamThirdMaintenanceOrderExportYj> eamThirdMaintenanceOrderExportYjs=new  ArrayList<>();
+        if (!eamThirdMaintenanceOrderExports.isEmpty()){
+            for (EamThirdMaintenanceOrderExport eamThirdMaintenanceOrderExport:eamThirdMaintenanceOrderExports) {
+                EamThirdMaintenanceOrderExportYj eamThirdMaintenanceOrderExportYj = new EamThirdMaintenanceOrderExportYj();
+                BeanUtils.copyProperties(eamThirdMaintenanceOrderExport, eamThirdMaintenanceOrderExportYj);
+                eamThirdMaintenanceOrderExportYjs.add(eamThirdMaintenanceOrderExportYj);
+            }
+        }
         //濉厖瀵瑰簲淇悊鏇存崲澶囦欢鏄庣粏
-        eamThirdMaintenanceOrderExports.forEach(eamThirdMaintenanceOrderExport->{
+        eamThirdMaintenanceOrderExportYjs.forEach(eamThirdMaintenanceOrderExportYj->{
             List<EamThirdMaintenanceSpare> eamThirdMaintenanceSpares=eamThirdMaintenanceSpareService.list(
-                    new QueryWrapper<EamThirdMaintenanceSpare>().eq("order_Id",eamThirdMaintenanceOrderExport.getId()));
+                    new QueryWrapper<EamThirdMaintenanceSpare>().eq("order_Id",eamThirdMaintenanceOrderExportYj.getId()));
             if (!eamThirdMaintenanceSpares.isEmpty()){
-                eamThirdMaintenanceOrderExport.setEamThirdMaintenanceSpareList(eamThirdMaintenanceSpares);
+                eamThirdMaintenanceOrderExportYj.setEamThirdMaintenanceSpareList(eamThirdMaintenanceSpares);
             }
         });
-        return eamThirdMaintenanceOrderExports;
+        return eamThirdMaintenanceOrderExportYjs;
     }
 
     /**
@@ -691,6 +702,110 @@
     }
 
     /**
+     * 璁惧绠$悊棣栭〉-涓変繚璁″垝
+     * @return
+     * */
+    @Override
+    public List<EchartsDto> selectList() {
+        List<EchartsDto> echartsDtos = new ArrayList<>();
+
+        // 鐢ㄦ埛鏁版嵁鏉冮檺妫�鏌�
+        LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();
+        if (sysUser == null) {
+            return echartsDtos; // 杩斿洖绌哄垪琛ㄨ�岄潪null
+        }
+
+        QueryWrapper<EamThirdMaintenanceOrder> queryWrapper = new QueryWrapper<>();
+
+        // 璁惧杩囨护閫昏緫
+        if (StringUtils.isNotBlank(sysUser.getEamEquipmentIds())) {
+            List<String> equipArr = Arrays.asList(sysUser.getEamEquipmentIds().split(","));
+            queryWrapper.in("e.equipment_code", equipArr);
+        } else {
+            List<BaseFactoryUser> baseFactoryUserList = baseFactoryUserService
+                    .list(new LambdaQueryWrapper<BaseFactoryUser>()
+                            .eq(BaseFactoryUser::getUserId, sysUser.getId()));
+
+            if (CollectionUtils.isEmpty(baseFactoryUserList)) {
+                return echartsDtos; // 杩斿洖绌哄垪琛ㄨ�岄潪null
+            }
+
+            Set<String> factoryIds = baseFactoryUserList.stream()
+                    .map(BaseFactoryUser::getFactoryId)
+                    .collect(Collectors.toSet());
+
+            Set<String> factoryCodes = baseFactoryService.listByIds(factoryIds)
+                    .stream()
+                    .map(BaseFactory::getOrgCode)
+                    .collect(Collectors.toSet());
+
+            queryWrapper.in("e.factory_org_code", factoryCodes);
+        }
+
+        // 鑾峰彇褰撳墠骞存湀鍜屼笅涓や釜鏈堢殑骞存湀瀛楃涓�
+        String currentYearMonth = LocalDate.now().format(DateTimeFormatter.ofPattern("yyyy-MM"));
+        String nextMonth = LocalDate.now().plusMonths(1).format(DateTimeFormatter.ofPattern("yyyy-MM"));
+        String nextNextMonth = LocalDate.now().plusMonths(2).format(DateTimeFormatter.ofPattern("yyyy-MM"));
+
+        // 浠庡瓧鍏歌〃鑾峰彇閰嶇疆鍊�
+        String bysbjh = sysDictService.queryDictTextByKey("eam_home_third_number_bysbzs", "bysbzs");
+        String bywc = sysDictService.queryDictTextByKey("eam_home_third_number_bwc", "bwc");
+        String xysb = sysDictService.queryDictTextByKey("eam_home_third_number_xysb", "xysb");
+        String xxysb = sysDictService.queryDictTextByKey("eam_home_third_number_xxysb", "xxysb");
+
+        // 鏈湀涓変繚璁″垝鎬绘暟
+        if ("0".equals(bysbjh)) {
+            List<EamThirdMaintenanceOrder> currentMonthOrders = this.baseMapper.queryAsList(
+                    queryWrapper.clone().like("maintenance_date", currentYearMonth)
+            );
+            echartsDtos.add(new EchartsDto("bysbzs", "鏈湀涓変繚璁″垝鎬绘暟",
+                    String.valueOf(currentMonthOrders.size()), null, null));
+        } else {
+            echartsDtos.add(new EchartsDto("bysbzs", "鏈湀涓変繚璁″垝鎬绘暟",
+                    bysbjh, null, null));
+        }
+
+        // 鏈湀瀹屾垚
+        if ("0".equals(bywc)) {
+            List<EamThirdMaintenanceOrder> currentMonthCompleted = this.baseMapper.queryAsList(
+                    queryWrapper.clone().like("maintenance_date", currentYearMonth)
+                            .eq("maintenance_status", ThirdMaintenanceStatusEnum.COMPLETE.name())
+            );
+            echartsDtos.add(new EchartsDto("bwc", "鏈湀瀹屾垚",
+                    String.valueOf(currentMonthCompleted.size()), null, null));
+        } else {
+            echartsDtos.add(new EchartsDto("bwc", "鏈湀瀹屾垚",
+                    bywc, null, null));
+        }
+
+        // 涓嬫湀涓変繚璁″垝
+        if ("0".equals(xysb)) {
+            List<EamThirdMaintenanceOrder> nextMonthOrders = this.baseMapper.queryAsList(
+                    queryWrapper.clone().like("maintenance_date", nextMonth)
+            );
+            echartsDtos.add(new EchartsDto("xysb", "涓嬫湀涓変繚璁″垝",
+                    String.valueOf(nextMonthOrders.size()), null, null));
+        } else {
+            echartsDtos.add(new EchartsDto("xysb", "涓嬫湀涓変繚璁″垝",
+                    xysb, null, null));
+        }
+
+        // 涓嬩笅鏈堜笁淇濊鍒�
+        if ("0".equals(xxysb)) {
+            List<EamThirdMaintenanceOrder> nextNextMonthOrders = this.baseMapper.queryAsList(
+                    queryWrapper.clone().like("maintenance_date", nextNextMonth)
+            );
+            echartsDtos.add(new EchartsDto("xxysb", "涓嬩笅鏈堜笁淇濊鍒�",
+                    String.valueOf(nextNextMonthOrders.size()), null, null));
+        } else {
+            echartsDtos.add(new EchartsDto("xxysb", "涓嬩笅鏈堜笁淇濊鍒�",
+                    xxysb, null, null));
+        }
+
+        return echartsDtos;
+    }
+
+    /**
      * 鏇存柊宸ュ崟鐘舵��
      */
     private void updateOrderStatus(Result result, EamThirdMaintenanceRequest request, EamThirdMaintenanceOrder order, LoginUser user) {

--
Gitblit v1.9.3