From 4b8477f30194cf6dea7f1cecf405e29efb0f7bed Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期六, 12 七月 2025 14:51:19 +0800
Subject: [PATCH] 保洁巡检本周代码

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppealController.java |   82 ++++++++++++++++++++++++++++++++++++-----
 1 files changed, 72 insertions(+), 10 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppealController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppealController.java
index 4fe08ac..c232c77 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppealController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TAppealController.java
@@ -3,6 +3,7 @@
 
 import com.ruoyi.common.annotation.Log;
 import com.ruoyi.common.basic.PageInfo;
+import com.ruoyi.common.core.domain.BaseModel;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.enums.BusinessType;
@@ -14,6 +15,8 @@
 import com.ruoyi.system.service.*;
 import com.ruoyi.system.vo.system.AppealDetailVO;
 import com.ruoyi.system.vo.system.AppealListVO;
+import com.ruoyi.web.controller.tool.EmailUtils;
+import com.ruoyi.web.controller.tool.MsgUtils;
 import com.tencentcloudapi.es.v20180416.models.TaskDetail;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
@@ -71,18 +74,28 @@
         List<SysUser> sysUsers = sysUserService.selectAllList();
         List<TLocation> locationList = locationService.list();
         if (StringUtils.hasLength(query.getDeptName())){
-            List<String> projectIds = projectDeptService.lambdaQuery().like(TProjectDept::getProjectName, query.getDeptName()).list()
+            List<TProjectDept> list = projectDeptService.lambdaQuery().like(TProjectDept::getProjectName, query.getDeptName()).list();
+            List<String> listIds = projectDeptService.lambdaQuery().like(TProjectDept::getProjectName, query.getDeptName()).list()
                     .stream().map(TProjectDept::getId).collect(Collectors.toList());
+            for (TProjectDept tProjectDept : list) {
+                if (tProjectDept.getParentId().equals("0")){
+                    List<String> collect = projectDeptService.lambdaQuery().eq(TProjectDept::getParentId, tProjectDept.getId()).list()
+                            .stream().map(TProjectDept::getId).collect(Collectors.toList());
+                    listIds.addAll(collect);
+                }
+            }
             List<String> deptIds = deptService.lambdaQuery().like(TDept::getDeptName, query.getDeptName()).list()
                     .stream().map(TDept::getId).collect(Collectors.toList());
-            projectIds.addAll(deptIds);
-            if (projectIds.isEmpty()){
-                return R.ok(new PageInfo<>());
+            listIds.addAll(deptIds);
+            if (listIds.isEmpty()){
+                listIds.add("0");
             }
+            query.setPatrolInspectorIds(sysUsers.stream().filter(e->listIds.contains(e.getDeptId())).map(SysUser::getUserId)
+                    .collect(Collectors.toList()));
             if (StringUtils.hasLength(query.getPhonenumber())){
                 List<Long> patrolInspectorIds = sysUsers.stream().filter(sysUser ->
                         sysUser.getPhonenumber().equals(query.getPhonenumber())
-                                && projectIds.contains(sysUser.getDeptId())
+                                && listIds.contains(sysUser.getDeptId())
                 ).map(SysUser::getUserId).collect(Collectors.toList());
                 if (patrolInspectorIds.isEmpty()){
                     return R.ok(new PageInfo<>());
@@ -105,7 +118,11 @@
         }
         if (query.getClearStatus()!=null){
             List<String> collect = tTaskDetailService.lambdaQuery().eq(TTaskDetail::getClearStatus, query.getClearStatus())
-                    .list().stream().distinct().map(TTaskDetail::getTaskId).collect(Collectors.toList());
+                    .eq(TTaskDetail::getHandleType,1)
+                    .groupBy(TTaskDetail::getTaskId)
+                    .orderByDesc(BaseModel::getCreateTime)
+                    .list().stream().map(TTaskDetail::getTaskId).collect(Collectors.toList());
+
             query.setTaskIds(collect);
             if (collect.isEmpty()){
                 return R.ok(new PageInfo<>());
@@ -126,9 +143,11 @@
                 query.setLocationIds(collect);
                 return R.ok(new PageInfo<>());
             }else{
-                collect = collect.stream().filter(query.getLocationIds()::contains).collect(Collectors.toList());
-                if (collect.isEmpty()){
-                    return R.ok(new PageInfo<>());
+                if (query.getLocationIds()!=null){
+                    collect = collect.stream().filter(query.getLocationIds()::contains).collect(Collectors.toList());
+                    if (collect.isEmpty()){
+                        return R.ok(new PageInfo<>());
+                    }
                 }
                 query.setLocationIds(collect);
             }
@@ -175,11 +194,20 @@
     }
     @Resource
     private TNoticeService noticeService;
+    @Resource
+    private MsgUtils msgUtils;
+    @Resource
+    private TNoticeSetService noticeSetService;
+    @Resource
+    private TDictDataService dictDataService;
     @Log(title = "审核申诉记录", businessType = BusinessType.UPDATE)
     @ApiOperation(value = "审核申诉记录")
     @PostMapping(value = "/audit")
-    public R<Boolean> audit(@RequestBody @Valid TAppealAuditDTO dto) {
+    public R<Boolean> audit(@RequestBody @Valid TAppealAuditDTO dto) throws Exception {
+        List<SysUser> sysUsers = sysUserService.selectAllList();
         TAppeal appeal = appealService.getById(dto.getId());
+        SysUser sysUser = sysUsers.stream().filter(e -> e.getUserId().equals(Long.valueOf(dto.getAppealPerson())))
+                .findFirst().orElse(null);
         dto.setStatus(dto.getStatus());
         dto.setAuditPerson(tokenService.getLoginUser().getUserId()+"");
         dto.setAuditTime(LocalDateTime.now());
@@ -194,6 +222,12 @@
         taskDetail.setTaskId(appeal.getTaskId());
         Long count = tTaskDetailService.lambdaQuery().eq(TTaskDetail::getTaskId, appeal.getTaskId())
                 .eq(TTaskDetail::getHandleType, 1).count();
+        TNoticeSet noticeSet = noticeSetService.lambdaQuery().eq(TNoticeSet::getType, 2).last("limit 1")
+                .one();
+        // 邮箱
+        TDictData email = dictDataService.lambdaQuery().eq(TDictData::getDataType,4).one();
+        // 授权码
+        TDictData code = dictDataService.lambdaQuery().eq(TDictData::getDataType,5).one();
         if (dto.getStatus()==2){
             taskDetail.setClearStatus(1);
             taskDetail.setAuditTime(LocalDateTime.now());
@@ -214,6 +248,20 @@
             taskCleanService.updateById(byId);
             tNotice.setNoticeType(5);
             tNotice.setNoticeContent("【"+location.getLocationName()+"】任务申诉通过");
+            if (sysUser!=null){
+                switch (noticeSet.getNoticeType()) {
+                    case 1:
+                        msgUtils.sendMsg3(sysUser.getPhonenumber(),location.getLocationName(),"通过");
+                        break;
+                    case 2:
+                        if (StringUtils.hasLength(email.getDataContent())&&StringUtils.hasLength(code.getDataContent())){
+                            EmailUtils.sendEmail(sysUser.getEmail(),email.getDataContent(),code.getDataContent(),"【"+location.getLocationName()+"】任务申诉通过");
+                        }
+                        break;
+                    case 3:
+                        break;
+                }
+            }
         }else{
             taskDetail.setClearStatus(2);
             taskDetail.setAuditTime(LocalDateTime.now());
@@ -224,6 +272,20 @@
             taskDetail.setAppealId(dto.getId());
             tNotice.setNoticeType(4);
             tNotice.setNoticeContent("【"+location.getLocationName()+"】任务申诉驳回");
+            if (sysUser!=null){
+                switch (noticeSet.getNoticeType()) {
+                    case 1:
+                        msgUtils.sendMsg3(sysUser.getPhonenumber(),location.getLocationName(),"通过");
+                        break;
+                    case 2:
+                        if (StringUtils.hasLength(email.getDataContent())&&StringUtils.hasLength(code.getDataContent())){
+                            EmailUtils.sendEmail(sysUser.getEmail(),email.getDataContent(),code.getDataContent(),"【"+location.getLocationName()+"】任务申诉驳回");
+                        }
+                        break;
+                    case 3:
+                        break;
+                }
+            }
         }
         noticeService.save(tNotice);
         dto.setAuditPerson(tokenService.getLoginUser().getUserId()+"");

--
Gitblit v1.7.1