From d87896f06a8478af76fa85a4709f4daf1dfcc466 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期一, 29 九月 2025 17:08:34 +0800
Subject: [PATCH] 任务管理列表,指派规则

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java |   72 ++++++++++++++++++++++++++++++++++++
 1 files changed, 72 insertions(+), 0 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java
index 3af9f45..fe086be 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java
@@ -1,10 +1,19 @@
 package com.ruoyi.system.service.impl;
 
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.system.mapper.TMissionMapper;
 import com.ruoyi.system.model.TMission;
+import com.ruoyi.system.query.TMissionQuery;
 import com.ruoyi.system.service.TMissionService;
+import com.ruoyi.system.vo.TMissionReassignVO;
+import com.ruoyi.system.vo.TMissionVO;
 import org.springframework.stereotype.Service;
+import org.springframework.util.CollectionUtils;
+
+import java.time.Duration;
+import java.util.List;
+import java.util.Objects;
 
 /**
  * <p>
@@ -17,4 +26,67 @@
 @Service
 public class TMissionServiceImpl extends ServiceImpl<TMissionMapper, TMission> implements TMissionService {
 
+    @Override
+    public PageInfo<TMissionVO> pageListAssigned(TMissionQuery query) {
+        PageInfo<TMissionVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
+        List<TMissionVO> list = this.baseMapper.pageListAssigned(query, pageInfo);
+        if(CollectionUtils.isEmpty(list)){
+            return pageInfo;
+        }
+        // 计算时间差
+        for (TMissionVO tMissionVO : list) {
+            if(Objects.nonNull(tMissionVO.getAssignTime())){
+                if(Objects.nonNull(tMissionVO.getReceiveTime())){
+                    // 计算LocalDateTime两个时间相差秒数
+                    Duration duration = Duration.between(tMissionVO.getAssignTime(), tMissionVO.getReceiveTime());
+                    tMissionVO.setResponseTimePoor(duration.getSeconds());
+                }
+                if(Objects.nonNull(tMissionVO.getFinishTime())){
+                    // 计算LocalDateTime两个时间相差小时
+                    Duration duration = Duration.between(tMissionVO.getReceiveTime(), tMissionVO.getFinishTime());
+                    double minutes = (double) duration.toMinutes();
+                    minutes = minutes / 60;
+                    tMissionVO.setFinishTimePoor(minutes);
+                }
+            }
+        }
+        pageInfo.setRecords(list);
+        return pageInfo;
+    }
+
+    @Override
+    public PageInfo<TMissionReassignVO> pageListReassignAudit(TMissionQuery query) {
+        PageInfo<TMissionReassignVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
+        List<TMissionReassignVO> list = this.baseMapper.pageListReassignAudit(query, pageInfo);
+        pageInfo.setRecords(list);
+        return pageInfo;
+    }
+
+    @Override
+    public PageInfo<TMissionVO> pageListMissionPool(TMissionQuery query) {
+        PageInfo<TMissionVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
+        List<TMissionVO> list = this.baseMapper.pageListMissionPool(query, pageInfo);
+        if(CollectionUtils.isEmpty(list)){
+            return pageInfo;
+        }
+        // 计算时间差
+        for (TMissionVO tMissionVO : list) {
+            if(Objects.nonNull(tMissionVO.getAssignTime())){
+                if(Objects.nonNull(tMissionVO.getReceiveTime())){
+                    // 计算LocalDateTime两个时间相差秒数
+                    Duration duration = Duration.between(tMissionVO.getAssignTime(), tMissionVO.getReceiveTime());
+                    tMissionVO.setResponseTimePoor(duration.getSeconds());
+                }
+                if(Objects.nonNull(tMissionVO.getFinishTime())){
+                    // 计算LocalDateTime两个时间相差小时
+                    Duration duration = Duration.between(tMissionVO.getReceiveTime(), tMissionVO.getFinishTime());
+                    double minutes = (double) duration.toMinutes();
+                    minutes = minutes / 60;
+                    tMissionVO.setFinishTimePoor(minutes);
+                }
+            }
+        }
+        pageInfo.setRecords(list);
+        return pageInfo;
+    }
 }

--
Gitblit v1.7.1