APP中巡检相关接口;浸润线查询按时间升序
parent
57510912f4
commit
8a392a0737
|
|
@ -3,7 +3,8 @@ package com.gunshi.project.xyt.controller;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.gunshi.core.result.R;
|
import com.gunshi.core.result.R;
|
||||||
import com.gunshi.project.xyt.entity.so.InspectTaskPageSo;
|
import com.gunshi.project.xyt.entity.so.InspectTaskPageSo;
|
||||||
import com.gunshi.project.xyt.entity.vo.InspectTaskDetailVo;
|
import com.gunshi.project.xyt.entity.so.InspectTaskSo;
|
||||||
|
import com.gunshi.project.xyt.entity.vo.InspectTaskVo;
|
||||||
import com.gunshi.project.xyt.model.InspectTask;
|
import com.gunshi.project.xyt.model.InspectTask;
|
||||||
import com.gunshi.project.xyt.service.InspectTaskService;
|
import com.gunshi.project.xyt.service.InspectTaskService;
|
||||||
import com.gunshi.project.xyt.validate.markers.Insert;
|
import com.gunshi.project.xyt.validate.markers.Insert;
|
||||||
|
|
@ -61,10 +62,16 @@ public class InspectTaskController extends AbstractCommonFileController{
|
||||||
return R.ok(service.startInspect(id));
|
return R.ok(service.startInspect(id));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(summary = "结束巡查")
|
@Operation(summary = "APP-保存/结束巡查")
|
||||||
@PostMapping("/finish")
|
@PostMapping("/finish")
|
||||||
public R<Boolean> finish(@RequestBody @Validated List<InspectTaskDetailVo> list) {
|
public R<Boolean> finish(@RequestBody @Validated InspectTaskVo vo) {
|
||||||
return R.ok(service.finish(list));
|
return R.ok(service.finish(vo));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Operation(summary = "APP-我的巡查任务")
|
||||||
|
@PostMapping("/list")
|
||||||
|
public R<List<InspectTask>> list(@RequestBody @Validated InspectTaskSo so) {
|
||||||
|
return R.ok(service.listQuery(so));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -46,6 +46,12 @@ public class InspectTaskDetailController{
|
||||||
return R.ok(service.pageQuery(page));
|
return R.ok(service.pageQuery(page));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Operation(summary = "APP-处理")
|
||||||
|
@PostMapping("/handle")
|
||||||
|
public R<String> handle(@RequestBody @Validated InspectProblemVo vo) {
|
||||||
|
return R.ok(service.handle(vo));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,46 @@
|
||||||
|
package com.gunshi.project.xyt.controller;
|
||||||
|
|
||||||
|
import com.gunshi.core.result.R;
|
||||||
|
import com.gunshi.project.xyt.model.InspectTaskTrack;
|
||||||
|
import com.gunshi.project.xyt.service.InspectTaskTrackService;
|
||||||
|
import com.gunshi.project.xyt.validate.markers.Insert;
|
||||||
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
/**
|
||||||
|
* 描述: 巡查轨迹
|
||||||
|
* author: xusan
|
||||||
|
* date: 2024-09-18 13:59:21
|
||||||
|
*/
|
||||||
|
@Tag(name = "巡查轨迹")
|
||||||
|
@RestController
|
||||||
|
@RequestMapping(value="/inspectTaskTrack")
|
||||||
|
public class InspectTaskTrackController {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private InspectTaskTrackService service;
|
||||||
|
|
||||||
|
|
||||||
|
@Operation(summary = "新增")
|
||||||
|
@PostMapping("/insert")
|
||||||
|
public R<InspectTaskTrack> insert(@Validated(Insert.class) @RequestBody InspectTaskTrack dto) {
|
||||||
|
dto.setCreateTime(new Date());
|
||||||
|
boolean result = service.save(dto);
|
||||||
|
return R.ok(result ? dto : null);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Operation(summary = "列表")
|
||||||
|
@PostMapping("/list")
|
||||||
|
public R<List<InspectTaskTrack>> list(@Schema(name = "taskId",description = "任务id") @RequestParam(name = "taskId") Long taskId) {
|
||||||
|
return R.ok(service.lambdaQuery().eq(InspectTaskTrack::getTaskId,taskId).orderByAsc(InspectTaskTrack::getCreateTime).list());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,35 @@
|
||||||
|
package com.gunshi.project.xyt.entity.so;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
|
||||||
|
import com.gunshi.db.dto.DateRangeSo;
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import jakarta.validation.constraints.NotNull;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Description:
|
||||||
|
* Created by wanyan on 2024/3/19
|
||||||
|
*
|
||||||
|
* @author wanyan
|
||||||
|
* @version 1.0
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Schema(description = "巡检任务查询对象")
|
||||||
|
public class InspectTaskSo {
|
||||||
|
|
||||||
|
|
||||||
|
@Schema(description="巡查人id")
|
||||||
|
@NotNull(message = "巡查人id不能为空")
|
||||||
|
@JsonSerialize(using = ToStringSerializer.class)
|
||||||
|
private Long inspectUserId;
|
||||||
|
|
||||||
|
@Schema(description = "时间范围")
|
||||||
|
private DateRangeSo dateRangeSo;
|
||||||
|
|
||||||
|
@Schema(description = "状态")
|
||||||
|
private List<Integer> statusList;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,25 @@
|
||||||
|
package com.gunshi.project.xyt.entity.vo;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import jakarta.validation.constraints.NotNull;
|
||||||
|
import lombok.Data;
|
||||||
|
import org.hibernate.validator.constraints.Range;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author xusan
|
||||||
|
* @Date 2023/7/4 10:28
|
||||||
|
* @Notes
|
||||||
|
**/
|
||||||
|
@Data
|
||||||
|
public class InspectTaskVo {
|
||||||
|
|
||||||
|
@Schema(description="任务状态")
|
||||||
|
@Range(min = 1,max = 2)
|
||||||
|
@NotNull(message = "任务状态不可为空")
|
||||||
|
private Integer status;
|
||||||
|
|
||||||
|
@Schema(description="巡查信息")
|
||||||
|
private List<InspectTaskDetailVo> list;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,15 @@
|
||||||
|
package com.gunshi.project.xyt.mapper;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||||
|
import com.gunshi.project.xyt.model.InspectTaskTrack;
|
||||||
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述: 巡查轨迹
|
||||||
|
* author: xusan
|
||||||
|
* date: 2024-09-18 13:59:21
|
||||||
|
*/
|
||||||
|
@Mapper
|
||||||
|
public interface InspectTaskTrackMapper extends BaseMapper<InspectTaskTrack> {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,71 @@
|
||||||
|
package com.gunshi.project.xyt.model;
|
||||||
|
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.annotation.IdType;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableField;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||||
|
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
|
||||||
|
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
|
||||||
|
import com.gunshi.core.dateformat.DateFormatString;
|
||||||
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述: 巡查轨迹
|
||||||
|
* author: xusan
|
||||||
|
* date: 2024-09-18 13:59:21
|
||||||
|
*/
|
||||||
|
@Schema(description="巡查轨迹")
|
||||||
|
@Data
|
||||||
|
@TableName("public.inspect_task_track")
|
||||||
|
public class InspectTaskTrack implements Serializable {
|
||||||
|
|
||||||
|
public final static String thisTableName = "InspectTaskTrack";
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 主键
|
||||||
|
*/
|
||||||
|
@TableId(value="id", type= IdType.AUTO)
|
||||||
|
@Schema(description="主键")
|
||||||
|
@JsonSerialize(using = ToStringSerializer.class)
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 任务id
|
||||||
|
*/
|
||||||
|
@TableField(value="task_id")
|
||||||
|
@Schema(description="任务id")
|
||||||
|
@JsonSerialize(using = ToStringSerializer.class)
|
||||||
|
private Long taskId;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 经度 (°)
|
||||||
|
*/
|
||||||
|
@TableField(value="lgtd")
|
||||||
|
@Schema(description="经度 (°)")
|
||||||
|
private BigDecimal lgtd;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 纬度 (°)
|
||||||
|
*/
|
||||||
|
@TableField(value="lttd")
|
||||||
|
@Schema(description="纬度 (°)")
|
||||||
|
private BigDecimal lttd;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 创建时间
|
||||||
|
*/
|
||||||
|
@TableField(value="create_time")
|
||||||
|
@Schema(description="创建时间")
|
||||||
|
@JsonFormat(pattern = DateFormatString.YYYY_MM_DD_HH_MM_SS, timezone = "GMT+8")
|
||||||
|
private Date createTime;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
package com.gunshi.project.xyt.service;
|
package com.gunshi.project.xyt.service;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||||
|
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
|
||||||
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
|
@ -16,6 +17,7 @@ import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
@ -123,6 +125,10 @@ public class InspectTaskDetailService extends ServiceImpl<InspectTaskDetailMappe
|
||||||
|
|
||||||
public void finish(List<InspectTaskDetailVo> list) {
|
public void finish(List<InspectTaskDetailVo> list) {
|
||||||
List<InspectTaskDetail> res = new ArrayList<>();
|
List<InspectTaskDetail> res = new ArrayList<>();
|
||||||
|
List<String> ids = list.stream().map(InspectTaskDetailVo::getId).map(Object::toString).collect(Collectors.toList());
|
||||||
|
if(CollectionUtils.isNotEmpty(ids)){
|
||||||
|
fileService.removeByBzIds(ids);
|
||||||
|
}
|
||||||
for(InspectTaskDetailVo vo : list){
|
for(InspectTaskDetailVo vo : list){
|
||||||
InspectTaskDetail detail = new InspectTaskDetail();
|
InspectTaskDetail detail = new InspectTaskDetail();
|
||||||
BeanUtils.copyProperties(vo,detail);
|
BeanUtils.copyProperties(vo,detail);
|
||||||
|
|
@ -135,6 +141,17 @@ public class InspectTaskDetailService extends ServiceImpl<InspectTaskDetailMappe
|
||||||
//更新任务巡检信息表
|
//更新任务巡检信息表
|
||||||
this.updateBatchById(res);
|
this.updateBatchById(res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String handle(InspectProblemVo vo) {
|
||||||
|
InspectTaskDetail detail = new InspectTaskDetail();
|
||||||
|
BeanUtils.copyProperties(vo,detail,InspectTaskDetail.class);
|
||||||
|
detail.setIsHandle(1);
|
||||||
|
detail.setHandleTime(new Date());
|
||||||
|
this.updateById(detail);
|
||||||
|
fileService.save(vo.getHandlePics(),vo.getId().toString(),getGroupId(),getHandlePicType());
|
||||||
|
fileService.save(vo.getHandleVideos(),vo.getId().toString(),getGroupId(),getHandleVideoType());
|
||||||
|
return "处理成功";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,10 +1,14 @@
|
||||||
package com.gunshi.project.xyt.service;
|
package com.gunshi.project.xyt.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
||||||
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
import com.gunshi.project.xyt.entity.so.InspectTaskPageSo;
|
import com.gunshi.project.xyt.entity.so.InspectTaskPageSo;
|
||||||
|
import com.gunshi.project.xyt.entity.so.InspectTaskSo;
|
||||||
import com.gunshi.project.xyt.entity.vo.InspectTaskDetailVo;
|
import com.gunshi.project.xyt.entity.vo.InspectTaskDetailVo;
|
||||||
|
import com.gunshi.project.xyt.entity.vo.InspectTaskVo;
|
||||||
import com.gunshi.project.xyt.mapper.InspectTaskMapper;
|
import com.gunshi.project.xyt.mapper.InspectTaskMapper;
|
||||||
import com.gunshi.project.xyt.model.InspectTask;
|
import com.gunshi.project.xyt.model.InspectTask;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
|
@ -71,13 +75,27 @@ public class InspectTaskService extends ServiceImpl<InspectTaskMapper, InspectTa
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public Boolean finish(List<InspectTaskDetailVo> list) {
|
public Boolean finish(InspectTaskVo vo) {
|
||||||
|
List<InspectTaskDetailVo> list = vo.getList();
|
||||||
inspectTaskDetailService.finish(list);
|
inspectTaskDetailService.finish(list);
|
||||||
InspectTask task = this.getById(list.get(0).getTaskId());
|
InspectTask task = this.getById(list.get(0).getTaskId());
|
||||||
task.setFinishTime(new Date());
|
task.setFinishTime(vo.getStatus() == 2 ? new Date() : null);
|
||||||
task.setStatus(2);
|
task.setStatus(vo.getStatus());
|
||||||
return this.updateById(task);
|
return this.updateById(task);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<InspectTask> listQuery(InspectTaskSo so) {
|
||||||
|
LambdaQueryWrapper<InspectTask> queryWrapper = Wrappers.lambdaQuery();
|
||||||
|
queryWrapper.eq(InspectTask::getInspectUserId,so.getInspectUserId())
|
||||||
|
.in(InspectTask::getStatus,so.getStatusList());
|
||||||
|
if(so.getDateRangeSo() != null && so.getDateRangeSo().getStart() != null){
|
||||||
|
queryWrapper.ge(InspectTask::getStartDate,so.getDateRangeSo().getStart());
|
||||||
|
}
|
||||||
|
if(so.getDateRangeSo() != null && so.getDateRangeSo().getEnd() != null){
|
||||||
|
queryWrapper.le(InspectTask::getStartDate,so.getDateRangeSo().getEnd());
|
||||||
|
}
|
||||||
|
return this.list(queryWrapper);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,23 @@
|
||||||
|
package com.gunshi.project.xyt.service;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.gunshi.project.xyt.mapper.InspectTaskTrackMapper;
|
||||||
|
import com.gunshi.project.xyt.model.InspectTaskTrack;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 描述: 巡查轨迹
|
||||||
|
* author: xusan
|
||||||
|
* date: 2024-09-18 13:59:21
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
@Slf4j
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public class InspectTaskTrackService extends ServiceImpl<InspectTaskTrackMapper, InspectTaskTrack>
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -207,7 +207,7 @@ public class OsmoticPressRService extends ServiceImpl<OsmoticPressRMapper, Osmot
|
||||||
}
|
}
|
||||||
resList.add(vo);
|
resList.add(vo);
|
||||||
}
|
}
|
||||||
return resList;
|
return resList.stream().sorted(Comparator.comparing(OsmoticStationVo::getTm)).collect(Collectors.toList());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue