From 6831e7b977681e3f6a1c619e13c2fe28e7ccc49d Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期三, 02 七月 2025 10:36:31 +0800
Subject: [PATCH] 保洁巡检本周代码

---
 ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/TUserController.java |  228 ++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 210 insertions(+), 18 deletions(-)

diff --git a/ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/TUserController.java b/ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/TUserController.java
index f7add81..2c55767 100644
--- a/ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/TUserController.java
+++ b/ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/TUserController.java
@@ -1,6 +1,7 @@
 package com.ruoyi.web.controller.api;
 
 
+import cn.hutool.core.util.RandomUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.ruoyi.common.annotation.Log;
 import com.ruoyi.common.basic.PageInfo;
@@ -9,13 +10,11 @@
 import com.ruoyi.common.core.domain.entity.SysRole;
 import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.enums.BusinessType;
+import com.ruoyi.common.utils.DateUtils;
 import com.ruoyi.common.utils.bean.BeanUtils;
 import com.ruoyi.framework.web.service.TokenService;
 import com.ruoyi.system.applet.dto.*;
-import com.ruoyi.system.applet.query.AppealListQuery;
-import com.ruoyi.system.applet.query.KnowledgeListUserQuery;
-import com.ruoyi.system.applet.query.LeaveListUserQuery;
-import com.ruoyi.system.applet.query.TaskUserListQuery;
+import com.ruoyi.system.applet.query.*;
 import com.ruoyi.system.applet.vo.*;
 import com.ruoyi.system.dto.KnowledgeDTO;
 import com.ruoyi.system.dto.TTaskAuditBatchDTO;
@@ -35,9 +34,15 @@
 
 import javax.annotation.Resource;
 import javax.validation.Valid;
+import java.math.BigDecimal;
+import java.text.SimpleDateFormat;
+import java.time.LocalDate;
 import java.time.LocalDateTime;
+import java.time.LocalTime;
+import java.time.format.DateTimeFormatter;
 import java.util.ArrayList;
 import java.util.Arrays;
+import java.util.Date;
 import java.util.List;
 import java.util.stream.Collectors;
 
@@ -91,8 +96,152 @@
     private TFeedbackService feedbackService;
     @Resource
     private TProblemEscalationService problemEscalationService;
+    @Resource
+    private TNoticeService noticeService;
+    @ApiOperation(value = "消息通知列表")
+    @PostMapping(value = "/noticeList")
+    public R<PageInfo<NoticeListVO>> noticeList(@RequestBody NoticeListQuery query) {
+        Long userId = tokenService.getLoginUserApplet().getUserId();
+        query.setUserId(userId+"");
+        return R.ok(noticeService.noticeList(query));
+    }
+    /**
+     * 生成数据
+     * @param id
+     * @return
+     */
+    @ApiOperation(value = "测试接口不要调")
 
+    @GetMapping(value = "/testData")
+    public R<AppealDetailVO> testData(@RequestParam String id) {
+//        List<TAppeal> tAppeals = new ArrayList<>();
+//        for (int i = 0; i < 25; i++) {
+//            TAppeal tAppeal = new TAppeal();
+//            tAppeal.setTaskId("1938536771253641217");
+//            tAppeal.setAppealPerson("152");
+//            tAppeal.setStatus(1);
+//            tAppeal.setAppealContent("申诉");
+//            tAppeal.setPictures("https://bjxj.oss-cn-guangzhou.aliyuncs.com/bjxj/88d2d5614fe6492bba5666a7ab01e76b.png");
+//            tAppeals.add(tAppeal);
+//        }
+//        appealService.saveBatch(tAppeals);
+//        List<TAppeal> tAppeals1 = new ArrayList<>();
+//        for (int i = 0; i < 25; i++) {
+//            TAppeal tAppeal = new TAppeal();
+//            tAppeal.setTaskId("1938536771253641217");
+//            tAppeal.setAppealPerson("152");
+//            tAppeal.setStatus(2);
+//            tAppeal.setAppealContent("申诉");
+//            tAppeal.setPictures("https://bjxj.oss-cn-guangzhou.aliyuncs.com/bjxj/88d2d5614fe6492bba5666a7ab01e76b.png");
+//            tAppeal.setAuditPerson("162");
+//            tAppeal.setAuditRemark("备注");
+//            tAppeal.setAuditTime(LocalDateTime.now());
+//            tAppeals1.add(tAppeal);
+//        }
+//        appealService.saveBatch(tAppeals1);
+//        List<TAppeal> tAppeals2 = new ArrayList<>();
+//        for (int i = 0; i < 25; i++) {
+//            TAppeal tAppeal = new TAppeal();
+//            tAppeal.setTaskId("1938536771253641217");
+//            tAppeal.setAppealPerson("152");
+//            tAppeal.setStatus(3);
+//            tAppeal.setAppealContent("申诉");
+//            tAppeal.setPictures("https://bjxj.oss-cn-guangzhou.aliyuncs.com/bjxj/88d2d5614fe6492bba5666a7ab01e76b.png");
+//            tAppeal.setAuditPerson("162");
+//            tAppeal.setAuditRemark("备注");
+//            tAppeal.setAuditTime(LocalDateTime.now());
+//            tAppeals2.add(tAppeal);
+//        }
+//        appealService.saveBatch(tAppeals2);
+//        List<TAppeal> tAppeals3 = new ArrayList<>();
+//        for (int i = 0; i < 25; i++) {
+//            TAppeal tAppeal = new TAppeal();
+//            tAppeal.setTaskId("1938536771253641217");
+//            tAppeal.setAppealPerson("152");
+//            tAppeal.setStatus(4);
+//            tAppeal.setAppealContent("申诉");
+//            tAppeal.setPictures("https://bjxj.oss-cn-guangzhou.aliyuncs.com/bjxj/88d2d5614fe6492bba5666a7ab01e76b.png");
+//
+//            tAppeals3.add(tAppeal);
+//
+//        }
+//        appealService.saveBatch(tAppeals3);
+        return R.ok();
+    }
 
+    @ApiOperation(value = "个人中心-首页")
+    @PostMapping(value = "/userIndex")
+    public R<UserIndexVO> userIndex() {
+        UserIndexVO userIndexVO = new UserIndexVO();
+
+        Long userId = tokenService.getLoginUserApplet().getUserId();
+        SysUser sysUser = sysUserService.selectUserById(userId);
+        userIndexVO.setAvatar(sysUser.getAvatar());
+        userIndexVO.setNickName(sysUser.getNickName());
+        userIndexVO.setPhonenumber(sysUser.getPhonenumber());
+        if (sysUser.getDeptType() == 1){
+            TProjectDept tProjectDept = projectDeptService.getById(sysUser.getDeptId());
+            if (!tProjectDept.getParentId().equals("0")){
+                TProjectDept tProjectDept1 = projectDeptService.getById(tProjectDept.getParentId());
+                userIndexVO.setDeptName(tProjectDept1.getProjectName()+">"+tProjectDept.getProjectName());
+            }else{
+                userIndexVO.setDeptName(tProjectDept.getProjectName());
+            }
+        }else{
+            TDept tDept = deptService.getById(sysUser.getDeptId());
+            userIndexVO.setDeptName(tDept.getDeptName());
+        }
+        // 查询请假状态
+        List<TLeave> list = leaveService.lambdaQuery().eq(TLeave::getLeavePerson, userId)
+                .eq(TLeave::getAuditStatus, 2)
+                .list();
+        userIndexVO.setIsLeave(0);
+        for (TLeave tLeave : list) {
+            LocalDate now = LocalDate.now();
+            LocalDate startDate = tLeave.getStartTime().toLocalDate();
+            LocalDate endDate = tLeave.getStartTime().toLocalDate();
+            if (now.isAfter(startDate) && now.isBefore(endDate)) {
+                userIndexVO.setIsLeave(1);
+            }else if (now.isEqual(startDate)|| now.isEqual(endDate)){
+                userIndexVO.setIsLeave(1);
+            }
+        }
+        // 获取本月第一天凌晨00:00:00 和本月最后一天23:59:59 类型为LocalDateTime
+        // 获取当前日期
+        LocalDate now = LocalDate.now();
+        // 本月第一天
+        LocalDate firstDayOfMonth = now.withDayOfMonth(1);
+        // 本月最后一天
+        LocalDate lastDayOfMonth = now.withDayOfMonth(now.lengthOfMonth());
+        // 转换为 LocalDateTime:第一天的 00:00:00
+        LocalDateTime startOfMonth = LocalDateTime.of(firstDayOfMonth, LocalTime.MIN);
+        // 转换为 LocalDateTime:最后一天的 23:59:59
+        LocalDateTime endOfMonth = LocalDateTime.of(lastDayOfMonth, LocalTime.MAX);
+        List<TTask> finishTask = taskCleanerService.lambdaQuery().eq(TTask::getPatrolInspector, userId)
+                .ge(TTask::getImplementTime, startOfMonth)
+                .le(TTask::getImplementTime, endOfMonth).list();
+        List<String> taskIds = finishTask.stream().map(TTask::getId).collect(Collectors.toList());
+        List<TTaskDetail> taskDetails = taskDetailService.lambdaQuery()
+                .eq(TTaskDetail::getAuditStatus,1).in(TTaskDetail::getTaskId, taskIds)
+                .isNotNull(TTaskDetail::getClearStatus)
+                .groupBy(TTaskDetail::getTaskId)
+                .orderByDesc(TTaskDetail::getCreateTime).list();
+
+        int size = (int) finishTask.stream().filter(e -> e.getStatus() == 5 || e.getStatus() == 6).count();
+        userIndexVO.setFinishCount(size);
+        List<TTaskDetail> status1 = taskDetails.stream().filter(e -> e.getClearStatus() == 1).collect(Collectors.toList());
+        List<TTaskDetail> status2 = taskDetails.stream().filter(e -> e.getClearStatus() == 2).collect(Collectors.toList());
+        if (status1.size()+status2.size()!=0){
+            BigDecimal divide = new BigDecimal(status1.size()+status2.size())
+                    .divide(new BigDecimal(status1.size()), 2, BigDecimal.ROUND_DOWN).multiply(new BigDecimal(100));
+            userIndexVO.setRate(divide);
+        }else{
+            userIndexVO.setRate(new BigDecimal(0));
+        }
+        // todo 月排名
+        userIndexVO.setRanking(0);
+        return R.ok(userIndexVO);
+    }
     @ApiOperation(value = "任务记录分页列表")
     @PostMapping(value = "/taskList")
     public R<PageInfo<TaskUserListVO>> pageList(@RequestBody TaskUserListQuery query) {
@@ -115,11 +264,15 @@
         taskDetailVO.setLocationIcon(byId2.getLocationIcon());
         taskDetailVO.setLocationName(byId2.getLocationName());
         TTaskDetail tTaskDetail = list.stream().filter(e -> e.getHandleType() == 1).findFirst().orElse(null);
+        TTaskDetail tTaskDetailFinish = list.stream().filter(e -> e.getHandleType() == 2).findFirst().orElse(null);
         if (tTaskDetail!=null &&  tTaskDetail.getUnqualified()!=null){
             TDictData byId3 = dictDataService.getById(tTaskDetail.getUnqualified());
             if (byId3!=null){
                 tTaskDetail.setUnqualifiedName(byId3.getDataContent());
             }
+        }
+        if (tTaskDetailFinish!=null){
+            tTaskDetailFinish.setFinishTime(tTaskDetailFinish.getCreateTime());
         }
         taskDetailVO.setTaskDetail(tTaskDetail);
         taskDetailVO.setRecords(list);
@@ -153,6 +306,7 @@
     @ApiOperation(value = "申诉记录分页列表")
     @PostMapping(value = "/appealList")
     public R<PageInfo<AppealListVO>> pageListUser(@RequestBody AppealListQuery query) {
+        query.setUserId(tokenService.getLoginUserApplet().getUserId()+"");
         return R.ok(appealService.pageListUser(query));
     }
     @ApiOperation(value = "详情申诉记录")
@@ -168,14 +322,17 @@
         appealDetailVO.setLocationIcon(byId2.getLocationIcon());
         appealDetailVO.setLocationName(byId2.getLocationName());
         appealDetailVO.setTaskId(byId.getId());
-        SysUser sysUser = sysUserService.selectUserById(Long.valueOf(appeal.getAuditPerson()));
-        if (sysUser!=null){
-            appealDetailVO.setAuditPersonName(sysUser.getUserName());
+        if (StringUtils.hasLength(appeal.getAuditPerson())){
+            SysUser sysUser = sysUserService.selectUserById(Long.valueOf(appeal.getAuditPerson()));
+            if (sysUser!=null){
+                appealDetailVO.setAuditPersonName(sysUser.getUserName());
+            }
         }
         appealDetailVO.setTaskName(byId.getTaskName());
         appealDetailVO.setTaskCode(byId.getTaskCode());
         return R.ok(appealDetailVO);
     }
+
     @Log(title = "取消申诉记录", businessType = BusinessType.OTHER)
     @ApiOperation(value = "取消申诉记录")
     @GetMapping(value = "/cancelAppeal")
@@ -203,7 +360,7 @@
     @ApiOperation(value = "上传督察任务")
     @PostMapping(value = "/addInspector")
     public R<Boolean> addInspector(@RequestBody InspectorAddDTO dto) {
-        dto.setCommit_person(tokenService.getLoginUser().getUserId()+"");
+        dto.setCommitPerson(tokenService.getLoginUserApplet().getUserId()+"");
         if (dto.getClearStatus()==1){
             dto.setStatus(4);
         }else{
@@ -215,14 +372,14 @@
     @ApiOperation(value = "上传意见反馈")
     @PostMapping(value = "/addFeedback")
     public R<Boolean> addFeedback(@RequestBody FeedbackDTO dto) {
-        dto.setFeedbackPerson(tokenService.getLoginUser().getUserId()+"");
+        dto.setFeedbackPerson(tokenService.getLoginUserApplet().getUserId()+"");
         feedbackService.save(dto);
         return R.ok();
     }
     @ApiOperation(value = "上传问题上报")
     @PostMapping(value = "/addProblem")
     public R<Boolean> addProblem(@RequestBody ProblemDTO dto) {
-        dto.setEscalationId(tokenService.getLoginUser().getUserId()+"");
+        dto.setEscalationId(tokenService.getLoginUserApplet().getUserId()+"");
         problemEscalationService.save(dto);
         return R.ok();
     }
@@ -262,12 +419,12 @@
     @GetMapping(value = "/leaveAuditList")
     public R<LeaveAuditListVO> leaveAuditList() {
         LeaveAuditListVO res = new LeaveAuditListVO();
-        Long userId = tokenService.getLoginUser().getUserId();
+        Long userId = tokenService.getLoginUserApplet().getUserId();
         SysUser user = sysUserService.selectUserById(userId);
         Long userRole = sysUserService.getUserRole(userId);
         SysRole sysRole = roleService.selectRoleById(userRole);
         List<SysUser> sysUsers = sysUserService.selectAllList();
-
+        sysRole.setRoleName("项目负责人");
         SysUser auditPerson = sysUserService.selectUserById(999L);
         //项目负责人、部门负责人、公司成员提交由最终审批人审批;
         if (user.getDeptType()==2 ||sysRole.getRoleName().contains("项目负责人")||sysRole.getRoleName().contains("部门负责人")){
@@ -275,6 +432,7 @@
             tLeaveAudit.setAvatar(auditPerson.getAvatar());
             tLeaveAudit.setNickName(auditPerson.getNickName());
             res.setAuditPerson(tLeaveAudit);
+            res.setAuditPersonId("999");
         }else if (!sysRole.getRoleName().equals("部门助理")){
             // 审批人根据当前角色类型来
             if (sysRole.getRoleName().contains("现场负责人")||sysRole.getRoleName().contains("组长")){
@@ -288,6 +446,8 @@
                         tLeaveAudit.setAvatar(sysUser.getAvatar());
                         tLeaveAudit.setNickName(sysUser.getNickName());
                         res.setAuditPerson(tLeaveAudit);
+                        res.setAuditPersonId(sysUser.getUserId()+"");
+                        break;
                     }
                 }
             }
@@ -302,6 +462,8 @@
                     tLeaveAudit.setAvatar(sysUser.getAvatar());
                     tLeaveAudit.setNickName(sysUser.getNickName());
                     res.setAuditPerson(tLeaveAudit);
+                    res.setAuditPersonId(sysUser.getUserId()+"");
+                    break;
                 }
             }
         }
@@ -319,17 +481,38 @@
         res.setCopyPerson(leaveAuditVOS);
         return R.ok(res);
     }
+
+    public static void main(String[] args) {
+        String temp = "2025-06-30 00:00:00";
+        // 轉化爲localdateTime
+        LocalDateTime parse = LocalDateTime.parse(temp, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
+        System.out.println(parse);
+    }
     @ApiOperation(value = "发起请假")
     @PostMapping(value = "/addLeave")
     public R addLeave(@RequestBody LeaveDTO leaveDTO) {
-        Long userId = tokenService.getLoginUser().getUserId();
+//        String startTime1 = leaveDTO.getStartTime1();
+//        // 轉化爲LocalDateTime類型
+//        leaveDTO.setStartTime(LocalDateTime.parse(startTime1, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
+//        String endTime1 = leaveDTO.getEndTime1();
+//        // 轉化爲LocalDateTime類型
+//        leaveDTO.setStartTime(LocalDateTime.parse(endTime1, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
+        Long userId = tokenService.getLoginUserApplet().getUserId();
         SysUser user = sysUserService.selectUserById(userId);
         Long userRole = sysUserService.getUserRole(userId);
         SysRole sysRole = roleService.selectRoleById(userRole);
         List<SysUser> sysUsers = sysUserService.selectAllList();
         SysUser auditPerson = sysUserService.selectUserById(999L);
         leaveDTO.setAuditStatus(1);
+        Date date = new Date();
+        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyyMMddHHmmss");
+        // 生成随机数字6位
+        String format = simpleDateFormat.format(date);
+        leaveDTO.setCode(format+ RandomUtil.randomNumbers(6));
+        leaveDTO.setTemplateId(user.getTemplateId());
+        leaveDTO.setLeavePerson(userId+"");
         leaveService.save(leaveDTO);
+        sysRole.setRoleName("项目负责人");
         //项目负责人、部门负责人、公司成员提交由最终审批人审批;
         if (user.getDeptType()==2 ||sysRole.getRoleName().contains("项目负责人")||sysRole.getRoleName().contains("部门负责人")){
             TLeaveAudit tLeaveAudit1 = new TLeaveAudit();
@@ -385,16 +568,26 @@
     @ApiOperation(value = "我的审批-我的申请")
     @PostMapping(value = "/leaveList")
     public R<PageInfo<LeaveUserListVO>> leaveList(@RequestBody LeaveListUserQuery query) {
-        query.setUserId(tokenService.getLoginUser().getUserId()+"");
+        query.setUserId(tokenService.getLoginUserApplet().getUserId()+"");
         return R.ok( leaveService.leaveList(query));
+    }
+    @ApiOperation(value = "我的审批-审批")
+    @PostMapping(value = "/auditLeave")
+    public R<Boolean> auditLeave(@RequestBody LeaveAuditDTO dto) {
+        dto.setAuditId(tokenService.getLoginUserApplet().getUserId()+"");
+        dto.setAuditTime(LocalDateTime.now());
+        leaveService.updateById(dto);
+        return R.ok();
     }
     @ApiOperation(value = "我的审批-详情")
     @GetMapping(value = "/leaveDetail")
     public R<LeaveUserDetailVO> leaveDetail(@RequestParam String id) {
+        TLeave leave = leaveService.getById(id);
         LeaveUserDetailVO leaveUserDetailVO = new LeaveUserDetailVO();
-        SysUser sysUser = sysUserService.selectUserById(Long.parseLong(leaveUserDetailVO.getLeavePerson()));
+        SysUser sysUser = sysUserService.selectUserById(Long.parseLong(leave.getLeavePerson()));
         Long userRole = sysUserService.getUserRole(sysUser.getUserId());
         SysRole sysRole = roleService.selectRoleById(userRole);
+        sysRole.setRoleName("项目负责人");
         if (sysRole.getRoleName().contains("现场负责人")||sysRole.getRoleName().equals("组长")){
             if (sysUser.getDeptType() == 1){
                 TProjectDept tProjectDept = projectDeptService.getById(sysUser.getDeptId());
@@ -416,11 +609,10 @@
             TDept byId = deptService.getById(sysUser.getDeptId());
             leaveUserDetailVO.setDeptName(byId.getDeptName());
         }
-        TLeave leave = leaveService.getById(id);
         leaveUserDetailVO.setLeavePersonName(sysUser.getNickName());
         LeaveAuditListVO leaveAuditListVO = new LeaveAuditListVO();
         List<TLeaveAudit> list = leaveAuditService.list(new LambdaQueryWrapper<TLeaveAudit>()
-                .eq(TLeaveAudit::getAuditId, leave.getId()));
+                .eq(TLeaveAudit::getLeaveId, leave.getId()));
         for (TLeaveAudit tLeaveAudit : list) {
             if (tLeaveAudit.getAuditType()==1){
                 LeaveAuditVO leaveAuditVO = new LeaveAuditVO();
@@ -466,7 +658,7 @@
         leaveUserDetailVO.setAuditTime(leave.getAuditTime());
         leaveUserDetailVO.setAuditRemark(leave.getAuditRemark());
         leaveUserDetailVO.setCode(leave.getCode());
-        return R.ok( );
+        return R.ok(leaveUserDetailVO);
     }
 }
 

--
Gitblit v1.7.1