From 14681dfe7052cb76eefcc0c17d0a0d708e1ac9dd Mon Sep 17 00:00:00 2001
From: zhuguifei <zhuguifei@zhuguifeideiMac.local>
Date: 星期二, 13 五月 2025 16:31:14 +0800
Subject: [PATCH] 完成移动端基本功能

---
 eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/service/impl/EimsInspectStServiceImpl.java |   71 +++++++++++++++++++++++++++++++++++
 1 files changed, 70 insertions(+), 1 deletions(-)

diff --git a/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/service/impl/EimsInspectStServiceImpl.java b/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/service/impl/EimsInspectStServiceImpl.java
index 6db24c0..199219d 100644
--- a/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/service/impl/EimsInspectStServiceImpl.java
+++ b/eims/ruoyi-modules/lb-eims/src/main/java/org/dromara/eims/service/impl/EimsInspectStServiceImpl.java
@@ -10,8 +10,10 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import lombok.RequiredArgsConstructor;
+import org.dromara.eims.domain.EimsEqu;
 import org.dromara.eims.domain.EimsInspectRecord;
 import org.dromara.eims.domain.vo.EimsInspectRecordVo;
+import org.dromara.eims.mapper.EimsEquMapper;
 import org.dromara.eims.mapper.EimsInspectRecordMapper;
 import org.springframework.stereotype.Service;
 import org.dromara.eims.domain.bo.EimsInspectStBo;
@@ -39,6 +41,7 @@
 public class EimsInspectStServiceImpl implements IEimsInspectStService {
 
     private final EimsInspectStMapper baseMapper;
+    private final EimsEquMapper equMapper;
     private final EimsInspectRecordMapper recordMapper;
 
     /**
@@ -49,7 +52,73 @@
      */
     @Override
     public EimsInspectStVo queryById(Long id){
-        return baseMapper.selectVoById(id);
+        EimsInspectStVo stVo = baseMapper.selectVoById(id);
+        if(stVo!=null&&stVo.getEquId()!=null){
+            EimsEqu eimsEqu = equMapper.selectById(stVo.getEquId());
+            stVo.setEquName(eimsEqu.getEquName());
+            stVo.setAssetNo(eimsEqu.getAssetNo());
+        }
+        // fillStDataSingle(stVo);
+        return stVo;
+    }
+
+    @Override
+    public EimsInspectStVo queryByStId(String stId) {
+        QueryWrapper<EimsInspectSt> queryWrapper = new QueryWrapper<>();
+        queryWrapper.eq("st_id", stId);
+        EimsInspectStVo stVo = baseMapper.selectVoOne(queryWrapper);
+        if(stVo!=null&&stVo.getEquId()!=null){
+            EimsEqu eimsEqu = equMapper.selectById(stVo.getEquId());
+            stVo.setEquName(eimsEqu.getEquName());
+            stVo.setAssetNo(eimsEqu.getAssetNo());
+        }
+        // fillStDataSingle(stVo);
+        return stVo;
+    }
+
+
+    /**
+     *
+     * @param stVo type Day-鏃ヨ鍥� Month-鏈堣鍥�
+     * @param
+     */
+    private void fillStDataSingle(EimsInspectStVo stVo) {
+
+            LambdaQueryWrapper<EimsInspectRecord> recordLqw = Wrappers.lambdaQuery();
+            recordLqw.eq(EimsInspectRecord::getEquId, stVo.getEquId());
+            LocalDate planTime = stVo.getPlanTime().toInstant().atZone(ZoneId.systemDefault()).toLocalDate();
+            // 鏈堣鍥炬煡璇㈣寖鍥�
+            LocalDate startOfMonth = planTime.with(TemporalAdjusters.firstDayOfMonth());
+            LocalDate endOfMonth = planTime.with(TemporalAdjusters.lastDayOfMonth());
+
+            // 鏃ヨ鍥炬煡璇㈣寖鍥�
+            if(stVo.getType().equals("Day")){
+                recordLqw.between(EimsInspectRecord::getPlanTime, planTime, planTime);
+            }else {
+                //  鏈堣鍥炬煡璇㈣寖鍥�
+                recordLqw.between(EimsInspectRecord::getPlanTime, startOfMonth, endOfMonth);
+            }
+
+
+            // 鎵ц鏌ヨ
+            List<EimsInspectRecordVo> recordList = recordMapper.selectVoList(recordLqw);
+            // TODO 鏍规嵁瀛楀吀eims_inspect_status
+            Map<String, Long> cMap = recordList.stream()
+                .filter(order -> List.of("0", "1").contains(order.getStatus()))
+                .collect(Collectors.groupingBy(EimsInspectRecordVo::getStatus, Collectors.counting()));
+            // TODO 鏍规嵁瀛楀吀eims_inspect_result
+            Map<String, Long> rMap = recordList.stream()
+                .filter(order ->order.getInspResult()!=null && List.of("1", "2").contains(order.getInspResult()))
+                .collect(Collectors.groupingBy(EimsInspectRecordVo::getInspResult, Collectors.counting()));
+
+            stVo.setRecordCount(recordList.size());
+            stVo.setUnCheckCount(cMap.getOrDefault("0", 0L).intValue());
+            stVo.setCheckCount(cMap.getOrDefault("1", 0L).intValue());
+
+            stVo.setNormalNum(rMap.getOrDefault("1", 0L).intValue());
+            stVo.setAbNormalNum(rMap.getOrDefault("2", 0L).intValue());
+
+
     }
 
     /**

--
Gitblit v1.9.3