From 25b19e60e004290531f61fdf608d1adb5e531903 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期六, 12 七月 2025 14:40:12 +0800 Subject: [PATCH] 保洁巡检本周代码 --- ruoyi-applet/src/main/java/com/ruoyi/web/controller/api/TUserController.java | 256 +++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 207 insertions(+), 49 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 d5284d1..2548608 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 @@ -26,6 +26,8 @@ import com.ruoyi.system.query.TaskListQuery; import com.ruoyi.system.service.*; import com.ruoyi.system.vo.system.*; +import com.ruoyi.web.controller.tool.EmailUtils; +import com.ruoyi.web.controller.tool.MsgUtils; import com.sun.jna.platform.win32.LMAccess; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; @@ -81,6 +83,8 @@ @Resource private TDictDataService dictDataService; @Resource + private TNoticeSetService noticeSetService; + @Resource private TLeaveService leaveService; @Resource private TLeaveAuditService leaveAuditService; @@ -96,6 +100,8 @@ private TProblemEscalationService problemEscalationService; @Resource private TNoticeService noticeService; + @Resource + private MsgUtils msgUtils; @ApiOperation(value = "消息通知列表") @PostMapping(value = "/noticeList") @@ -443,10 +449,10 @@ public R<List<TaskListAllVO>> listAllTask(@RequestBody AppealListDTO appealListDTO) { appealListDTO.setUserId(tokenService.getLoginUserApplet().getUserId() + ""); SysUser sysUser = sysUserService.selectUserById(tokenService.getLoginUserApplet().getUserId()); - if (sysUser.getDeptType()==2){ - // 公司部门查询所有任务 - appealListDTO.setUserId(null); - } +// if (sysUser.getDeptType()==2){ +// // 公司部门查询所有任务 +// appealListDTO.setUserId(null); +// } List<TaskListAllVO> res = appealService.listAllTask(appealListDTO); return R.ok(res); } @@ -463,22 +469,17 @@ @ApiOperation(value = "上传督察任务") @PostMapping(value = "/addInspector") - public R<Boolean> addInspector(@RequestBody InspectorAddDTO dto) { + public R<Boolean> addInspector(@RequestBody InspectorAddDTO dto) throws Exception { TTask task = taskCleanerService.getById(dto.getTaskId()); TLocation location = locationService.getById(task.getLocationId()); SysUser sysUser = sysUserService.selectUserById(Long.valueOf(task.getPatrolInspector())); dto.setCommitPerson(tokenService.getLoginUserApplet().getUserId() + ""); + if (dto.getClearStatus() == 1) { dto.setStatus(4); } else { dto.setStatus(1); - TNotice tNotice = new TNotice(); - tNotice.setUserId(sysUser.getUserId()+""); - tNotice.setNoticeContent("【"+location.getLocationName()+"】任务督察不合格,请及时整改!"); - tNotice.setStatus(1); - tNotice.setDataId(dto.getTaskId()); - tNotice.setNoticeType(8); - noticeService.save(tNotice); + } inspectorService.save(dto); return R.ok(); @@ -562,16 +563,37 @@ for (SysUser sysUser : collect) { Long userRole1 = sysUserService.getUserRole(sysUser.getUserId()); SysRole sysRole1 = roleService.selectRoleById(userRole1); - +// if (sysRole1 != null && sysRole1.getRoleName().equals("项目部负责人")) { +// if (userDept.getId().equals(sysUser.getDeptId())){ +// LeaveAuditVO tLeaveAudit = new LeaveAuditVO(); +// tLeaveAudit.setAvatar(sysUser.getAvatar()); +// tLeaveAudit.setNickName(sysUser.getNickName()); +// res.setAuditPerson(tLeaveAudit); +// res.setAuditPersonId(sysUser.getUserId() + ""); +// break; +// } +// } if (sysRole1 != null && sysRole1.getRoleName().equals("项目部负责人")) { - if (userDept.getParentId().equals(sysUser.getDeptId())){ - LeaveAuditVO tLeaveAudit = new LeaveAuditVO(); - tLeaveAudit.setAvatar(sysUser.getAvatar()); - tLeaveAudit.setNickName(sysUser.getNickName()); - res.setAuditPerson(tLeaveAudit); - res.setAuditPersonId(sysUser.getUserId() + ""); - break; + if (!sysRole.getRoleName().contains("项目部助理")){ + if (userDept.getParentId().equals(sysUser.getDeptId())){ + LeaveAuditVO tLeaveAudit = new LeaveAuditVO(); + tLeaveAudit.setAvatar(sysUser.getAvatar()); + tLeaveAudit.setNickName(sysUser.getNickName()); + res.setAuditPerson(tLeaveAudit); + res.setAuditPersonId(sysUser.getUserId() + ""); + break; + } + }else{ + if (userDept.getId().equals(sysUser.getDeptId())){ + LeaveAuditVO tLeaveAudit = new LeaveAuditVO(); + tLeaveAudit.setAvatar(sysUser.getAvatar()); + tLeaveAudit.setNickName(sysUser.getNickName()); + res.setAuditPerson(tLeaveAudit); + res.setAuditPersonId(sysUser.getUserId() + ""); + break; + } } + } } } @@ -615,7 +637,7 @@ @ApiOperation(value = "发起请假") @PostMapping(value = "/addLeave") - public R addLeave(@RequestBody LeaveDTO leaveDTO) { + public R addLeave(@RequestBody LeaveDTO leaveDTO) throws Exception { // String startTime1 = leaveDTO.getStartTime1(); // // 轉化爲LocalDateTime類型 // leaveDTO.setStartTime(LocalDateTime.parse(startTime1, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"))); @@ -637,6 +659,12 @@ leaveDTO.setTemplateId(user.getTemplateId()); leaveDTO.setLeavePerson(userId + ""); leaveService.save(leaveDTO); + 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 (user.getDeptType() == 2 || sysRole.getRoleName().contains("项目部负责人") || sysRole.getRoleName().contains("部门负责人")) { TLeaveAudit tLeaveAudit1 = new TLeaveAudit(); @@ -645,6 +673,13 @@ tLeaveAudit1.setAuditId(auditPerson.getUserId() + ""); tLeaveAudit1.setAuditType(1); leaveAuditService.save(tLeaveAudit1); + TLeaveAudit tLeaveAudit2 = new TLeaveAudit(); + tLeaveAudit2.setLeaveId(leaveDTO.getId()); + tLeaveAudit2.setAuditStatus(2); + tLeaveAudit2.setAuditId(user.getUserId() + "," + auditPerson.getUserId()); + tLeaveAudit2.setAuditType(2); + tLeaveAudit2.setAuditTime(LocalDateTime.now()); + leaveAuditService.save(tLeaveAudit2); } else if (!sysRole.getRoleName().equals("部门助理")) { // 审批人根据当前角色类型来 if (sysRole.getRoleName().contains("片区负责人") || sysRole.getRoleName().contains("组长")|| sysRole.getRoleName().contains("队长") @@ -657,25 +692,91 @@ SysRole sysRole1 = roleService.selectRoleById(userRole1); if (sysRole1 != null && sysRole1.getRoleName().equals("项目部负责人")) { - if (userDept.getParentId().equals(sysUser.getDeptId())){ - LeaveAuditVO tLeaveAudit = new LeaveAuditVO(); - tLeaveAudit.setAvatar(sysUser.getAvatar()); - tLeaveAudit.setNickName(sysUser.getNickName()); - TLeaveAudit tLeaveAudit1 = new TLeaveAudit(); - tLeaveAudit1.setLeaveId(leaveDTO.getId()); - tLeaveAudit1.setAuditStatus(1); - tLeaveAudit1.setAuditId(sysUser.getUserId() + ""); - tLeaveAudit1.setAuditType(1); - leaveAuditService.save(tLeaveAudit1); - TLeaveAudit tLeaveAudit2 = new TLeaveAudit(); - tLeaveAudit2.setLeaveId(leaveDTO.getId()); - tLeaveAudit2.setAuditStatus(2); - tLeaveAudit2.setAuditId(user.getUserId() + "," + sysUser.getUserId()); - tLeaveAudit2.setAuditType(2); - tLeaveAudit2.setAuditTime(LocalDateTime.now()); - leaveAuditService.save(tLeaveAudit2); - break; - } + if (!sysRole.getRoleName().contains("项目部助理")){ + if (userDept.getParentId().equals(sysUser.getDeptId())){ + LeaveAuditVO tLeaveAudit = new LeaveAuditVO(); + tLeaveAudit.setAvatar(sysUser.getAvatar()); + tLeaveAudit.setNickName(sysUser.getNickName()); + TLeaveAudit tLeaveAudit1 = new TLeaveAudit(); + tLeaveAudit1.setLeaveId(leaveDTO.getId()); + tLeaveAudit1.setAuditStatus(1); + tLeaveAudit1.setAuditId(sysUser.getUserId() + ""); + tLeaveAudit1.setAuditType(1); + leaveAuditService.save(tLeaveAudit1); + // 新增消息 + TNotice tNotice = new TNotice(); + tNotice.setUserId(sysUser.getUserId()+""); + tNotice.setNoticeContent(user.getNickName() + "提交了请假申请,请尽快审核"); + tNotice.setStatus(1); + tNotice.setDataId(leaveDTO.getId()); + tNotice.setNoticeType(6); + + switch (noticeSet.getNoticeType()) { + case 1: + msgUtils.sendMsg4(sysUser.getPhonenumber()); + break; + case 2: + if (StringUtils.hasLength(email.getDataContent()) && StringUtils.hasLength(code.getDataContent())) { + EmailUtils.sendEmail(sysUser.getEmail(), email.getDataContent(), code.getDataContent(), "你有一条请假申请待处理,请登录沿海市政质管小程序处理。"); + } + break; + case 3: + break; + } + + + noticeService.save(tNotice); + TLeaveAudit tLeaveAudit2 = new TLeaveAudit(); + tLeaveAudit2.setLeaveId(leaveDTO.getId()); + tLeaveAudit2.setAuditStatus(2); + tLeaveAudit2.setAuditId(user.getUserId() + "," + sysUser.getUserId()); + tLeaveAudit2.setAuditType(2); + tLeaveAudit2.setAuditTime(LocalDateTime.now()); + leaveAuditService.save(tLeaveAudit2); + break; + } + }else{ + if (userDept.getId().equals(sysUser.getDeptId())){ + LeaveAuditVO tLeaveAudit = new LeaveAuditVO(); + tLeaveAudit.setAvatar(sysUser.getAvatar()); + tLeaveAudit.setNickName(sysUser.getNickName()); + TLeaveAudit tLeaveAudit1 = new TLeaveAudit(); + tLeaveAudit1.setLeaveId(leaveDTO.getId()); + tLeaveAudit1.setAuditStatus(1); + tLeaveAudit1.setAuditId(sysUser.getUserId() + ""); + tLeaveAudit1.setAuditType(1); + leaveAuditService.save(tLeaveAudit1); + // 新增消息 + TNotice tNotice = new TNotice(); + tNotice.setUserId(sysUser.getUserId()+""); + tNotice.setNoticeContent(user.getNickName() + "提交了请假申请,请尽快审核"); + tNotice.setStatus(1); + tNotice.setDataId(leaveDTO.getId()); + tNotice.setNoticeType(6); + noticeService.save(tNotice); + switch (noticeSet.getNoticeType()) { + case 1: + msgUtils.sendMsg4(sysUser.getPhonenumber()); + break; + case 2: + if (StringUtils.hasLength(email.getDataContent()) && StringUtils.hasLength(code.getDataContent())) { + EmailUtils.sendEmail(sysUser.getEmail(), email.getDataContent(), code.getDataContent(), "你有一条请假申请待处理,请登录沿海市政质管小程序处理。"); + } + break; + case 3: + break; + } + TLeaveAudit tLeaveAudit2 = new TLeaveAudit(); + tLeaveAudit2.setLeaveId(leaveDTO.getId()); + tLeaveAudit2.setAuditStatus(2); + tLeaveAudit2.setAuditId(user.getUserId() + "," + sysUser.getUserId()); + tLeaveAudit2.setAuditType(2); + tLeaveAudit2.setAuditTime(LocalDateTime.now()); + leaveAuditService.save(tLeaveAudit2); + break; + } + } + } } } @@ -692,6 +793,26 @@ tLeaveAudit1.setAuditId(sysUser.getUserId() + ""); tLeaveAudit1.setAuditType(1); leaveAuditService.save(tLeaveAudit1); + // 新增消息 + TNotice tNotice = new TNotice(); + tNotice.setUserId(sysUser.getUserId()+""); + tNotice.setNoticeContent(user.getNickName() + "提交了请假申请,请尽快审核"); + tNotice.setStatus(1); + tNotice.setDataId(leaveDTO.getId()); + tNotice.setNoticeType(6); + noticeService.save(tNotice); + switch (noticeSet.getNoticeType()) { + case 1: + msgUtils.sendMsg4(sysUser.getPhonenumber()); + break; + case 2: + if (StringUtils.hasLength(email.getDataContent()) && StringUtils.hasLength(code.getDataContent())) { + EmailUtils.sendEmail(sysUser.getEmail(), email.getDataContent(), code.getDataContent(), "你有一条请假申请待处理,请登录沿海市政质管小程序处理。"); + } + break; + case 3: + break; + } TLeaveAudit tLeaveAudit2 = new TLeaveAudit(); tLeaveAudit2.setLeaveId(leaveDTO.getId()); tLeaveAudit2.setAuditStatus(2); @@ -703,14 +824,7 @@ } } - // 新增消息 - TNotice tNotice = new TNotice(); - tNotice.setUserId(leaveDTO.getAuditId()); - tNotice.setNoticeContent(user.getNickName() + "提交了请假申请,请尽快审核"); - tNotice.setStatus(1); - tNotice.setDataId(leaveDTO.getId()); - tNotice.setNoticeType(6); - noticeService.save(tNotice); + return R.ok(); } @@ -723,14 +837,21 @@ @ApiOperation(value = "我的审批-审批") @PostMapping(value = "/auditLeave") - public R<Boolean> auditLeave(@RequestBody LeaveAuditDTO dto) { + public R<Boolean> auditLeave(@RequestBody LeaveAuditDTO dto) throws Exception { dto.setAuditId(tokenService.getLoginUserApplet().getUserId() + ""); dto.setAuditTime(LocalDateTime.now()); leaveService.updateById(dto); + List<SysUser> sysUsers = sysUserService.selectAllList(); SysUser sysUser = sysUserService.selectUserById(Long.valueOf(dto.getLeavePerson())); TLeaveAudit leaveAudit = leaveAuditService.lambdaQuery().eq(TLeaveAudit::getLeaveId, dto.getId()) .eq(TLeaveAudit::getAuditType, 2).one(); + 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(); TNotice tNotice = new TNotice(); tNotice.setUserId(leaveAudit.getAuditId().split(",")[0]); tNotice.setNoticeContent(sysUser.getNickName()+"的请假申请已审核,请查收"); @@ -738,6 +859,29 @@ tNotice.setDataId(dto.getId()); tNotice.setNoticeType(7); noticeService.save(tNotice); + LocalDateTime startTime = dto.getStartTime(); + LocalDateTime endTime = dto.getEndTime(); + SysUser sysUser1 = sysUsers.stream().filter(e -> e.getUserId().equals(Long.valueOf(leaveAudit.getAuditId().split(",")[0]))) + .findFirst().orElse(null); + SysUser sysUser2 = sysUsers.stream().filter(e -> e.getUserId().equals(Long.valueOf(leaveAudit.getAuditId().split(",")[1]))) + .findFirst().orElse(null); + // 转化为yyyy-MM-dd 格式字符串 + String leaveTime = startTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd"))+"至"+endTime.format(DateTimeFormatter.ofPattern("yyyy-MM-dd")); + if (sysUser1!=null){ + switch (noticeSet.getNoticeType()) { + case 1: + msgUtils.sendMsg5(sysUser1.getPhonenumber(),sysUser1.getNickName(),leaveTime); + break; + case 2: + if (StringUtils.hasLength(email.getDataContent())&&StringUtils.hasLength(code.getDataContent())){ + EmailUtils.sendEmail(sysUser1.getEmail(),email.getDataContent(),code.getDataContent(),sysUser1.getNickName()+"的请假申请已审核,请查收"); + } + break; + case 3: + break; + } + } + TNotice tNotice1 = new TNotice(); tNotice1.setUserId(leaveAudit.getAuditId().split(",")[1]); tNotice1.setNoticeContent(sysUser.getNickName()+"的请假申请已审核,请查收"); @@ -745,6 +889,20 @@ tNotice1.setDataId(dto.getId()); tNotice1.setNoticeType(7); noticeService.save(tNotice1); + if (sysUser2!=null) { + switch (noticeSet.getNoticeType()) { + case 1: + msgUtils.sendMsg5(sysUser2.getPhonenumber(), sysUser2.getNickName(), leaveTime); + break; + case 2: + if (StringUtils.hasLength(email.getDataContent()) && StringUtils.hasLength(code.getDataContent())) { + EmailUtils.sendEmail(sysUser2.getEmail(), email.getDataContent(), code.getDataContent(), sysUser2.getNickName() + "的请假申请已审核,请查收"); + } + break; + case 3: + break; + } + } return R.ok(); } -- Gitblit v1.7.1