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); } } 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; } 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; } 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); } } ard-work/src/main/resources/mapper/app/ArdAppPatrolplanMapper.xml
@@ -41,10 +41,12 @@ <if test="patroBeginTime != null and patroBeginTime != ''"> and patro_begin_time >= #{patroBeginTime}</if> <if test="patroEndTime != null and patroEndTime != ''"> and patro_end_time <= #{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