From 00952e11d9c2f7be5277a4d752cd5dd0796301cd Mon Sep 17 00:00:00 2001
From: zss <zss@example.com>
Date: 星期四, 18 四月 2024 17:57:39 +0800
Subject: [PATCH] 资质明细修改+检测项目统计

---
 cnas-server/src/main/java/com/yuanchu/mom/service/CertificationService.java          |    3 -
 cnas-server/src/main/java/com/yuanchu/mom/controller/CertificationController.java    |   10 +--
 cnas-server/src/main/resources/mapper/CertificationMapper.xml                        |    5 +
 cnas-server/src/main/java/com/yuanchu/mom/service/impl/CertificationServiceImpl.java |    8 --
 cnas-server/src/main/java/com/yuanchu/mom/pojo/Certification.java                    |    5 +
 inspect-server/src/main/java/com/yuanchu/mom/service/impl/ReportServiceImpl.java     |   94 +++++++++++++++++++++++-------
 6 files changed, 82 insertions(+), 43 deletions(-)

diff --git a/cnas-server/src/main/java/com/yuanchu/mom/controller/CertificationController.java b/cnas-server/src/main/java/com/yuanchu/mom/controller/CertificationController.java
index e994f2c..0cb47fe 100644
--- a/cnas-server/src/main/java/com/yuanchu/mom/controller/CertificationController.java
+++ b/cnas-server/src/main/java/com/yuanchu/mom/controller/CertificationController.java
@@ -1,6 +1,7 @@
 package com.yuanchu.mom.controller;
 
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.yuanchu.mom.annotation.ValueAuth;
 import com.yuanchu.mom.pojo.Certification;
 import com.yuanchu.mom.pojo.Device;
 import com.yuanchu.mom.service.CertificationService;
@@ -27,6 +28,7 @@
 
     @ApiOperation(value = "鏌ヨ璧勮川鏄庣粏鍒楄〃")
     @PostMapping("/getCertificationDetail")
+    @ValueAuth
     public Result getCertificationDetail(@RequestBody Map<String, Object> data) throws Exception {
         Page page = JackSonUtil.unmarshal(JackSonUtil.marshal(data.get("page")), Page.class);
         Certification certification = JackSonUtil.unmarshal(JackSonUtil.marshal(data.get("entity")), Certification.class);
@@ -41,13 +43,7 @@
 
     @ApiOperation(value = "鍒犻櫎璧勮川鏄庣粏鍒楄〃")
     @PostMapping("/delCertificationDetail")
-    public Result<?> delCertificationDetail(List<Integer> ids) {
+    public Result<?> delCertificationDetail(@RequestBody List<Integer> ids) {
         return Result.success(certificationService.delCertificationDetail(ids));
-    }
-
-    @ApiOperation(value = "闄勪欢涓嬭浇")
-    @PostMapping("/downFile")
-    public Result<?> downFile(Integer id) {
-        return Result.success(certificationService.downFile(id));
     }
 }
diff --git a/cnas-server/src/main/java/com/yuanchu/mom/pojo/Certification.java b/cnas-server/src/main/java/com/yuanchu/mom/pojo/Certification.java
index cf9bedd..cad004f 100644
--- a/cnas-server/src/main/java/com/yuanchu/mom/pojo/Certification.java
+++ b/cnas-server/src/main/java/com/yuanchu/mom/pojo/Certification.java
@@ -32,18 +32,21 @@
 
     @ValueTableShow(5)
     @ApiModelProperty(value = "璧勮川璇存槑")
-    private String explain;
+    private String explanation;
 
     @ValueTableShow(6)
     @ApiModelProperty(value = "棣栨棰佸彂鏃堕棿")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
     private LocalDateTime firstTime;
 
     @ValueTableShow(7)
     @ApiModelProperty(value = "鏈�杩戦鍙戞椂闂�")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
     private LocalDateTime recentlyTime;
 
     @ValueTableShow(8)
     @ApiModelProperty(value = "鍒版湡棰佸彂鏃堕棿")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
     private LocalDateTime expireTime;
 
     @ApiModelProperty(value = "鍒涘缓浜�")
diff --git a/cnas-server/src/main/java/com/yuanchu/mom/service/CertificationService.java b/cnas-server/src/main/java/com/yuanchu/mom/service/CertificationService.java
index c908326..826758e 100644
--- a/cnas-server/src/main/java/com/yuanchu/mom/service/CertificationService.java
+++ b/cnas-server/src/main/java/com/yuanchu/mom/service/CertificationService.java
@@ -16,7 +16,4 @@
 
     //鍒犻櫎璧勮川鏄庣粏鍒楄〃
     int delCertificationDetail(List<Integer> ids);
-
-    //闄勪欢涓嬭浇
-    String downFile(Integer id);
 }
diff --git a/cnas-server/src/main/java/com/yuanchu/mom/service/impl/CertificationServiceImpl.java b/cnas-server/src/main/java/com/yuanchu/mom/service/impl/CertificationServiceImpl.java
index 7c74ac1..8336cb3 100644
--- a/cnas-server/src/main/java/com/yuanchu/mom/service/impl/CertificationServiceImpl.java
+++ b/cnas-server/src/main/java/com/yuanchu/mom/service/impl/CertificationServiceImpl.java
@@ -13,6 +13,7 @@
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import java.time.LocalDateTime;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
@@ -30,8 +31,6 @@
     public Map<String, Object> getCertificationDetail(Page page, Certification certification) {
         Map<String, Object> map = new HashMap<>();
         map.put("head", PrintChina.printChina(Certification.class));
-        Map<String, Integer> map1 = getLook.selectPowerByMethodAndUserId("getCertificationDetail");
-        if (map1.get("look") == 1) certification.setCreateUser(map1.get("userId"));
         map.put("body", certificationMapper.getCertificationDetail(page, QueryWrappers.queryWrappers(certification)));
         return map;
     }
@@ -48,9 +47,4 @@
         return certificationMapper.deleteBatchIds(ids);
     }
 
-    //闄勪欢涓嬭浇
-    @Override
-    public String downFile(Integer id) {
-        return certificationMapper.selectById(id).getFileUrl();
-    }
 }
diff --git a/cnas-server/src/main/resources/mapper/CertificationMapper.xml b/cnas-server/src/main/resources/mapper/CertificationMapper.xml
index 55ae44b..2a355de 100644
--- a/cnas-server/src/main/resources/mapper/CertificationMapper.xml
+++ b/cnas-server/src/main/resources/mapper/CertificationMapper.xml
@@ -7,13 +7,14 @@
         c.name,
         c.code,
         organization,
-        `explain`,
+        explanation,
         first_time,
         recently_time,
         expire_time,
         u1.name create_user_name,
         c.create_time,
-        now()>expire_time?0:1 as state,
+        case when now()>expire_time then 0
+        else 1 end as state,
         image_url,
         file_url
         from certification c
diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/ReportServiceImpl.java b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/ReportServiceImpl.java
index c044f08..e90142f 100644
--- a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/ReportServiceImpl.java
+++ b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/ReportServiceImpl.java
@@ -45,9 +45,8 @@
         map.put("RECEIVE", receive);
         //鏄ㄦ棩浠诲姟鎺ユ敹
         Long received = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY"));
-        received = received == 0 ? 1 : received;
         //姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ
-        BigDecimal ratio = new BigDecimal(receive - received).divide(new BigDecimal(received), 2, BigDecimal.ROUND_HALF_UP);
+        BigDecimal ratio = new BigDecimal(receive - received).divide(new BigDecimal(received == 0 ? 1 : received), 2, BigDecimal.ROUND_HALF_UP);
         map.put("RECEIVE_RATIO", ratio);
 
         /*浠诲姟宸插畬鎴�*/
@@ -56,9 +55,8 @@
         map.put("FINISHE", finishe);
         //鏄ㄦ棩浠诲姟瀹屾垚
         Long finished = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 4).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY"));
-        finished = finished == 0 ? 1 : finished;
         //浠诲姟瀹屾垚姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ
-        BigDecimal finishedRatio = new BigDecimal(finishe - finished).divide(new BigDecimal(finished), 2, BigDecimal.ROUND_HALF_UP);
+        BigDecimal finishedRatio = new BigDecimal(finishe - finished).divide(new BigDecimal(finished == 0 ? 1 : finished), 2, BigDecimal.ROUND_HALF_UP);
         map.put("FINISHE_RATIO", finishedRatio);
 
         /*浠诲姟鍓╀綑*/
@@ -67,9 +65,8 @@
         map.put("SURPLUS", surplus);
         //鏄ㄦ棩浠诲姟鍓╀綑
         long surplused = received - finished;
-        surplused = surplused == 0 ? 1 : surplused;
         //鍓╀綑姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ
-        BigDecimal surplusRatio = new BigDecimal(surplus - surplused).divide(new BigDecimal(surplused), 2, BigDecimal.ROUND_HALF_UP);
+        BigDecimal surplusRatio = new BigDecimal(surplus - surplused).divide(new BigDecimal(surplused == 0 ? 1 : surplused), 2, BigDecimal.ROUND_HALF_UP);
         map.put("SURPLUS_RATIO", surplusRatio);
 
         /*妫�娴嬭垂鐢�*/
@@ -93,9 +90,8 @@
         for (CostStatisticsDto record : dtoIPage.getRecords()) {
             priced.add(record.getPrice());
         }
-        priced = priced.compareTo(BigDecimal.ZERO) == 0 ? BigDecimal.ONE : priced;
         //姣斾緥=(浠婃棩-鏄ㄦ棩)/鏄ㄦ棩
-        BigDecimal priceRatio = (price.subtract(priced)).divide(priced, 2, BigDecimal.ROUND_HALF_UP);
+        BigDecimal priceRatio = (price.subtract(priced)).divide(priced.compareTo(BigDecimal.ZERO) == 0 ? BigDecimal.ONE : priced, 2, BigDecimal.ROUND_HALF_UP);
         map.put("PRICE_RATIO", priceRatio);
 
         /*妫�娴嬪伐鏃�*/
@@ -110,21 +106,21 @@
         for (CostStatisticsDto record : dtoIPage.getRecords()) {
             costed += record.getCost();
         }
-        costed = costed == 0 ? 1 : costed;
         //姣斾緥=(浠婃棩-鏄ㄦ棩)/鏄ㄦ棩
-        BigDecimal costRatio = new BigDecimal(cost - costed).divide(new BigDecimal(costed), 2, BigDecimal.ROUND_HALF_UP);
+        BigDecimal costRatio = new BigDecimal(cost - costed).divide(new BigDecimal(costed == 0 ? 1 : costed), 2, BigDecimal.ROUND_HALF_UP);
         map.put("COST_RATIO", costRatio);
 
 
         /*妫�娴嬩汉鍛�*/
         //浠婃棩妫�娴嬩汉鍛�
-        Long person = insProductUserMapper.selectCount(Wrappers.<InsProductUser>lambdaQuery().apply("DATE(create_time) = CURDATE()"));
+        List<InsProductUser> insProductUsers = insProductUserMapper.selectList(Wrappers.<InsProductUser>lambdaQuery().apply("DATE(create_time) = CURDATE()"));
+        long person = insProductUsers.stream().map(InsProductUser::getCreateUser).distinct().count();
         map.put("PERSON", person);
         //鏄ㄦ棩妫�娴嬩汉鍛�
-        Long persons = insProductUserMapper.selectCount(Wrappers.<InsProductUser>lambdaQuery().apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY"));
-        persons = persons == 0 ? 1 : persons;
+        List<InsProductUser> insProductUserss = insProductUserMapper.selectList(Wrappers.<InsProductUser>lambdaQuery().apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY"));
+        long persons = insProductUserss.stream().map(InsProductUser::getCreateUser).distinct().count();
         //姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ
-        BigDecimal personRatio = new BigDecimal(person - persons).divide(new BigDecimal(persons), 2, BigDecimal.ROUND_HALF_UP);
+        BigDecimal personRatio = new BigDecimal(person - persons).divide(new BigDecimal(persons == 0 ? 1 : persons), 2, BigDecimal.ROUND_HALF_UP);
         map.put("PERSON_RATIO", personRatio);
 
         /*杩戝崄鏃ヤ换鍔℃帴鏀堕噺涓庡畬鎴愰噺*/
@@ -151,12 +147,64 @@
         /*椤圭洰鎺ユ敹*/
         //浠婃棩椤圭洰鎺ユ敹閲�
         Long receive = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).apply("DATE(create_time) = CURDATE()"));
+        map.put("RECEVICE", receive);
+        //鏄ㄦ棩椤圭洰鎺ユ敹閲�
+        Long received = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY"));
+        //姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ
+        BigDecimal ratio = new BigDecimal(receive - received).divide(new BigDecimal(received == 0 ? 1 : received), 2, BigDecimal.ROUND_HALF_UP);
+        map.put("RECEIVE_RATIO", ratio);
+
         /*椤圭洰瀹屾垚*/
+        //浠婃棩椤圭洰瀹屾垚閲�
+        Long finishe = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).isNotNull(InsProduct::getInsResult).apply("DATE(create_time) = CURDATE()"));
+        map.put("FINISHE", finishe);
+        //鏄ㄦ棩椤圭洰瀹屾垚閲�
+        Long finished = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).isNotNull(InsProduct::getInsResult).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY"));
+        //浠诲姟瀹屾垚姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ
+        BigDecimal finishedRatio = new BigDecimal(finishe - finished).divide(new BigDecimal(finished == 0 ? 1 : finished), 2, BigDecimal.ROUND_HALF_UP);
+        map.put("FINISHE_RATIO", finishedRatio);
+
         /*椤圭洰鍓╀綑*/
+        //浠婃棩椤圭洰鍓╀綑閲�
+        long surplus = receive - finishe;
+        map.put("SURPLUS", surplus);
+        //鏄ㄦ棩椤圭洰鍓╀綑
+        long surplused = received - finished;
+        //鍓╀綑姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ
+        BigDecimal surplusRatio = new BigDecimal(surplus - surplused).divide(new BigDecimal(surplused == 0 ? 1 : surplused), 2, BigDecimal.ROUND_HALF_UP);
+        map.put("SURPLUS_RATIO", surplusRatio);
+
         /*浠婃棩椤圭洰鍚堟牸鐜�*/
+        //浠婃棩瀹屾垚閲忎腑鐨勫悎鏍奸噺/浠婃棩瀹屾垚閲�
+        Long accept = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).eq(InsProduct::getInsResult,1).apply("DATE(create_time) = CURDATE()"));
+        BigDecimal acceptRate = new BigDecimal(accept).divide(new BigDecimal(finishe == 0 ? 1 : finishe), 2, BigDecimal.ROUND_HALF_UP);
+        map.put("ACCEPT_RATE_TODAY", acceptRate);
+
         /*浠婃棩椤圭洰瀹屾垚鐜�*/
+        //浠婃棩瀹屾垚閲�/浠婃棩鎺ユ敹閲�
+        BigDecimal finishRate = new BigDecimal(finishe).divide(new BigDecimal(receive == 0 ? 1 : receive), 2, BigDecimal.ROUND_HALF_UP);
+        map.put("FINISH_RATE_TODAY", finishRate);
+
         /*浠婃棩椤圭洰寤舵湡鐜�*/
+        //浠婃棩椤圭洰鍓╀綑/浠婃棩椤圭洰鎺ユ敹閲�
+        BigDecimal delayRate = new BigDecimal(surplus).divide(new BigDecimal(received == 0 ? 1 : received), 2, BigDecimal.ROUND_HALF_UP);
+        map.put("DELAY_RATE_TODAY", delayRate);
+
         /*杩戝崄鏃ョ殑椤圭洰鎺ユ敹閲忎笌瀹屾垚閲�*/
+        //鑾峰彇杩戝崄鏃ョ殑妯潗鏍�
+        LocalDate currentDate = LocalDate.now();
+        List<LocalDate> lastTenDays = new ArrayList<>();
+        List<Long> receTenDays = new ArrayList<>();
+        List<Long> finTenDays = new ArrayList<>();
+        for (int i = 9; i > -1; i--) {
+            lastTenDays.add(currentDate.minusDays(i));
+            receTenDays.add(insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY")));
+            finTenDays.add(insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).isNotNull(InsProduct::getInsResult).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY")));
+        }
+        map.put("DAYS", lastTenDays);
+        map.put("RECETENDAYS", receTenDays);
+        map.put("FINISHTENDAYS", finTenDays);
+
         return map;
     }
 
@@ -164,25 +212,25 @@
     @Override
     public Map<String, Object> calendarWorkByWeek() {
         Map<String, Object> map = new HashMap<>();
-        List<Integer> insState=new ArrayList<>();
+        List<Integer> insState = new ArrayList<>();
         insState.add(0);
         insState.add(1);
         /*鑾峰彇鍚庝竴鍛ㄦ棩鏈�*/
         LocalDate currentDate = LocalDate.now();
         List<LocalDate> weekDays = new ArrayList<>();
-        for (int i = 0; i <7; i++) {
+        for (int i = 0; i < 7; i++) {
             weekDays.add(currentDate.plusDays(i));
             //鏌ヨ褰撳ぉ闇�瑕佹娴嬬殑濮旀墭璁㈠崟
-            List<InsOrder> insOrders = insOrderMapper.selectList(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 1).in(InsOrder::getInsState, insState).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY"));
-            List<Map<String,Object>> works = insOrders.stream().map(insOrder -> {
+            List<InsOrder> insOrders = insOrderMapper.selectList(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 1).in(InsOrder::getInsState, insState).apply("DATE(create_time) = CURDATE() + INTERVAL " + i + " DAY"));
+            List<Map<String, Object>> works = insOrders.stream().map(insOrder -> {
                 HashMap<String, Object> hashMap = new HashMap<>();
-                hashMap.put("text","濮旀墭璁㈠崟" + insOrder.getEntrustCode() + "妫�娴�");
-                hashMap.put("type",insOrder.getType());
+                hashMap.put("text", "濮旀墭璁㈠崟" + insOrder.getEntrustCode() + "妫�娴�");
+                hashMap.put("type", insOrder.getType());
                 User user = userMapper.selectById(insOrder.getCreateUser());
                 hashMap.put("name", user.getName());
-                return  hashMap;
+                return hashMap;
             }).collect(Collectors.toList());
-            map.put("work"+i, works);
+            map.put("work" + i, works);
         }
         map.put("weekDays", weekDays);
         return map;
@@ -208,6 +256,6 @@
         LocalDate localDate = LocalDate.parse(date, DateTimeFormatter.ofPattern("yyyy-MM-dd"));
         LocalDateTime startTime = localDate.atStartOfDay();
         LocalDateTime endTime = localDate.plusDays(1).atStartOfDay().minusSeconds(1);
-        return scheduleMapper.selectList(Wrappers.<Schedule>lambdaQuery().eq(Schedule::getUserId,userId).between(Schedule::getScheduleTime,startTime,endTime));
+        return scheduleMapper.selectList(Wrappers.<Schedule>lambdaQuery().eq(Schedule::getUserId, userId).between(Schedule::getScheduleTime, startTime, endTime));
     }
 }

--
Gitblit v1.9.3