From bd3916f68a3f8971bfe8c78b0b71e87fba643e11 Mon Sep 17 00:00:00 2001
From: Administrator <1144154118@qq.com>
Date: 星期四, 10 八月 2023 09:24:58 +0800
Subject: [PATCH] 巡检日历及查询优化

---
 ard-work/src/main/java/com/ruoyi/app/patrolplan/domain/param/ArdAppPatrolpointRecordParam.java       |   12 ++++
 ard-work/src/main/resources/mapper/app/ArdAppPatrolplanMapper.xml                                    |    6 +
 ard-work/src/main/java/com/ruoyi/app/patrolplan/service/IArdAppPatrolpointRecordService.java         |    4 +
 ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java |   86 +++++++++++++++++++++++++++-
 ard-work/src/main/java/com/ruoyi/app/patrolplan/controller/ArdAppPatrolplanController.java           |   13 ++++
 5 files changed, 112 insertions(+), 9 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/app/patrolplan/controller/ArdAppPatrolplanController.java b/ard-work/src/main/java/com/ruoyi/app/patrolplan/controller/ArdAppPatrolplanController.java
index 4970d48..5dd4f92 100644
--- a/ard-work/src/main/java/com/ruoyi/app/patrolplan/controller/ArdAppPatrolplanController.java
+++ b/ard-work/src/main/java/com/ruoyi/app/patrolplan/controller/ArdAppPatrolplanController.java
@@ -1,5 +1,6 @@
 package com.ruoyi.app.patrolplan.controller;
 
+import java.text.ParseException;
 import java.util.List;
 import java.util.Map;
 import javax.annotation.Resource;
@@ -13,6 +14,7 @@
 import com.ruoyi.alarmpoints.well.service.IArdAlarmpointsWellService;
 import com.ruoyi.app.patrolplan.domain.ArdAppPatrolpoint;
 import com.ruoyi.app.patrolplan.domain.ArdAppPatrolpointRecord;
+import com.ruoyi.app.patrolplan.domain.param.ArdAppPatrolpointRecordParam;
 import com.ruoyi.app.patrolplan.service.IArdAppPatrolpointRecordService;
 import com.ruoyi.app.patrolplan.service.IArdAppPatrolpointService;
 import com.ruoyi.app.patrolplan.service.IArdAppPatroluserService;
@@ -206,11 +208,20 @@
      * 宸℃鎵撳崱
      */
     @PreAuthorize("@ss.hasPermi('app:appPatrolplan:record')")
-    @Log(title = "app宸℃璁″垝", businessType = BusinessType.UPDATE)
     @ApiOperation("宸℃鎵撳崱")
     @PostMapping("record")
     public Results edit(@RequestBody ArdAppPatrolpointRecord ardAppPatrolpointRecord) {
         return recordService.record(ardAppPatrolpointRecord);
     }
 
+    /**
+     * 宸℃鏃ュ巻
+     */
+    @PreAuthorize("@ss.hasPermi('app:appPatrolplan:recordMonth')")
+    @ApiOperation("宸℃鏃ュ巻")
+    @PostMapping("recordMonth")
+    public Results recordMonth(@RequestBody ArdAppPatrolpointRecordParam ardAppPatrolpointRecordParam) throws ParseException {
+        return recordService.recordMonth(ardAppPatrolpointRecordParam);
+    }
+
 }
diff --git a/ard-work/src/main/java/com/ruoyi/app/patrolplan/domain/param/ArdAppPatrolpointRecordParam.java b/ard-work/src/main/java/com/ruoyi/app/patrolplan/domain/param/ArdAppPatrolpointRecordParam.java
new file mode 100644
index 0000000..0aaf27a
--- /dev/null
+++ b/ard-work/src/main/java/com/ruoyi/app/patrolplan/domain/param/ArdAppPatrolpointRecordParam.java
@@ -0,0 +1,12 @@
+package com.ruoyi.app.patrolplan.domain.param;
+
+import lombok.Data;
+
+@Data
+public class ArdAppPatrolpointRecordParam {
+
+    private String begin;
+    private String end;
+    private String planId;
+    private String cycle;
+}
diff --git a/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/IArdAppPatrolpointRecordService.java b/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/IArdAppPatrolpointRecordService.java
index 9353718..c002cd0 100644
--- a/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/IArdAppPatrolpointRecordService.java
+++ b/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/IArdAppPatrolpointRecordService.java
@@ -1,9 +1,11 @@
 package com.ruoyi.app.patrolplan.service;
 
+import java.text.ParseException;
 import java.util.List;
 import java.util.Map;
 
 import com.ruoyi.app.patrolplan.domain.ArdAppPatrolpointRecord;
+import com.ruoyi.app.patrolplan.domain.param.ArdAppPatrolpointRecordParam;
 import com.ruoyi.utils.result.Results;
 
 /**
@@ -64,5 +66,5 @@
 
     Results record(ArdAppPatrolpointRecord ardAppPatrolpointRecord);
 
-    Results recordMonth(Map<String,Object> map);
+    Results recordMonth(ArdAppPatrolpointRecordParam ardAppPatrolpointRecordParam) throws ParseException;
 }
diff --git a/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java b/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java
index fe68763..226735c 100644
--- a/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java
@@ -1,9 +1,18 @@
 package com.ruoyi.app.patrolplan.service.impl;
 
+import java.text.ParseException;
+import java.text.SimpleDateFormat;
+import java.util.Date;
 import java.util.List;
 import java.util.Map;
 
+import com.alibaba.fastjson2.JSONArray;
+import com.alibaba.fastjson2.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.ruoyi.app.patrolplan.domain.ArdAppPatrolplan;
 import com.ruoyi.app.patrolplan.domain.ArdAppPatrolpointRecordImg;
+import com.ruoyi.app.patrolplan.domain.param.ArdAppPatrolpointRecordParam;
+import com.ruoyi.app.patrolplan.mapper.ArdAppPatrolplanMapper;
 import com.ruoyi.app.patrolplan.mapper.ArdAppPatrolpointRecordImgMapper;
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.uuid.IdUtils;
@@ -15,6 +24,7 @@
 import com.ruoyi.app.patrolplan.service.IArdAppPatrolpointRecordService;
 
 import javax.annotation.Resource;
+import javax.xml.crypto.Data;
 
 /**
  * app宸℃璁″垝璁板綍Service涓氬姟灞傚鐞�
@@ -29,6 +39,9 @@
 
     @Resource
     private ArdAppPatrolpointRecordImgMapper recordImgMapper;
+
+    @Resource
+    private ArdAppPatrolplanMapper patrolplanMapper;
 
     /**
      * 鏌ヨapp宸℃璁″垝璁板綍
@@ -119,10 +132,73 @@
     }
 
     @Override
-    public Results recordMonth(Map<String, Object> map) {
-        String begin = (String) map.get("begin");
-        String end = (String) map.get("end");
-
-        return null;
+    public Results recordMonth(ArdAppPatrolpointRecordParam ardAppPatrolpointRecordParam) throws ParseException {
+        //鑾峰彇鍓嶇鍙傛暟
+        String begin = ardAppPatrolpointRecordParam.getBegin();
+        String end = ardAppPatrolpointRecordParam.getEnd();
+        String planId = ardAppPatrolpointRecordParam.getPlanId();
+        //鏌ヨ璁″垝琛�
+        ArdAppPatrolplan ardAppPatrolplan = patrolplanMapper.selectById(planId);
+        //鏌ヨ鍑烘湁鏁堟墦鍗℃暟鎹�
+        QueryWrapper<ArdAppPatrolpointRecord> queryWrapper = new QueryWrapper<>();
+        queryWrapper.between("record_time",begin,end).eq("plan_id",planId);
+        List<ArdAppPatrolpointRecord> list = ardAppPatrolpointRecordMapper.selectList(queryWrapper);
+        //鏃堕棿鎷嗗垎
+        String[] parts = end.split("[-\\s:]");
+        int year = Integer.parseInt(parts[0]);
+        int month = Integer.parseInt(parts[1]);
+        int day = Integer.parseInt(parts[2]);
+        JSONArray jsonArray = new JSONArray();
+        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
+        for (int i = 1; i <= day; i++) {
+            JSONObject jsonObject = new JSONObject();
+            Boolean planBoolean = false;
+            //寰幆姣忎竴澶�
+            String ymd = year+"-"+month+"-"+i;
+            Date ymdDate = dateFormat.parse(ymd);
+            //鍖归厤璁″垝鏃堕棿
+            String cycle = ardAppPatrolplan.getCycle();
+            if(cycle.equals("day")){
+                String createTime = ardAppPatrolplan.getCreateTime();
+                Date beginCreateDate = dateFormat.parse(createTime);
+                int d = ymdDate.compareTo(beginCreateDate);
+                if(d>=0){
+                    planBoolean = true;
+                }
+            }else if(cycle.equals("once")){
+                String onceBegin = ardAppPatrolplan.getPatroBeginTime();
+                Date onceBeginDate = dateFormat.parse(onceBegin);
+                String onceEnd = ardAppPatrolplan.getPatroEndTime();
+                Date onceEndDate = dateFormat.parse(onceEnd);
+                int bd = ymdDate.compareTo(onceBeginDate);
+                int ed = ymdDate.compareTo(onceEndDate);
+                if(bd>=0 && ed<=0){
+                    planBoolean = true;
+                }
+            }
+            //鍖归厤鎵撳崱鏃堕棿
+            Boolean or = false;
+            if(planBoolean){
+                for (int j = 0; j < list.size(); j++) {
+                    //鎵撳崱鏃堕棿鎷嗗垎
+                    String recordTime = list.get(j).getRecordTime();
+                    String[] part = recordTime.split("[-\\s:]");
+                    int recordYear = Integer.parseInt(part[0]);
+                    int recordMonth = Integer.parseInt(part[1]);
+                    int recordDay = Integer.parseInt(part[2]);
+                    String recordDate = recordYear+"-"+recordMonth+"-"+recordDay;
+                    //濡傛灉鐩哥瓑璇存槑杩欏ぉ鏈夋墦鍗¤褰曡褰�
+                    if(ymd.equals(recordDate)){
+                        or = true;
+                        break;
+                    }
+                }
+            }
+            jsonObject.put("toDay",ymdDate);
+            jsonObject.put("plan",planBoolean);
+            jsonObject.put("record",or);
+            jsonArray.add(jsonObject);
+        }
+        return Results.succeed(jsonArray);
     }
 }
diff --git a/ard-work/src/main/resources/mapper/app/ArdAppPatrolplanMapper.xml b/ard-work/src/main/resources/mapper/app/ArdAppPatrolplanMapper.xml
index 7e82cdb..cfeb44f 100644
--- a/ard-work/src/main/resources/mapper/app/ArdAppPatrolplanMapper.xml
+++ b/ard-work/src/main/resources/mapper/app/ArdAppPatrolplanMapper.xml
@@ -41,10 +41,12 @@
             <if test="patroBeginTime != null  and patroBeginTime != ''"> and patro_begin_time &gt;= #{patroBeginTime}</if>
             <if test="patroEndTime != null  and patroEndTime != ''"> and patro_end_time &lt;= #{patroEndTime}</if>
             <if test="wellId != null  and wellId != ''">
-                and well.alarmpoints_id in (select ard_alarmpoints_well.id from ard_alarmpoints_well where well_id = #{wellId})
+<!--                and well.alarmpoints_id in (select ard_alarmpoints_well.id from ard_alarmpoints_well where well_id = #{wellId})-->
+                and well.alarmpoints_id = #{wellId}
             </if>
             <if test="pUser != null  and pUser != ''">
-                and users.app_user_id in (select sys_user.user_id from sys_user where nick_name = #{pUser})
+<!--                and users.app_user_id in (select sys_user.user_id from sys_user where nick_name = #{pUser})-->
+                and users.app_user_id = #{pUser}
             </if>
         </where>
             group by ard_app_patrolplan.id

--
Gitblit v1.9.3