From a10bd6f63ab8347f7e3cb259765e159004ba19f1 Mon Sep 17 00:00:00 2001
From: Administrator <1144154118@qq.com>
Date: 星期四, 17 八月 2023 16:40:16 +0800
Subject: [PATCH] 单兵端--巡检日历

---
 ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java |  164 ++++++++++++++++++++++++++++++++----------------------
 1 files changed, 96 insertions(+), 68 deletions(-)

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 d4c769c..9aae3b1 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
@@ -59,73 +59,6 @@
     @Resource
     private ArdAlarmpointsWellMapper wellMapper;
 
-    /**
-     * 鏌ヨapp宸℃璁″垝璁板綍
-     *
-     * @param id app宸℃璁″垝璁板綍涓婚敭
-     * @return app宸℃璁″垝璁板綍
-     */
-    @Override
-    public ArdAppPatrolpointRecord selectArdAppPatrolpointRecordById(String id) {
-        return ardAppPatrolpointRecordMapper.selectArdAppPatrolpointRecordById(id);
-    }
-
-    /**
-     * 鏌ヨapp宸℃璁″垝璁板綍鍒楄〃
-     *
-     * @param ardAppPatrolpointRecord app宸℃璁″垝璁板綍
-     * @return app宸℃璁″垝璁板綍
-     */
-    @Override
-    public List<ArdAppPatrolpointRecord> selectArdAppPatrolpointRecordList(ArdAppPatrolpointRecord ardAppPatrolpointRecord) {
-        return ardAppPatrolpointRecordMapper.selectArdAppPatrolpointRecordList(ardAppPatrolpointRecord);
-    }
-
-    /**
-     * 鏂板app宸℃璁″垝璁板綍
-     *
-     * @param ardAppPatrolpointRecord app宸℃璁″垝璁板綍
-     * @return 缁撴灉
-     */
-    @Override
-    public int insertArdAppPatrolpointRecord(ArdAppPatrolpointRecord ardAppPatrolpointRecord) {
-                ardAppPatrolpointRecord.setUserId(SecurityUtils.getUserId());
-            return ardAppPatrolpointRecordMapper.insertArdAppPatrolpointRecord(ardAppPatrolpointRecord);
-    }
-
-    /**
-     * 淇敼app宸℃璁″垝璁板綍
-     *
-     * @param ardAppPatrolpointRecord app宸℃璁″垝璁板綍
-     * @return 缁撴灉
-     */
-    @Override
-    public int updateArdAppPatrolpointRecord(ArdAppPatrolpointRecord ardAppPatrolpointRecord) {
-        return ardAppPatrolpointRecordMapper.updateArdAppPatrolpointRecord(ardAppPatrolpointRecord);
-    }
-
-    /**
-     * 鎵归噺鍒犻櫎app宸℃璁″垝璁板綍
-     *
-     * @param ids 闇�瑕佸垹闄ょ殑app宸℃璁″垝璁板綍涓婚敭
-     * @return 缁撴灉
-     */
-    @Override
-    public int deleteArdAppPatrolpointRecordByIds(String[] ids) {
-        return ardAppPatrolpointRecordMapper.deleteArdAppPatrolpointRecordByIds(ids);
-    }
-
-    /**
-     * 鍒犻櫎app宸℃璁″垝璁板綍淇℃伅
-     *
-     * @param id app宸℃璁″垝璁板綍涓婚敭
-     * @return 缁撴灉
-     */
-    @Override
-    public int deleteArdAppPatrolpointRecordById(String id) {
-        return ardAppPatrolpointRecordMapper.deleteArdAppPatrolpointRecordById(id);
-    }
-
     @Override
     public Results record(ArdAppPatrolpointRecord ardAppPatrolpointRecord) {
         String id = IdUtils.simpleUUID();
@@ -423,7 +356,7 @@
     }
 
     @Override
-    public Results executeMonth(RecordMonthParam RecordMonthParam) throws ParseException {
+    public Results executeMonthOld(RecordMonthParam RecordMonthParam) throws ParseException {
         //鑾峰彇鍓嶇鍙傛暟
         String begin = RecordMonthParam.getBegin();
         String end = RecordMonthParam.getEnd();
@@ -622,4 +555,99 @@
         return Results.succeed(list);
     }
 
+    @Override
+    public Results executeMonth(RecordMonthExParam recordMonthExParam) throws ParseException {
+        //鑾峰彇鍓嶇鍙傛暟
+        String begin = recordMonthExParam.getBegin();
+        String end = recordMonthExParam.getEnd();
+        //杩斿洖杩欎釜
+        JSONArray jsonArray = new JSONArray();
+        //鏃堕棿鎷嗗垎
+        String[] parts = end.split("[-\\s:]");
+        int year = Integer.parseInt(parts[0]);
+        int month = Integer.parseInt(parts[1]);
+        int day = Integer.parseInt(parts[2]);
+        String monthZero;
+        if(month<10){
+            monthZero = String.format("%02d", month);
+        }else {
+            monthZero = String.valueOf(month);
+        }
+        String userId = SecurityUtils.getUserId();
+        recordMonthExParam.setUserId(userId);
+        //鏌ヨ璇ョ敤鎴蜂笅闇�瑕佹墽琛岀殑鍗曟璁″垝
+        List<ArdAppPatrolplan> onceList = patrolplanMapper.oncePlan(recordMonthExParam);
+        //鏌ヨ璇ョ敤鎴蜂笅闇�瑕佹墽琛岀殑姣忔棩璁″垝
+        List<ArdAppPatrolplan> dayList = patrolplanMapper.dayPlan(recordMonthExParam);
+        //寰幆涓�涓湀涓殑姣忎竴澶�
+        for (int i = 1; i <= day; i++) {
+            String di;
+            Boolean planBoolean = false;
+            Boolean recordBoolean = false;
+            //璁板綍杩欏ぉ璁″垝鏉℃暟
+            int dayNum = 0;
+            int onceNum = 0;
+            //璁板綍杩欏ぉ鐨勬墦寮�鍦扮偣鏁�
+            int dayWell = 0;
+            int onceWell = 0;
+            if (i < 10) {
+                di = String.format("%02d", i);
+            } else {
+                di = String.valueOf(i);
+            }
+            //姣忎竴澶�
+            String ymd = year + "-" + monthZero + "-" + di;
+            JSONObject jsonObject = new JSONObject();
+            jsonObject.put("toDay",ymd );
+            //濡傛灉姣忔棩璁″垝鏈夋暟鎹�
+            if (dayList.size() > 0) {
+                for (int j = 0; j < dayList.size(); j++) {
+                    String dayTime = dayList.get(j).getCreateTime();
+                    String dt = dayTime.substring(0,10);
+                    //濡傛灉姣忔棩璁″垝鏃ユ湡绛変簬杩欎竴澶╋紝閭d粠杩欎竴澶╀箣鍚庣殑姣忎竴澶╅兘鏄湁璁″垝鐨�
+                    if(dt.compareTo(ymd)<=0){
+                        planBoolean =true;
+                        dayNum+=1;
+                        String id = dayList.get(j).getId();
+                        List<ArdAlarmpointsWell> dayWells = wellMapper.wellByPlanId(id);
+                        dayWell = dayWells.size();
+                    }
+                }
+            }
+            //濡傛灉鍗曟璁″垝鏈夋暟鎹�
+            if(onceList.size()>0){
+                for (int j = 0; j < onceList.size(); j++) {
+                    String beginTime = onceList.get(j).getPatroBeginTime();
+                    String bt = beginTime.substring(0,10);
+                    if(bt.equals(ymd)){
+                        planBoolean = true;
+                        onceNum+=1;
+                        List<ArdAlarmpointsWell> onceWells = wellMapper.wellByPlanId(onceList.get(j).getId());
+                        onceWell = onceWells.size();
+                    }
+                }
+            }
+            if(planBoolean){
+                //杩欏ぉ鎬讳换鍔℃潯鏁�
+                int planNum = dayNum+onceNum;
+                //杩欏ぉ鎬诲叴瓒g偣鏁�
+                int wellNum = dayWell+onceWell;
+                QueryWrapper<ArdAppPatrolpointRecord> queryWrapper = new QueryWrapper<>();
+                queryWrapper.eq("user_id",userId).like("record_time",ymd);
+                List<ArdAppPatrolpointRecord> list = ardAppPatrolpointRecordMapper.selectList(queryWrapper);
+                //宸叉墦鍗℃�绘潯鏁�
+                int num = list.size();
+                //搴旀墦鍗℃�绘潯鏁�
+                int record = planNum*wellNum;
+                if(num==record){
+                    recordBoolean = true;
+                }
+            }
+            jsonObject.put("toDay",ymd );
+            jsonObject.put("plan",planBoolean);
+            jsonObject.put("record",recordBoolean);
+            jsonArray.add(jsonObject);
+        }
+        return Results.succeed(jsonArray);
+    }
 }

--
Gitblit v1.9.3