From 5e2d78f61bf7d1513d5d5c8cd55442133a6e898e Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期一, 14 七月 2025 18:23:36 +0800 Subject: [PATCH] 保洁巡检本周代码 --- ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TTaskCleanServiceImpl.java | 73 ++++++++++++++++++++++++++++++++++-- 1 files changed, 69 insertions(+), 4 deletions(-) diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TTaskCleanServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TTaskCleanServiceImpl.java index e4e726b..564c2d3 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TTaskCleanServiceImpl.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TTaskCleanServiceImpl.java @@ -7,6 +7,7 @@ import com.ruoyi.common.core.domain.BaseModel; import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.utils.DateUtils; +import com.ruoyi.system.applet.dto.IndexDTO; import com.ruoyi.system.applet.query.TaskUserListQuery; import com.ruoyi.system.applet.vo.TaskUserListVO; import com.ruoyi.system.mapper.*; @@ -20,6 +21,7 @@ import com.ruoyi.system.vo.system.TaskListVO; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import org.springframework.util.CollectionUtils; import org.springframework.util.StringUtils; import java.math.BigDecimal; @@ -60,7 +62,6 @@ } List<TTaskDetail> taskDetails = taskDetailMapper.selectList(Wrappers.lambdaQuery(TTaskDetail.class) .in(TTaskDetail::getTaskId, collect) - .eq(TTaskDetail::getClearStatus, 2) .eq(TTaskDetail::getHandleType,1) .orderByDesc(TTaskDetail::getCreateTime)); taskDetails = new ArrayList<>(taskDetails.stream() @@ -105,16 +106,50 @@ @Override public PageInfo<TaskUserListVO> pageListUser(TaskUserListQuery query) { PageInfo<TaskUserListVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); - List<TaskUserListVO> list = this.baseMapper.pageListUser(query,pageInfo); + List<TaskUserListVO> list = this.baseMapper.pageListUser(query); + List<TTaskDetail> taskDetails = taskDetailMapper.selectList(Wrappers.lambdaQuery(TTaskDetail.class) + .eq(TTaskDetail::getHandleType,1) + .orderByDesc(TTaskDetail::getCreateTime)); + taskDetails = new ArrayList<>(taskDetails.stream() + .collect(Collectors.groupingBy( + TTaskDetail::getTaskId, + Collectors.collectingAndThen( + Collectors.toList(), + listAll -> listAll.get(0) + ) + )) + .values()); for (TaskUserListVO taskUserListVO : list) { + TTaskDetail tTaskDetail = taskDetails.stream().filter(e -> e.getTaskId().equals(taskUserListVO.getId())) + .findFirst().orElse(null); + if (tTaskDetail!=null){ + if (tTaskDetail.getClearStatus()==1){ + taskUserListVO.setStatus(5); + }else{ + taskUserListVO.setStatus(4); + + } + } if (taskUserListVO.getDistance()!=null){ taskUserListVO.setDistance(taskUserListVO.getDistance().divide(new BigDecimal("1000"),2, RoundingMode.HALF_DOWN)); }else{ taskUserListVO.setDistance(new BigDecimal("0")); } } - pageInfo.setRecords(list); + List<TaskUserListVO> res = new ArrayList<>(); + if (query.getClearStatus()!=null){ + for (TaskUserListVO taskUserListVO : list) { + if (taskUserListVO.getClearStatus().equals(query.getClearStatus())){ + res.add(taskUserListVO); + } + } + pageInfo.setRecords(res); + pageInfo.setTotal(res.size()); + }else{ + pageInfo.setRecords(list); + pageInfo.setTotal(list.size()); + } return pageInfo; } @@ -163,20 +198,50 @@ List<TDept> deptList = deptMapper.selectList(Wrappers.lambdaQuery(TDept.class)); List<TProjectDept> projectDeptList = projectDeptMapper.selectList(Wrappers.lambdaQuery(TProjectDept.class)); + if(CollectionUtils.isEmpty(list)){ + return pageInfo; + } + + List<String> taskIds = list.stream().map(TLocationTaskListVO::getId).collect(Collectors.toList()); + List<TTaskDetail> taskDetails = taskDetailMapper.selectList(Wrappers.lambdaQuery(TTaskDetail.class) + .in(TTaskDetail::getTaskId,taskIds) + .orderByDesc(BaseModel::getCreateTime)); + for (TLocationTaskListVO tLocationTaskListVO : list) { if(tLocationTaskListVO.getDeptType()==1){ projectDeptList.stream().filter(e -> e.getId().equals(tLocationTaskListVO.getDeptId())).findFirst().ifPresent(e -> { - tLocationTaskListVO.setDeptName(e.getProjectName()); + if("0".equals(e.getParentId())){ + tLocationTaskListVO.setDeptName(e.getProjectName()); + }else { + projectDeptList.stream().filter(ee -> ee.getId().equals(e.getParentId())).findFirst().ifPresent(ee -> { + tLocationTaskListVO.setDeptName(ee.getProjectName()); + }); + } }); }else { deptList.stream().filter(e -> e.getId().equals(tLocationTaskListVO.getDeptId())).findFirst().ifPresent(e -> { tLocationTaskListVO.setDeptName(e.getDeptName()); }); } + + taskDetails.stream().filter(e -> e.getTaskId().equals(tLocationTaskListVO.getId())).findFirst().ifPresent(e -> { + tLocationTaskListVO.setClearStatus(e.getClearStatus()); + }); + } pageInfo.setRecords(list); return pageInfo; } + @Override + public List<TTask> indexTask(IndexDTO dto) { + return this.baseMapper.indexTask(dto); + } + + @Override + public List<TTask> getTaskByIds(List<String> collect1,String lon,String lat) { + return this.baseMapper.getTaskByIds(collect1,lon,lat); + } + } -- Gitblit v1.7.1