优化
This commit is contained in:
		| @ -209,6 +209,30 @@ sms: | |||||||
|       signature: 重庆远界大数据研究院 |       signature: 重庆远界大数据研究院 | ||||||
|       sdk-app-id: 1401018866 |       sdk-app-id: 1401018866 | ||||||
|       template-id: 2491776 |       template-id: 2491776 | ||||||
|  |     config4: | ||||||
|  |       # 质量工单逾期 | ||||||
|  |       supplier: tencent | ||||||
|  |       access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv | ||||||
|  |       access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi | ||||||
|  |       signature: 重庆远界大数据研究院 | ||||||
|  |       sdk-app-id: 1401018866 | ||||||
|  |       template-id: 2534747 | ||||||
|  |     config5: | ||||||
|  |       # 设计图纸 | ||||||
|  |       supplier: tencent | ||||||
|  |       access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv | ||||||
|  |       access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi | ||||||
|  |       signature: 重庆远界大数据研究院 | ||||||
|  |       sdk-app-id: 1401018866 | ||||||
|  |       template-id: 2534750 | ||||||
|  |     config6: | ||||||
|  |       # 安全工单 | ||||||
|  |       supplier: tencent | ||||||
|  |       access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv | ||||||
|  |       access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi | ||||||
|  |       signature: 重庆远界大数据研究院 | ||||||
|  |       sdk-app-id: 1401018866 | ||||||
|  |       template-id: 2534848 | ||||||
|  |  | ||||||
|  |  | ||||||
| --- # 三方授权 | --- # 三方授权 | ||||||
|  | |||||||
| @ -213,6 +213,30 @@ sms: | |||||||
|       signature: 重庆远界大数据研究院 |       signature: 重庆远界大数据研究院 | ||||||
|       sdk-app-id: 1401018866 |       sdk-app-id: 1401018866 | ||||||
|       template-id: 2491776 |       template-id: 2491776 | ||||||
|  |     config4: | ||||||
|  |       # 质量工单逾期 | ||||||
|  |       supplier: tencent | ||||||
|  |       access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv | ||||||
|  |       access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi | ||||||
|  |       signature: 重庆远界大数据研究院 | ||||||
|  |       sdk-app-id: 1401018866 | ||||||
|  |       template-id: 2534747 | ||||||
|  |     config5: | ||||||
|  |       # 设计图纸 | ||||||
|  |       supplier: tencent | ||||||
|  |       access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv | ||||||
|  |       access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi | ||||||
|  |       signature: 重庆远界大数据研究院 | ||||||
|  |       sdk-app-id: 1401018866 | ||||||
|  |       template-id: 2534750 | ||||||
|  |     config6: | ||||||
|  |       # 安全工单 | ||||||
|  |       supplier: tencent | ||||||
|  |       access-key-id: AKIDb3JK5dx4wa0DCxWqvxlKejvysZ3ITVJv | ||||||
|  |       access-key-secret: c5LPFsJI8k7GDxTkoeFj4A1ukQr66rPi | ||||||
|  |       signature: 重庆远界大数据研究院 | ||||||
|  |       sdk-app-id: 1401018866 | ||||||
|  |       template-id: 2534848 | ||||||
|  |  | ||||||
| --- # 三方授权 | --- # 三方授权 | ||||||
| justauth: | justauth: | ||||||
|  | |||||||
| @ -189,6 +189,7 @@ public class ProjectBigScreenServiceImpl implements ProjectBigScreenService { | |||||||
|             if (CollUtil.isNotEmpty(attendancePeopleList)) { |             if (CollUtil.isNotEmpty(attendancePeopleList)) { | ||||||
|                 List<SubConstructionUser> users = constructionUserService.lambdaQuery() |                 List<SubConstructionUser> users = constructionUserService.lambdaQuery() | ||||||
|                     .in(SubConstructionUser::getSysUserId, attendancePeopleList) |                     .in(SubConstructionUser::getSysUserId, attendancePeopleList) | ||||||
|  |                     .isNotNull(SubConstructionUser::getTeamId) | ||||||
|                     .list(); |                     .list(); | ||||||
|                 userTeamMap = users.stream() |                 userTeamMap = users.stream() | ||||||
|                     .collect(Collectors.groupingBy(SubConstructionUser::getTeamId)); |                     .collect(Collectors.groupingBy(SubConstructionUser::getTeamId)); | ||||||
|  | |||||||
| @ -0,0 +1,41 @@ | |||||||
|  | package org.dromara.common.utils; | ||||||
|  |  | ||||||
|  | import lombok.extern.slf4j.Slf4j; | ||||||
|  | import org.dromara.common.core.utils.MessageUtils; | ||||||
|  | import org.dromara.common.sse.dto.SseMessageDto; | ||||||
|  | import org.dromara.common.sse.utils.SseMessageUtils; | ||||||
|  | import org.dromara.sms4j.api.SmsBlend; | ||||||
|  | import org.dromara.sms4j.api.entity.SmsResponse; | ||||||
|  | import org.dromara.sms4j.core.factory.SmsFactory; | ||||||
|  | import org.springframework.scheduling.annotation.Async; | ||||||
|  | import org.springframework.stereotype.Component; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | @Component | ||||||
|  | @Slf4j | ||||||
|  | public class AsyncUtil { | ||||||
|  |  | ||||||
|  |     //发送短信 | ||||||
|  |     @Async | ||||||
|  |     public void sendSms(List<String> mobileList, String config) { | ||||||
|  |         SmsBlend smsBlend = SmsFactory.getSmsBlend(config); | ||||||
|  |         for (String mobile : mobileList) { | ||||||
|  |             SmsResponse smsResponse = smsBlend.sendMessage(mobile, (String) null); | ||||||
|  |             if (!smsResponse.isSuccess()) { | ||||||
|  |                 log.error("验证码短信发送异常 => {}", smsResponse); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     //发送sse | ||||||
|  |     @Async | ||||||
|  |     public void sendSse(List<Long> userId, String message) { | ||||||
|  |         SseMessageDto sseMessageDto = new SseMessageDto(); | ||||||
|  |         sseMessageDto.setUserIds(userId); | ||||||
|  |         sseMessageDto.setMessage(message); | ||||||
|  |         SseMessageUtils.publishMessage(sseMessageDto); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -1510,6 +1510,7 @@ public class SubConstructionUserServiceImpl extends ServiceImpl<SubConstructionU | |||||||
|         lqw.eq(ObjectUtils.isNotEmpty(typeOfWork), SubConstructionUser::getTypeOfWork, typeOfWork); |         lqw.eq(ObjectUtils.isNotEmpty(typeOfWork), SubConstructionUser::getTypeOfWork, typeOfWork); | ||||||
|  |  | ||||||
|         lqw.isNull(SubConstructionUser::getTeamId); |         lqw.isNull(SubConstructionUser::getTeamId); | ||||||
|  |         lqw.eq(SubConstructionUser::getUserRole, "0"); | ||||||
|         if (req.getProjectId() == null) { |         if (req.getProjectId() == null) { | ||||||
|             lqw.isNull(SubConstructionUser::getProjectId); |             lqw.isNull(SubConstructionUser::getProjectId); | ||||||
|         } else { |         } else { | ||||||
|  | |||||||
| @ -651,13 +651,18 @@ public class DesDesignChangeServiceImpl extends ServiceImpl<DesDesignChangeMappe | |||||||
|                 List<DesVolumeFile> list = volumeFileService.list(Wrappers.lambdaQuery(DesVolumeFile.class) |                 List<DesVolumeFile> list = volumeFileService.list(Wrappers.lambdaQuery(DesVolumeFile.class) | ||||||
|                     .in(DesVolumeFile::getType, Arrays.asList(DesVolumeFile.BLUEPRINT, DesVolumeFile.WASTE)) |                     .in(DesVolumeFile::getType, Arrays.asList(DesVolumeFile.BLUEPRINT, DesVolumeFile.WASTE)) | ||||||
|                     .eq(DesVolumeFile::getVolumeCatalogId, volumeCatalog.getDesign()) |                     .eq(DesVolumeFile::getVolumeCatalogId, volumeCatalog.getDesign()) | ||||||
|                     .orderByDesc(DesVolumeFile::getVersion) |                     .last("ORDER BY CAST(SUBSTRING(version, 4) AS DECIMAL(10, 2)) DESC") | ||||||
|                 ); |                 ); | ||||||
|                 String version = "1.0"; |                 String version = "LT-1.0"; | ||||||
|                 if (CollUtil.isNotEmpty(list)) { |                 if (CollUtil.isNotEmpty(list)) { | ||||||
|                     String lastVersion = list.getFirst().getVersion(); |                     String lastVersion = list.getFirst().getVersion(); | ||||||
|                     int majorVersion = (int) Math.floor(Double.parseDouble(lastVersion)) + 1; |                     // 提取版本号数字部分(去除LT-前缀) | ||||||
|                     version = majorVersion + ".0"; |                     String versionNumber = lastVersion; | ||||||
|  |                     if (lastVersion.startsWith("LT-")) { | ||||||
|  |                         versionNumber = lastVersion.substring(3); // 去除"LT-"前缀 | ||||||
|  |                     } | ||||||
|  |                     int majorVersion = (int) Math.floor(Double.parseDouble(versionNumber)) + 1; | ||||||
|  |                     version = "LT-" + majorVersion + ".0"; | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 for (SysOssVo ossVo : ossVoList1) { |                 for (SysOssVo ossVo : ossVoList1) { | ||||||
|  | |||||||
| @ -24,6 +24,7 @@ import org.dromara.common.sse.config.SseProperties; | |||||||
| import org.dromara.common.sse.dto.SeeMessageContentDto; | import org.dromara.common.sse.dto.SeeMessageContentDto; | ||||||
| import org.dromara.common.sse.dto.SseMessageDto; | import org.dromara.common.sse.dto.SseMessageDto; | ||||||
| import org.dromara.common.sse.utils.SseMessageUtils; | import org.dromara.common.sse.utils.SseMessageUtils; | ||||||
|  | import org.dromara.common.utils.AsyncUtil; | ||||||
| import org.dromara.design.domain.DesVolumeCatalog; | import org.dromara.design.domain.DesVolumeCatalog; | ||||||
| import org.dromara.design.domain.DesVolumeFile; | import org.dromara.design.domain.DesVolumeFile; | ||||||
| import org.dromara.design.domain.bo.DesVolumeFileBo; | import org.dromara.design.domain.bo.DesVolumeFileBo; | ||||||
| @ -39,8 +40,11 @@ import org.dromara.design.service.IDesVolumeCatalogService; | |||||||
| import org.dromara.design.service.IDesVolumeFileService; | import org.dromara.design.service.IDesVolumeFileService; | ||||||
| import org.dromara.project.domain.BusProject; | import org.dromara.project.domain.BusProject; | ||||||
| import org.dromara.project.service.IBusProjectService; | import org.dromara.project.service.IBusProjectService; | ||||||
|  | import org.dromara.system.domain.SysUser; | ||||||
| import org.dromara.system.domain.vo.SysOssVo; | import org.dromara.system.domain.vo.SysOssVo; | ||||||
| import org.dromara.system.service.ISysOssService; | import org.dromara.system.service.ISysOssService; | ||||||
|  | import org.dromara.system.service.ISysRoleService; | ||||||
|  | import org.dromara.system.service.ISysUserService; | ||||||
| import org.springframework.beans.BeanUtils; | import org.springframework.beans.BeanUtils; | ||||||
| import org.springframework.context.annotation.Lazy; | import org.springframework.context.annotation.Lazy; | ||||||
| import org.springframework.context.event.EventListener; | import org.springframework.context.event.EventListener; | ||||||
| @ -82,6 +86,16 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
|     @Resource |     @Resource | ||||||
|     private SseProperties sseProperties; |     private SseProperties sseProperties; | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private AsyncUtil asyncUtil; | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private ISysUserService userService; | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private ISysRoleService roleService; | ||||||
|  |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 分页查询卷册文件列表 |      * 分页查询卷册文件列表 | ||||||
|      * |      * | ||||||
| @ -262,15 +276,15 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
|  |  | ||||||
|     private void validUpload(DesVolumeFileCreateReq req) { |     private void validUpload(DesVolumeFileCreateReq req) { | ||||||
|         // 蓝图文件 |         // 蓝图文件 | ||||||
|         if (CollectionUtil.isNotEmpty(req.getFileIds())) { | //        if (CollectionUtil.isNotEmpty(req.getFileIds())) { | ||||||
|             List<DesVolumeFile> existingFiles = baseMapper.selectList(new LambdaQueryWrapper<DesVolumeFile>() | //            List<DesVolumeFile> existingFiles = baseMapper.selectList(new LambdaQueryWrapper<DesVolumeFile>() | ||||||
|                 .eq(DesVolumeFile::getVolumeCatalogId, req.getVolumeCatalogId()) | //                .eq(DesVolumeFile::getVolumeCatalogId, req.getVolumeCatalogId()) | ||||||
|                 .eq(DesVolumeFile::getType, DesVolumeFile.BLUEPRINT) | //                .eq(DesVolumeFile::getType, DesVolumeFile.BLUEPRINT) | ||||||
|                 .orderByDesc(DesVolumeFile::getVersion)); | //                .orderByDesc(DesVolumeFile::getVersion)); | ||||||
|             if (!existingFiles.isEmpty()) { | //            if (!existingFiles.isEmpty()) { | ||||||
|                 throw new ServiceException("蓝图已上传"); | //                throw new ServiceException("蓝图已上传"); | ||||||
|             } | //            } | ||||||
|         } | //        } | ||||||
|         // 过程文件 |         // 过程文件 | ||||||
| //        if (CollectionUtil.isNotEmpty(req.getCancellationIds())) { | //        if (CollectionUtil.isNotEmpty(req.getCancellationIds())) { | ||||||
| //            List<DesVolumeFile> existingFiles = baseMapper.selectList(new LambdaQueryWrapper<DesVolumeFile>() | //            List<DesVolumeFile> existingFiles = baseMapper.selectList(new LambdaQueryWrapper<DesVolumeFile>() | ||||||
| @ -288,17 +302,21 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 处理文件上传 |  | ||||||
|      * |  | ||||||
|      * @param req            请求参数 |  | ||||||
|      * @param fileIds        文件ID列表 |  | ||||||
|      * @param type           文件类型 |  | ||||||
|      * @param desVolumeFiles 文件集合 |  | ||||||
|      */ |  | ||||||
| //    private void processFiles(DesVolumeFileCreateReq req, List<Long> fileIds, String type, List<DesVolumeFile> desVolumeFiles) { | //    private void processFiles(DesVolumeFileCreateReq req, List<Long> fileIds, String type, List<DesVolumeFile> desVolumeFiles) { | ||||||
| //        // 用于记录同一批次中已处理的文件名及对应的版本号 | //        // 用于记录同一批次中的索引 | ||||||
| //        Map<String, String> batchFileVersionMap = new HashMap<>(); | //        int fileIndex = 0; | ||||||
|  | // | ||||||
|  | //        // 先找出数据库中已存在的最高版本号 | ||||||
|  | //        List<DesVolumeFile> existingFilesInDB = baseMapper.selectList(new LambdaQueryWrapper<DesVolumeFile>() | ||||||
|  | //            .eq(DesVolumeFile.PROCESS.equals(type), DesVolumeFile::getType, type) | ||||||
|  | //            .in(DesVolumeFile.BLUEPRINT.equals(type), DesVolumeFile::getType, Arrays.asList(DesVolumeFile.BLUEPRINT, DesVolumeFile.WASTE)) | ||||||
|  | //            .eq(DesVolumeFile::getVolumeCatalogId, req.getVolumeCatalogId()) | ||||||
|  | //           .last("ORDER BY CAST(SUBSTRING(version_str, 4) AS DECIMAL(10, 2)) DESC")); | ||||||
|  | // | ||||||
|  | //        double maxBatchVersion = 0.0; | ||||||
|  | //        if (CollectionUtil.isNotEmpty(existingFilesInDB)) { | ||||||
|  | //            maxBatchVersion = Double.parseDouble(existingFilesInDB.getFirst().getVersion()); | ||||||
|  | //        } | ||||||
| // | // | ||||||
| //        for (Long fileId : fileIds) { | //        for (Long fileId : fileIds) { | ||||||
| //            SysOssVo ossVo = ossService.getById(fileId); | //            SysOssVo ossVo = ossService.getById(fileId); | ||||||
| @ -312,95 +330,60 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
| // | // | ||||||
| //            String fileName = ossVo.getOriginalName(); | //            String fileName = ossVo.getOriginalName(); | ||||||
| // | // | ||||||
| //            // 根据文件类型和文件名判断是否存在文件,存在则版本号往上增 |  | ||||||
| //            List<DesVolumeFile> existingFiles = baseMapper.selectList(new LambdaQueryWrapper<DesVolumeFile>() |  | ||||||
| //                .eq(DesVolumeFile.PROCESS.equals(type),DesVolumeFile::getType, type) |  | ||||||
| //                .in(DesVolumeFile.BLUEPRINT.equals(type),DesVolumeFile::getType, Arrays.asList(DesVolumeFile.BLUEPRINT, DesVolumeFile.WASTE)) |  | ||||||
| //                .eq(DesVolumeFile::getVolumeCatalogId, file.getVolumeCatalogId()) |  | ||||||
| ////                .eq(DesVolumeFile::getFileName, fileName) |  | ||||||
| //                .orderByDesc(DesVolumeFile::getVersion)); |  | ||||||
| // |  | ||||||
| //            String versionStr = "1.0"; // 默认版本号 | //            String versionStr = "1.0"; // 默认版本号 | ||||||
| // | // | ||||||
| //            if (DesVolumeFile.BLUEPRINT.equals(type)) { | //            if (DesVolumeFile.BLUEPRINT.equals(type)) { | ||||||
| //                // 蓝图文件:1.0, 2.0, 3.0... | //                // 蓝图文件:1.0, 2.0, 3.0... | ||||||
| //                if (CollectionUtil.isNotEmpty(existingFiles)) { | //                // 每个文件递增主版本号 | ||||||
| //                    String lastVersion = existingFiles.getFirst().getVersion(); | //                int majorVersion = (int) maxBatchVersion + fileIndex + 1; | ||||||
| //                    int majorVersion = (int) Math.floor(Double.parseDouble(lastVersion)) + 1; | //                versionStr = majorVersion + ".0"; | ||||||
| //                    versionStr = majorVersion + ".0"; |  | ||||||
| //                } |  | ||||||
| //            } else if (DesVolumeFile.PROCESS.equals(type)) { | //            } else if (DesVolumeFile.PROCESS.equals(type)) { | ||||||
| //                // 过程图纸:基于蓝图版本号,如蓝图是1.0,则过程图为1.1, 1.2...1.9, 1.10 | //                // 过程图纸:基于蓝图版本号 | ||||||
| //                // 先查找对应的蓝图文件最新版本 |  | ||||||
| //                List<DesVolumeFile> blueprintFiles = baseMapper.selectList(new LambdaQueryWrapper<DesVolumeFile>() | //                List<DesVolumeFile> blueprintFiles = baseMapper.selectList(new LambdaQueryWrapper<DesVolumeFile>() | ||||||
| //                    .in(DesVolumeFile::getType, Arrays.asList(DesVolumeFile.BLUEPRINT, DesVolumeFile.WASTE)) // 蓝图类型 | //                    .in(DesVolumeFile::getType, Arrays.asList(DesVolumeFile.BLUEPRINT, DesVolumeFile.WASTE)) | ||||||
| //                    .eq(DesVolumeFile::getVolumeCatalogId, file.getVolumeCatalogId()) | //                    .eq(DesVolumeFile::getVolumeCatalogId, req.getVolumeCatalogId()) | ||||||
| ////                    .eq(DesVolumeFile::getFileName, fileName) |  | ||||||
| //                    .orderByDesc(DesVolumeFile::getVersion)); | //                    .orderByDesc(DesVolumeFile::getVersion)); | ||||||
| // | // | ||||||
| //                String blueprintVersion = "0.0"; // 默认蓝图版本 | //                String blueprintVersion = "0.0"; | ||||||
| //                if (CollectionUtil.isNotEmpty(blueprintFiles)) { | //                if (CollectionUtil.isNotEmpty(blueprintFiles)) { | ||||||
| //                    blueprintVersion = blueprintFiles.getFirst().getVersion(); | //                    blueprintVersion = blueprintFiles.getFirst().getVersion(); | ||||||
| //                } | //                } | ||||||
| // | // | ||||||
| //                // 解析蓝图版本号 |  | ||||||
| //                String[] blueprintParts = blueprintVersion.split("\\."); | //                String[] blueprintParts = blueprintVersion.split("\\."); | ||||||
| //                int blueprintMajor = Integer.parseInt(blueprintParts[0]); | //                int blueprintMajor = Integer.parseInt(blueprintParts[0]); | ||||||
| // | // | ||||||
| //                if (CollectionUtil.isNotEmpty(existingFiles)) { | //                // 对于过程图纸,需要基于数据库中已存在的最高版本号来计算 | ||||||
| //                    // 已存在过程图纸,需要递增次版本号 | //                if (CollectionUtil.isNotEmpty(existingFilesInDB) && existingFilesInDB.getFirst().getType().equals(DesVolumeFile.PROCESS)) { | ||||||
| //                    String lastVersion = existingFiles.getFirst().getVersion(); | //                    // 如果数据库中已存在过程图纸,则基于最高版本号递增 | ||||||
| //                    String[] parts = lastVersion.split("\\."); | //                    String lastProcessVersion = existingFilesInDB.getFirst().getVersion(); | ||||||
| //                    int major = Integer.parseInt(parts[0]); | //                    String[] lastParts = lastProcessVersion.split("\\."); | ||||||
| //                    int minor = Integer.parseInt(parts[1]); | //                    int lastMajor = Integer.parseInt(lastParts[0]); | ||||||
|  | //                    int lastMinor = Integer.parseInt(lastParts[1]); | ||||||
| // | // | ||||||
| //                    if (major == blueprintMajor) { | //                    // 如果主版本号相同,则次版本号递增;否则使用蓝图主版本号,次版本号从1开始 | ||||||
| //                        // 同一主版本,次版本号递增 | //                    if (lastMajor == blueprintMajor) { | ||||||
| //                        minor++; | //                        int minorVersion = lastMinor + fileIndex + 1; | ||||||
| //                        versionStr = major + "." + minor; | //                        versionStr = lastMajor + "." + minorVersion; | ||||||
| //                    } else { | //                    } else { | ||||||
| //                        // 不同主版本,使用蓝图的主版本并从1开始 | //                        int minorVersion = fileIndex + 1; | ||||||
| //                        versionStr = blueprintMajor + ".1"; | //                        versionStr = blueprintMajor + "." + minorVersion; | ||||||
| //                    } | //                    } | ||||||
| //                } else { | //                } else { | ||||||
| //                    // 不存在过程图纸,从蓝图版本的.1开始 | //                    // 数据库中没有过程图纸,从蓝图版本的.1开始 | ||||||
| //                    versionStr = blueprintMajor + ".1"; | //                    int minorVersion = fileIndex + 1; | ||||||
|  | //                    versionStr = blueprintMajor + "." + minorVersion; | ||||||
| //                } | //                } | ||||||
| //            } | //            } | ||||||
| // | // | ||||||
| //            // 检查同一批次中是否已存在同名文件 |  | ||||||
| //            if (batchFileVersionMap.containsKey(fileName)) { |  | ||||||
| //                String lastBatchVersion = String.valueOf(batchFileVersionMap.get(fileName)); |  | ||||||
| //                if ( DesVolumeFile.BLUEPRINT.equals(type)) { |  | ||||||
| //                    // 蓝图文件批次处理 |  | ||||||
| //                    int lastMajor = (int) Math.floor(Double.parseDouble(lastBatchVersion)); |  | ||||||
| //                    versionStr = (lastMajor + 1) + ".0"; |  | ||||||
| //                } else if (DesVolumeFile.PROCESS.equals(type)) { |  | ||||||
| //                    // 过程图纸批次处理 |  | ||||||
| //                    String[] currentParts = versionStr.split("\\."); |  | ||||||
| //                    String[] batchParts = lastBatchVersion.split("\\."); |  | ||||||
| // |  | ||||||
| //                    int currentMajor = Integer.parseInt(currentParts[0]); |  | ||||||
| //                    int currentMinor = Integer.parseInt(currentParts[1]); |  | ||||||
| //                    int batchMajor = Integer.parseInt(batchParts[0]); |  | ||||||
| //                    int batchMinor = Integer.parseInt(batchParts[1]); |  | ||||||
| // |  | ||||||
| //                    if (currentMajor == batchMajor) { |  | ||||||
| //                        // 同一主版本,取较大的次版本号+1 |  | ||||||
| //                        int newMinor = Math.max(currentMinor, batchMinor) + 1; |  | ||||||
| //                        versionStr = currentMajor + "." + newMinor; |  | ||||||
| //                    } |  | ||||||
| //                } |  | ||||||
| //            } |  | ||||||
| // |  | ||||||
| //            // 更新批次文件版本映射(存储为字符串形式) |  | ||||||
| //            batchFileVersionMap.put(fileName, versionStr); |  | ||||||
| // |  | ||||||
| //            file.setVersion(versionStr); | //            file.setVersion(versionStr); | ||||||
| //            file.setFileName(fileName); | //            file.setFileName(fileName); | ||||||
| //            desVolumeFiles.add(file); | //            desVolumeFiles.add(file); | ||||||
|  | // | ||||||
|  | //            fileIndex++; | ||||||
| //        } | //        } | ||||||
| //    } | //    } | ||||||
|  |  | ||||||
|  |  | ||||||
|     private void processFiles(DesVolumeFileCreateReq req, List<Long> fileIds, String type, List<DesVolumeFile> desVolumeFiles) { |     private void processFiles(DesVolumeFileCreateReq req, List<Long> fileIds, String type, List<DesVolumeFile> desVolumeFiles) { | ||||||
|         // 用于记录同一批次中的索引 |         // 用于记录同一批次中的索引 | ||||||
|         int fileIndex = 0; |         int fileIndex = 0; | ||||||
| @ -410,13 +393,18 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
|             .eq(DesVolumeFile.PROCESS.equals(type), DesVolumeFile::getType, type) |             .eq(DesVolumeFile.PROCESS.equals(type), DesVolumeFile::getType, type) | ||||||
|             .in(DesVolumeFile.BLUEPRINT.equals(type), DesVolumeFile::getType, Arrays.asList(DesVolumeFile.BLUEPRINT, DesVolumeFile.WASTE)) |             .in(DesVolumeFile.BLUEPRINT.equals(type), DesVolumeFile::getType, Arrays.asList(DesVolumeFile.BLUEPRINT, DesVolumeFile.WASTE)) | ||||||
|             .eq(DesVolumeFile::getVolumeCatalogId, req.getVolumeCatalogId()) |             .eq(DesVolumeFile::getVolumeCatalogId, req.getVolumeCatalogId()) | ||||||
|             .orderByDesc(DesVolumeFile::getVersion)); |             .last("ORDER BY CAST(SUBSTRING(version, 4) AS DECIMAL(10, 2)) DESC")); | ||||||
|  |  | ||||||
|         double maxBatchVersion = 0.0; |         String maxBatchVersion = "0.0"; | ||||||
|         if (CollectionUtil.isNotEmpty(existingFilesInDB)) { |         if (CollectionUtil.isNotEmpty(existingFilesInDB)) { | ||||||
|             maxBatchVersion = Double.parseDouble(existingFilesInDB.getFirst().getVersion()); |             String version = existingFilesInDB.getFirst().getVersion(); | ||||||
|  |             // 提取版本号数字部分(去除前缀) | ||||||
|  |             if (version.contains("-")) { | ||||||
|  |                 maxBatchVersion = version.substring(version.indexOf("-") + 1); | ||||||
|  |             } else { | ||||||
|  |                 maxBatchVersion = version; | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         for (Long fileId : fileIds) { |         for (Long fileId : fileIds) { | ||||||
|             SysOssVo ossVo = ossService.getById(fileId); |             SysOssVo ossVo = ossService.getById(fileId); | ||||||
|             if (ossVo == null) { |             if (ossVo == null) { | ||||||
| @ -432,20 +420,34 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
|             String versionStr = "1.0"; // 默认版本号 |             String versionStr = "1.0"; // 默认版本号 | ||||||
|  |  | ||||||
|             if (DesVolumeFile.BLUEPRINT.equals(type)) { |             if (DesVolumeFile.BLUEPRINT.equals(type)) { | ||||||
|                 // 蓝图文件:1.0, 2.0, 3.0... |                 // 蓝图文件:LT-1.0, LT-1.1, LT-1.2... | ||||||
|                 // 每个文件递增主版本号 |                 double maxVersion = Double.parseDouble(maxBatchVersion); | ||||||
|                 int majorVersion = (int) maxBatchVersion + fileIndex + 1; |                 int majorVersion = (int) Math.floor(maxVersion); | ||||||
|                 versionStr = majorVersion + ".0"; |                 int minorVersion = (int) ((maxVersion - majorVersion) * 10) + fileIndex + 1; | ||||||
|  |  | ||||||
|  |                 // 如果是第一个文件且没有历史版本,则从1.0开始 | ||||||
|  |                 if (fileIndex == 0 && CollectionUtil.isEmpty(existingFilesInDB)) { | ||||||
|  |                     versionStr = "1.0"; | ||||||
|  |                 } else { | ||||||
|  |                     versionStr = majorVersion + "." + minorVersion; | ||||||
|  |                 } | ||||||
|  |                 versionStr = "LT-" + versionStr; | ||||||
|             } else if (DesVolumeFile.PROCESS.equals(type)) { |             } else if (DesVolumeFile.PROCESS.equals(type)) { | ||||||
|                 // 过程图纸:基于蓝图版本号 |                 // 过程图纸:基于蓝图版本号 | ||||||
|                 List<DesVolumeFile> blueprintFiles = baseMapper.selectList(new LambdaQueryWrapper<DesVolumeFile>() |                 List<DesVolumeFile> blueprintFiles = baseMapper.selectList(new LambdaQueryWrapper<DesVolumeFile>() | ||||||
|                     .in(DesVolumeFile::getType, Arrays.asList(DesVolumeFile.BLUEPRINT, DesVolumeFile.WASTE)) |                     .in(DesVolumeFile::getType, Arrays.asList(DesVolumeFile.BLUEPRINT, DesVolumeFile.WASTE)) | ||||||
|                     .eq(DesVolumeFile::getVolumeCatalogId, req.getVolumeCatalogId()) |                     .eq(DesVolumeFile::getVolumeCatalogId, req.getVolumeCatalogId()) | ||||||
|                     .orderByDesc(DesVolumeFile::getVersion)); |                     .last("ORDER BY CAST(SUBSTRING(version, 4) AS DECIMAL(10, 2)) DESC")); | ||||||
|  |  | ||||||
|                 String blueprintVersion = "0.0"; |                 String blueprintVersion = "1.0"; | ||||||
|                 if (CollectionUtil.isNotEmpty(blueprintFiles)) { |                 if (CollectionUtil.isNotEmpty(blueprintFiles)) { | ||||||
|                     blueprintVersion = blueprintFiles.getFirst().getVersion(); |                     String version = blueprintFiles.getFirst().getVersion(); | ||||||
|  |                     // 提取蓝图版本号数字部分 | ||||||
|  |                     if (version.contains("-")) { | ||||||
|  |                         blueprintVersion = version.substring(version.indexOf("-") + 1); | ||||||
|  |                     } else { | ||||||
|  |                         blueprintVersion = version; | ||||||
|  |                     } | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 String[] blueprintParts = blueprintVersion.split("\\."); |                 String[] blueprintParts = blueprintVersion.split("\\."); | ||||||
| @ -455,25 +457,32 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
|                 if (CollectionUtil.isNotEmpty(existingFilesInDB) && existingFilesInDB.getFirst().getType().equals(DesVolumeFile.PROCESS)) { |                 if (CollectionUtil.isNotEmpty(existingFilesInDB) && existingFilesInDB.getFirst().getType().equals(DesVolumeFile.PROCESS)) { | ||||||
|                     // 如果数据库中已存在过程图纸,则基于最高版本号递增 |                     // 如果数据库中已存在过程图纸,则基于最高版本号递增 | ||||||
|                     String lastProcessVersion = existingFilesInDB.getFirst().getVersion(); |                     String lastProcessVersion = existingFilesInDB.getFirst().getVersion(); | ||||||
|                     String[] lastParts = lastProcessVersion.split("\\."); |                     String versionNumber = lastProcessVersion; | ||||||
|  |                     if (lastProcessVersion.contains("-")) { | ||||||
|  |                         versionNumber = lastProcessVersion.substring(lastProcessVersion.indexOf("-") + 1); | ||||||
|  |                     } | ||||||
|  |  | ||||||
|  |                     String[] lastParts = versionNumber.split("\\."); | ||||||
|                     int lastMajor = Integer.parseInt(lastParts[0]); |                     int lastMajor = Integer.parseInt(lastParts[0]); | ||||||
|                     int lastMinor = Integer.parseInt(lastParts[1]); |                     int lastMinor = Integer.parseInt(lastParts[1]); | ||||||
|  |  | ||||||
|                     // 如果主版本号相同,则次版本号递增;否则使用蓝图主版本号,次版本号从1开始 |                     // 如果主版本号相同,则次版本号递增;否则使用蓝图主版本号,次版本号从0开始 | ||||||
|                     if (lastMajor == blueprintMajor) { |                     if (lastMajor == blueprintMajor) { | ||||||
|                         int minorVersion = lastMinor + fileIndex + 1; |                         int minorVersion = lastMinor + fileIndex + 1; | ||||||
|                         versionStr = lastMajor + "." + minorVersion; |                         versionStr = lastMajor + "." + minorVersion; | ||||||
|                     } else { |                     } else { | ||||||
|                         int minorVersion = fileIndex + 1; |                         int minorVersion = fileIndex; | ||||||
|                         versionStr = blueprintMajor + "." + minorVersion; |                         versionStr = blueprintMajor + "." + minorVersion; | ||||||
|                     } |                     } | ||||||
|                 } else { |                 } else { | ||||||
|                     // 数据库中没有过程图纸,从蓝图版本的.1开始 |                     // 数据库中没有过程图纸,从蓝图版本的.0开始 | ||||||
|                     int minorVersion = fileIndex + 1; |                     int minorVersion = fileIndex; | ||||||
|                     versionStr = blueprintMajor + "." + minorVersion; |                     versionStr = blueprintMajor + "." + minorVersion; | ||||||
|                 } |                 } | ||||||
|  |                 versionStr = "GC-" + versionStr; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |  | ||||||
|             file.setVersion(versionStr); |             file.setVersion(versionStr); | ||||||
|             file.setFileName(fileName); |             file.setFileName(fileName); | ||||||
|             desVolumeFiles.add(file); |             desVolumeFiles.add(file); | ||||||
| @ -492,9 +501,9 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
|     @Transactional(rollbackFor = Exception.class) |     @Transactional(rollbackFor = Exception.class) | ||||||
|     public Boolean deleteByIds(Collection<Long> ids) { |     public Boolean deleteByIds(Collection<Long> ids) { | ||||||
|         try { |         try { | ||||||
|             ossService.deleteWithValidByIds(ids,false); |             ossService.deleteWithValidByIds(ids, false); | ||||||
|         }catch (Exception e){ |         } catch (Exception e) { | ||||||
|             log.error("删除卷册文件存储失败",e); |             log.error("删除卷册文件存储失败", e); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return this.removeBatchByIds(ids); |         return this.removeBatchByIds(ids); | ||||||
| @ -565,7 +574,7 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
|     public AuditFileVo auditFile(AuditFileDto dto) { |     public AuditFileVo auditFile(AuditFileDto dto) { | ||||||
|         List<Long> volumeCatalogIds = dto.getVolumeCatalogIds(); |         List<Long> volumeCatalogIds = dto.getVolumeCatalogIds(); | ||||||
|         List<DesVolumeFileVo> desVolumeFileVos = baseMapper.selectVoList(Wrappers.lambdaQuery(DesVolumeFile.class) |         List<DesVolumeFileVo> desVolumeFileVos = baseMapper.selectVoList(Wrappers.lambdaQuery(DesVolumeFile.class) | ||||||
|             .in(CollectionUtil.isNotEmpty(volumeCatalogIds),DesVolumeFile::getVolumeCatalogId, volumeCatalogIds) |             .in(CollectionUtil.isNotEmpty(volumeCatalogIds), DesVolumeFile::getVolumeCatalogId, volumeCatalogIds) | ||||||
|             .eq(DesVolumeFile::getAuditStatus, "draft") |             .eq(DesVolumeFile::getAuditStatus, "draft") | ||||||
|         ); |         ); | ||||||
|         List<DesVolumeFileVo> list1 = desVolumeFileVos.stream().filter(vo -> "1".equals(vo.getType())).toList(); |         List<DesVolumeFileVo> list1 = desVolumeFileVos.stream().filter(vo -> "1".equals(vo.getType())).toList(); | ||||||
| @ -609,6 +618,15 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
|                     log.error("图纸[{}-{}]添加二维码失败", desVolumeFile.getFileName(), desVolumeFile.getId(), ex); |                     log.error("图纸[{}-{}]添加二维码失败", desVolumeFile.getFileName(), desVolumeFile.getId(), ex); | ||||||
|                     return null; |                     return null; | ||||||
|                 }); |                 }); | ||||||
|  |  | ||||||
|  |             //异步发送消息 项目经理 设计部主任(1961028169115197442) | ||||||
|  |             DesVolumeCatalog byId = volumeCatalogService.getById(desVolumeFile.getVolumeCatalogId()); | ||||||
|  |             List<Long> longs = roleService.selectRoleIdsByName("项目经理"); | ||||||
|  |             longs.add(1961028169115197442L); | ||||||
|  |  | ||||||
|  |             List<SysUser> sysUsers = userService.selectUserByRoleIdsAndProjectId(longs, byId.getProjectId()); | ||||||
|  |             asyncUtil.sendSms(sysUsers.stream().map(SysUser::getPhonenumber).toList(), "config5"); | ||||||
|  |             asyncUtil.sendSse(sysUsers.stream().map(SysUser::getUserId).toList(), "有新的蓝图审批完成"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
| @ -672,6 +690,14 @@ public class DesVolumeFileServiceImpl extends ServiceImpl<DesVolumeFileMapper, D | |||||||
|                     log.error("图纸[{}-{}]添加二维码失败", desVolumeFile.getFileName(), desVolumeFile.getId(), ex); |                     log.error("图纸[{}-{}]添加二维码失败", desVolumeFile.getFileName(), desVolumeFile.getId(), ex); | ||||||
|                     return null; |                     return null; | ||||||
|                 }); |                 }); | ||||||
|  |             //异步发送消息 项目经理 设计部主任(1961028169115197442) | ||||||
|  |             DesVolumeCatalog byId = volumeCatalogService.getById(desVolumeFile.getVolumeCatalogId()); | ||||||
|  |             List<Long> longs = roleService.selectRoleIdsByName("项目经理"); | ||||||
|  |             longs.add(1961028169115197442L); | ||||||
|  |  | ||||||
|  |             List<SysUser> sysUsers = userService.selectUserByRoleIdsAndProjectId(longs, byId.getProjectId()); | ||||||
|  |             asyncUtil.sendSms(sysUsers.stream().map(SysUser::getPhonenumber).toList(), "config5"); | ||||||
|  |             asyncUtil.sendSse(sysUsers.stream().map(SysUser::getUserId).toList(), "有新的蓝图审批完成"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -0,0 +1,108 @@ | |||||||
|  | package org.dromara.job.inspection; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import cn.hutool.core.date.DateUtil; | ||||||
|  | import com.aizuda.snailjob.client.job.core.annotation.JobExecutor; | ||||||
|  | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||||
|  | import jakarta.annotation.Resource; | ||||||
|  | import lombok.extern.slf4j.Slf4j; | ||||||
|  | import org.dromara.common.core.domain.R; | ||||||
|  | import org.dromara.project.service.IBusProjectService; | ||||||
|  | import org.dromara.quality.domain.QltQualityInspection; | ||||||
|  | import org.dromara.quality.service.IQltQualityInspectionService; | ||||||
|  | import org.dromara.safety.domain.HseSafetyInspection; | ||||||
|  | import org.dromara.safety.service.IHseSafetyInspectionService; | ||||||
|  | import org.dromara.sms4j.api.SmsBlend; | ||||||
|  | import org.dromara.sms4j.api.entity.SmsResponse; | ||||||
|  | import org.dromara.sms4j.core.factory.SmsFactory; | ||||||
|  | import org.dromara.system.service.ISysUserService; | ||||||
|  | import org.springframework.stereotype.Component; | ||||||
|  |  | ||||||
|  | import java.time.LocalDate; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | @Slf4j | ||||||
|  | @Component | ||||||
|  | public class InspectionJob { | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private IQltQualityInspectionService qltQualityInspectionService; | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private IHseSafetyInspectionService safetyInspectionService; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private ISysUserService userService; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     @JobExecutor(name = "qltInspection") | ||||||
|  |     public void qltInspection() { | ||||||
|  |         log.info("执行定时任务:质量工单短信提醒"); | ||||||
|  |         List<QltQualityInspection> list = qltQualityInspectionService.list(Wrappers.<QltQualityInspection>lambdaQuery() | ||||||
|  |             .eq(QltQualityInspection::getInspectionStatus, "1") | ||||||
|  |             .eq(QltQualityInspection::getIsReply, "1") | ||||||
|  |             .lt(QltQualityInspection::getReplyPeriodDate, LocalDate.now()) | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         SmsBlend smsBlend = SmsFactory.getSmsBlend("config4"); | ||||||
|  |  | ||||||
|  |         // 每500条记录作为一批进行处理 | ||||||
|  |         int batchSize = 500; | ||||||
|  |         for (int i = 0; i < list.size(); i += batchSize) { | ||||||
|  |             int endIndex = Math.min(i + batchSize, list.size()); | ||||||
|  |             List<QltQualityInspection> batch = list.subList(i, endIndex); | ||||||
|  |  | ||||||
|  |             for (QltQualityInspection qualityInspection : batch) { | ||||||
|  |                 Long correctorId = qualityInspection.getCorrectorId(); | ||||||
|  |                 String phonenumber = userService.queryById(correctorId).getPhonenumber(); | ||||||
|  |                 if (phonenumber == null) { | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  |                 SmsResponse smsResponse = smsBlend.sendMessage(phonenumber, (String) null); | ||||||
|  |                 if (!smsResponse.isSuccess()) { | ||||||
|  |                     log.error("验证码短信发送异常 => {}", smsResponse); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             log.info("质量工单短信提醒批次发送完成,当前批次数量: {}", batch.size()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         log.info("执行定时任务:质量工单短信提醒完成,总处理数量: {}", list.size()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @JobExecutor(name = "safeInspection") | ||||||
|  |     public void safeInspection() { | ||||||
|  |         log.info("执行定时任务:安全工单短信提醒"); | ||||||
|  |         List<HseSafetyInspection> list = safetyInspectionService.list(Wrappers.<HseSafetyInspection>lambdaQuery() | ||||||
|  |             .eq(HseSafetyInspection::getStatus, "1") | ||||||
|  |             .eq(HseSafetyInspection::getIsReply, "1") | ||||||
|  |             .lt(HseSafetyInspection::getRectificationDeadline, LocalDate.now()) | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         SmsBlend smsBlend = SmsFactory.getSmsBlend("config6"); | ||||||
|  |  | ||||||
|  |         // 每500条记录作为一批进行处理 | ||||||
|  |         int batchSize = 500; | ||||||
|  |         for (int i = 0; i < list.size(); i += batchSize) { | ||||||
|  |             int endIndex = Math.min(i + batchSize, list.size()); | ||||||
|  |             List<HseSafetyInspection> batch = list.subList(i, endIndex); | ||||||
|  |  | ||||||
|  |             for (HseSafetyInspection safetyInspection : batch) { | ||||||
|  |                 Long correctorId = safetyInspection.getCorrectorId(); | ||||||
|  |                 String phonenumber = userService.queryById(correctorId).getPhonenumber(); | ||||||
|  |                 if (phonenumber == null) { | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  |                 SmsResponse smsResponse = smsBlend.sendMessage(phonenumber, (String) null); | ||||||
|  |                 if (!smsResponse.isSuccess()) { | ||||||
|  |                     log.error("验证码短信发送异常 => {}", smsResponse); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             log.info("安全工单短信提醒批次发送完成,当前批次数量: {}", batch.size()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         log.info("执行定时任务:安全工单短信提醒完成,总处理数量: {}", list.size()); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -11,6 +11,7 @@ import org.dromara.common.satoken.utils.LoginHelper; | |||||||
| import org.dromara.common.web.core.BaseController; | import org.dromara.common.web.core.BaseController; | ||||||
| import org.dromara.contractor.service.ISubConstructionUserService; | import org.dromara.contractor.service.ISubConstructionUserService; | ||||||
| import org.dromara.project.domain.dto.leave.BusLeaveAddReq; | import org.dromara.project.domain.dto.leave.BusLeaveAddReq; | ||||||
|  | import org.dromara.project.domain.dto.leave.BusLeaveAuditDto; | ||||||
| import org.dromara.project.domain.dto.leave.BusLeaveQueryReq; | import org.dromara.project.domain.dto.leave.BusLeaveQueryReq; | ||||||
| import org.dromara.project.domain.dto.reissuecard.BusReissueCardQueryReq; | import org.dromara.project.domain.dto.reissuecard.BusReissueCardQueryReq; | ||||||
| import org.dromara.project.domain.vo.leave.BusLeaveVo; | import org.dromara.project.domain.vo.leave.BusLeaveVo; | ||||||
| @ -45,7 +46,7 @@ public class BusLeaveAppController extends BaseController { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 查询当前登录用户补卡审批列表 |      * 查询当前登录用户请假审批列表 | ||||||
|      */ |      */ | ||||||
|     @GetMapping("/list/auditUser") |     @GetMapping("/list/auditUser") | ||||||
|     public TableDataInfo<BusLeaveVo> listByAuditUser(BusLeaveQueryReq req, PageQuery pageQuery) { |     public TableDataInfo<BusLeaveVo> listByAuditUser(BusLeaveQueryReq req, PageQuery pageQuery) { | ||||||
| @ -55,7 +56,7 @@ public class BusLeaveAppController extends BaseController { | |||||||
|  |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 查询角色补卡审批列表 |      * 查询角色请假审批列表 | ||||||
|      */ |      */ | ||||||
|     @GetMapping("/list/auditRole") |     @GetMapping("/list/auditRole") | ||||||
|     public TableDataInfo<BusLeaveVo> listByAuditRole(BusLeaveQueryReq req, PageQuery pageQuery) { |     public TableDataInfo<BusLeaveVo> listByAuditRole(BusLeaveQueryReq req, PageQuery pageQuery) { | ||||||
| @ -63,8 +64,6 @@ public class BusLeaveAppController extends BaseController { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 提交请假 |      * 提交请假 | ||||||
|      */ |      */ | ||||||
| @ -75,5 +74,14 @@ public class BusLeaveAppController extends BaseController { | |||||||
|         return R.ok(leaveService.add(req)); |         return R.ok(leaveService.add(req)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 审批 | ||||||
|  |      */ | ||||||
|  |     @RepeatSubmit() | ||||||
|  |     @PutMapping() | ||||||
|  |     public R<Boolean> audit(@RequestBody BusLeaveAuditDto dto) { | ||||||
|  |         return R.ok(leaveService.audit(dto)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,15 @@ | |||||||
|  | package org.dromara.project.domain.dto.leave; | ||||||
|  |  | ||||||
|  | import com.alibaba.excel.annotation.ExcelProperty; | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | @Data | ||||||
|  | public class BusLeaveAuditDto { | ||||||
|  |  | ||||||
|  |     private Long id; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 意见(1未读 2同意 3拒绝) | ||||||
|  |      */ | ||||||
|  |     private String gangerOpinion; | ||||||
|  | } | ||||||
| @ -0,0 +1,10 @@ | |||||||
|  | package org.dromara.project.domain.vo.reissuecard; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | @Data | ||||||
|  | public class AuditUserVo { | ||||||
|  |     private Long userId; | ||||||
|  |     private String nickName; | ||||||
|  |     private String avatar; | ||||||
|  | } | ||||||
| @ -7,11 +7,13 @@ import lombok.Data; | |||||||
| import org.dromara.common.excel.annotation.ExcelDictFormat; | import org.dromara.common.excel.annotation.ExcelDictFormat; | ||||||
| import org.dromara.common.excel.convert.ExcelDictConvert; | import org.dromara.common.excel.convert.ExcelDictConvert; | ||||||
| import org.dromara.project.domain.BusReissueCard; | import org.dromara.project.domain.BusReissueCard; | ||||||
|  | import org.dromara.system.domain.vo.SysUserVo; | ||||||
|  |  | ||||||
| import java.io.Serial; | import java.io.Serial; | ||||||
| import java.io.Serializable; | import java.io.Serializable; | ||||||
| import java.time.LocalDateTime; | import java.time.LocalDateTime; | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @ -161,4 +163,15 @@ public class BusReissueCardVo implements Serializable { | |||||||
|      * 补卡类型(1上班 2下班) |      * 补卡类型(1上班 2下班) | ||||||
|      */ |      */ | ||||||
|     private String reissueCardType; |     private String reissueCardType; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 申请人类型(0-施工人员 1-管理人员 2-分包人员) | ||||||
|  |      */ | ||||||
|  |     private String userType; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 审批人列表 | ||||||
|  |      */ | ||||||
|  |     private List<AuditUserVo> auditors; | ||||||
| } | } | ||||||
|  | |||||||
| @ -6,10 +6,7 @@ import com.baomidou.mybatisplus.extension.service.IService; | |||||||
| import org.dromara.common.mybatis.core.page.PageQuery; | import org.dromara.common.mybatis.core.page.PageQuery; | ||||||
| import org.dromara.common.mybatis.core.page.TableDataInfo; | import org.dromara.common.mybatis.core.page.TableDataInfo; | ||||||
| import org.dromara.project.domain.BusLeave; | import org.dromara.project.domain.BusLeave; | ||||||
| import org.dromara.project.domain.dto.leave.BusLeaveAddReq; | import org.dromara.project.domain.dto.leave.*; | ||||||
| import org.dromara.project.domain.dto.leave.BusLeaveGangerReviewReq; |  | ||||||
| import org.dromara.project.domain.dto.leave.BusLeaveManagerReviewReq; |  | ||||||
| import org.dromara.project.domain.dto.leave.BusLeaveQueryReq; |  | ||||||
| import org.dromara.project.domain.dto.reissuecard.BusReissueCardQueryReq; | import org.dromara.project.domain.dto.reissuecard.BusReissueCardQueryReq; | ||||||
| import org.dromara.project.domain.vo.leave.BusLeaveVo; | import org.dromara.project.domain.vo.leave.BusLeaveVo; | ||||||
| import org.dromara.project.domain.vo.reissuecard.BusReissueCardVo; | import org.dromara.project.domain.vo.reissuecard.BusReissueCardVo; | ||||||
| @ -128,6 +125,6 @@ public interface IBusLeaveService extends IService<BusLeave> { | |||||||
|     TableDataInfo<BusLeaveVo> listByAuditRole(BusLeaveQueryReq req, PageQuery pageQuery); |     TableDataInfo<BusLeaveVo> listByAuditRole(BusLeaveQueryReq req, PageQuery pageQuery); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     Boolean  audit(BusLeaveAuditDto dto); | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -592,18 +592,20 @@ public class BusAttendanceServiceImpl extends ServiceImpl<BusAttendanceMapper, B | |||||||
|             .eq(BusUserProjectRelevancy::getProjectId, projectId) |             .eq(BusUserProjectRelevancy::getProjectId, projectId) | ||||||
|             .last("limit 1")); |             .last("limit 1")); | ||||||
|         if (relevancy == null) { |         if (relevancy == null) { | ||||||
|             throw new ServiceException("当前用户未加入项目", HttpStatus.BAD_REQUEST); |             throw new ServiceException("当前用户未加入项目", HttpStatus.ERROR); | ||||||
|         } |         } | ||||||
|         //判断是否是管理员 管理员返回项目全部打卡范围,施工人员返回班组打卡范围 |         SysUserVo sysUserVo = userService.queryById(userId); | ||||||
|         boolean isAdmin = "2".equals(relevancy.getUserType()); |  | ||||||
|  |         //判断是否是施工人员 管理员返回项目全部打卡范围,施工人员返回班组打卡范围 | ||||||
|  |         boolean isWork = "0".equals(sysUserVo.getAppUserType()); | ||||||
|         List<Long> rangeIds = new ArrayList<>(); |         List<Long> rangeIds = new ArrayList<>(); | ||||||
|         if (!isAdmin) { |         if (isWork) { | ||||||
|             BusProjectTeamMember one = projectTeamMemberService.getOne(Wrappers.lambdaQuery(BusProjectTeamMember.class) |             BusProjectTeamMember one = projectTeamMemberService.getOne(Wrappers.lambdaQuery(BusProjectTeamMember.class) | ||||||
|                 .eq(BusProjectTeamMember::getMemberId, userId) |                 .eq(BusProjectTeamMember::getMemberId, userId) | ||||||
|                 .eq(BusProjectTeamMember::getProjectId, projectId) |                 .eq(BusProjectTeamMember::getProjectId, projectId) | ||||||
|                 .last("limit 1")); |                 .last("limit 1")); | ||||||
|             if (one == null) { |             if (one == null) { | ||||||
|                 throw new ServiceException("当前用户未加入班组", HttpStatus.BAD_REQUEST); |                 throw new ServiceException("当前用户未加入班组", HttpStatus.ERROR); | ||||||
|             } |             } | ||||||
|             BusProjectTeam team = projectTeamService.getById(one.getTeamId()); |             BusProjectTeam team = projectTeamService.getById(one.getTeamId()); | ||||||
|             try { |             try { | ||||||
|  | |||||||
| @ -29,12 +29,9 @@ import org.dromara.contractor.domain.SubConstructionUser; | |||||||
| import org.dromara.contractor.service.ISubConstructionUserService; | import org.dromara.contractor.service.ISubConstructionUserService; | ||||||
| import org.dromara.contractor.service.ISubContractorService; | import org.dromara.contractor.service.ISubContractorService; | ||||||
| import org.dromara.project.domain.*; | import org.dromara.project.domain.*; | ||||||
| import org.dromara.project.domain.dto.leave.BusLeaveAddReq; | import org.dromara.project.domain.dto.leave.*; | ||||||
| import org.dromara.project.domain.dto.leave.BusLeaveGangerReviewReq; |  | ||||||
| import org.dromara.project.domain.dto.reissuecard.BusReissueCardQueryReq; | import org.dromara.project.domain.dto.reissuecard.BusReissueCardQueryReq; | ||||||
| import org.dromara.project.domain.enums.*; | import org.dromara.project.domain.enums.*; | ||||||
| import org.dromara.project.domain.dto.leave.BusLeaveManagerReviewReq; |  | ||||||
| import org.dromara.project.domain.dto.leave.BusLeaveQueryReq; |  | ||||||
| import org.dromara.project.domain.vo.leave.BusLeaveVo; | import org.dromara.project.domain.vo.leave.BusLeaveVo; | ||||||
| import org.dromara.project.domain.vo.reissuecard.BusReissueCardVo; | import org.dromara.project.domain.vo.reissuecard.BusReissueCardVo; | ||||||
| import org.dromara.project.mapper.BusLeaveMapper; | import org.dromara.project.mapper.BusLeaveMapper; | ||||||
| @ -391,7 +388,7 @@ public class BusLeaveServiceImpl extends ServiceImpl<BusLeaveMapper, BusLeave> | |||||||
|     public Long add(BusLeaveAddReq req) { |     public Long add(BusLeaveAddReq req) { | ||||||
|         // 1. 转换请求对象 |         // 1. 转换请求对象 | ||||||
|         BusLeave leave = new BusLeave(); |         BusLeave leave = new BusLeave(); | ||||||
|         BeanUtils.copyProperties(leave, req); |         BeanUtils.copyProperties(req, leave); | ||||||
|  |  | ||||||
|         // 2. 获取当前用户ID和时间区间 |         // 2. 获取当前用户ID和时间区间 | ||||||
|         Long userId = req.getUserId(); |         Long userId = req.getUserId(); | ||||||
| @ -483,17 +480,73 @@ public class BusLeaveServiceImpl extends ServiceImpl<BusLeaveMapper, BusLeave> | |||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     @Transactional(rollbackFor = Exception.class) | ||||||
|  |     public Boolean audit(BusLeaveAuditDto dto) { | ||||||
|  |         BusLeave busLeave = baseMapper.selectById(dto.getId()); | ||||||
|  |         if (busLeave == null) { | ||||||
|  |             throw new ServiceException("未找到该申请"); | ||||||
|  |         } | ||||||
|  |         String gangerOpinion = dto.getGangerOpinion(); | ||||||
|  |         busLeave.setGangerOpinion(gangerOpinion); | ||||||
|  |         int i = baseMapper.updateById(busLeave); | ||||||
|  |  | ||||||
|  |         if(gangerOpinion.equals("2")){ | ||||||
|  |             if(busLeave.getTimeType().equals("1")){ | ||||||
|  |                 LocalDateTime startTime = busLeave.getStartTime(); | ||||||
|  |                 LocalDateTime endTime = busLeave.getEndTime(); | ||||||
|  |                 LocalDate startDate = startTime.toLocalDate(); | ||||||
|  |                 LocalDate endDate = endTime.toLocalDate(); | ||||||
|  |  | ||||||
|  |                 List<BusAttendance> list = attendanceService.list(Wrappers.lambdaQuery(BusAttendance.class) | ||||||
|  |                     .eq(BusAttendance::getProjectId, busLeave.getProjectId()) | ||||||
|  |                     .le(BusAttendance::getClockDate, endDate) | ||||||
|  |                     .ge(BusAttendance::getClockDate, startDate) | ||||||
|  |                     .eq(BusAttendance::getUserId, busLeave.getUserId()) | ||||||
|  |                 ); | ||||||
|  |                 for (BusAttendance attendance : list) { | ||||||
|  |                     attendance.setClockStatus(BusAttendanceClockStatusEnum.LATE.getValue()); | ||||||
|  |                 } | ||||||
|  |                 if(!list.isEmpty()){ | ||||||
|  |                     attendanceService.updateBatchById(list); | ||||||
|  |                 } | ||||||
|  |             }else if(busLeave.getTimeType().equals("2")){ | ||||||
|  |                 if(busLeave.getPeriodType().equals("1")){ | ||||||
|  |                     LocalDateTime startTime = busLeave.getStartTime(); | ||||||
|  |                     LocalDate localDate = startTime.toLocalDate(); | ||||||
|  |                     List<BusAttendance> list = attendanceService.list(Wrappers.lambdaQuery(BusAttendance.class) | ||||||
|  |                         .eq(BusAttendance::getProjectId, busLeave.getProjectId()) | ||||||
|  |                         .eq(BusAttendance::getClockDate, localDate) | ||||||
|  |                         .eq(BusAttendance::getClockType, "1") | ||||||
|  |                         .eq(BusAttendance::getUserId, busLeave.getUserId()) | ||||||
|  |                     ); | ||||||
|  |                     for (BusAttendance attendance : list) { | ||||||
|  |                         attendance.setClockStatus(BusAttendanceClockStatusEnum.LATE.getValue()); | ||||||
|  |                     } | ||||||
|  |                     if(!list.isEmpty()){ | ||||||
|  |                         attendanceService.updateBatchById(list); | ||||||
|  |                     } | ||||||
|  |  | ||||||
|  |                 }else if(busLeave.getPeriodType().equals("2")){ | ||||||
|  |                     LocalDateTime endTime = busLeave.getEndTime(); | ||||||
|  |                     LocalDate localDate = endTime.toLocalDate(); | ||||||
|  |                     List<BusAttendance> list = attendanceService.list(Wrappers.lambdaQuery(BusAttendance.class) | ||||||
|  |                         .eq(BusAttendance::getProjectId, busLeave.getProjectId()) | ||||||
|  |                         .eq(BusAttendance::getClockDate, localDate) | ||||||
|  |                         .eq(BusAttendance::getClockType, "2") | ||||||
|  |                         .eq(BusAttendance::getUserId, busLeave.getUserId()) | ||||||
|  |                     ); | ||||||
|  |                     for (BusAttendance attendance : list) { | ||||||
|  |                         attendance.setClockStatus(BusAttendanceClockStatusEnum.LATE.getValue()); | ||||||
|  |                     } | ||||||
|  |                     if(!list.isEmpty()){ | ||||||
|  |                         attendanceService.updateBatchById(list); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return i>0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 总体流程监听(例如: 草稿,撤销,退回,作废,终止,已完成,单任务完成等) |      * 总体流程监听(例如: 草稿,撤销,退回,作废,终止,已完成,单任务完成等) | ||||||
|  | |||||||
| @ -2,6 +2,7 @@ package org.dromara.project.service.impl; | |||||||
|  |  | ||||||
| import cn.hutool.core.bean.BeanUtil; | import cn.hutool.core.bean.BeanUtil; | ||||||
| import cn.hutool.core.collection.CollUtil; | import cn.hutool.core.collection.CollUtil; | ||||||
|  | import cn.hutool.core.collection.CollectionUtil; | ||||||
| import cn.hutool.core.convert.Convert; | import cn.hutool.core.convert.Convert; | ||||||
| import cn.hutool.core.util.StrUtil; | import cn.hutool.core.util.StrUtil; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| @ -34,9 +35,12 @@ import org.dromara.project.domain.enums.BusOpinionStatusEnum; | |||||||
| import org.dromara.project.domain.enums.BusReviewStatusEnum; | import org.dromara.project.domain.enums.BusReviewStatusEnum; | ||||||
| import org.dromara.project.domain.dto.reissuecard.BusReissueCardManagerReviewReq; | import org.dromara.project.domain.dto.reissuecard.BusReissueCardManagerReviewReq; | ||||||
| import org.dromara.project.domain.dto.reissuecard.BusReissueCardQueryReq; | import org.dromara.project.domain.dto.reissuecard.BusReissueCardQueryReq; | ||||||
|  | import org.dromara.project.domain.vo.reissuecard.AuditUserVo; | ||||||
| import org.dromara.project.domain.vo.reissuecard.BusReissueCardVo; | import org.dromara.project.domain.vo.reissuecard.BusReissueCardVo; | ||||||
| import org.dromara.project.mapper.BusReissueCardMapper; | import org.dromara.project.mapper.BusReissueCardMapper; | ||||||
| import org.dromara.project.service.*; | import org.dromara.project.service.*; | ||||||
|  | import org.dromara.system.domain.SysUser; | ||||||
|  | import org.dromara.system.domain.SysUserRole; | ||||||
| import org.dromara.system.domain.vo.SysOssVo; | import org.dromara.system.domain.vo.SysOssVo; | ||||||
| import org.dromara.system.domain.vo.SysUserVo; | import org.dromara.system.domain.vo.SysUserVo; | ||||||
| import org.dromara.system.service.ISysOssService; | import org.dromara.system.service.ISysOssService; | ||||||
| @ -108,13 +112,41 @@ public class BusReissueCardServiceImpl extends ServiceImpl<BusReissueCardMapper, | |||||||
|         } |         } | ||||||
|         BusProject byId = projectService.getById(busReissueCardVo.getProjectId()); |         BusProject byId = projectService.getById(busReissueCardVo.getProjectId()); | ||||||
|         busReissueCardVo.setProjectName(byId.getProjectName()); |         busReissueCardVo.setProjectName(byId.getProjectName()); | ||||||
|  |         String userType = busReissueCardVo.getUserType(); | ||||||
|  |         //两个角色 一个审核分包的=6,一个审核管理的=7 | ||||||
|  |         List<SysUser> sysUsers = new ArrayList<>(); | ||||||
|  |         if("1".equals(userType)){ | ||||||
|  |             sysUsers = userService.selectUserByRoleIdAndProjectId(6L, busReissueCardVo.getProjectId()); | ||||||
|  |         } else if ("2".equals(userType)) { | ||||||
|  |             sysUsers = userService.selectUserByRoleIdAndProjectId(7L, busReissueCardVo.getProjectId()); | ||||||
|  |         }else{ | ||||||
|  |             SysUserVo sysUserVo = userService.selectUserById(busReissueCardVo.getGangerId()); | ||||||
|  |             if(sysUserVo != null){ | ||||||
|  |                 busReissueCardVo.setGangerName(sysUserVo.getNickName()); | ||||||
|  |                 if(sysUserVo.getAvatar() != null){ | ||||||
|  |                     SysOssVo byId1 = ossService.getById(sysUserVo.getAvatar()); | ||||||
|  |                     if(byId1 != null){ | ||||||
|  |                         busReissueCardVo.setAvatar(byId1.getUrl()); | ||||||
|  |                     } | ||||||
|  |  | ||||||
|         SysUserVo sysUserVo = userService.selectUserById(busReissueCardVo.getGangerId()); |                 } | ||||||
|         busReissueCardVo.setGangerName(sysUserVo.getNickName()); |             } | ||||||
|         if(sysUserVo.getAvatar() != null){ |  | ||||||
|             SysOssVo byId1 = ossService.getById(sysUserVo.getAvatar()); |  | ||||||
|             busReissueCardVo.setAvatar(byId1.getUrl()); |  | ||||||
|         } |         } | ||||||
|  |         if(CollectionUtil.isNotEmpty(sysUsers)){ | ||||||
|  |             busReissueCardVo.setAuditors(sysUsers.stream().map(sysUser -> { | ||||||
|  |                 AuditUserVo userVo = new AuditUserVo(); | ||||||
|  |                 userVo.setUserId(sysUser.getUserId()); | ||||||
|  |                 userVo.setNickName(sysUser.getNickName()); | ||||||
|  |                 if(sysUser.getAvatar() != null){ | ||||||
|  |                     SysOssVo byId1 = ossService.getById(sysUser.getAvatar()); | ||||||
|  |                     if(byId1 != null){ | ||||||
|  |                         userVo.setAvatar(byId1.getUrl()); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 return userVo; | ||||||
|  |             }).collect(Collectors.toList())); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|         return busReissueCardVo; |         return busReissueCardVo; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -64,6 +64,8 @@ import java.util.concurrent.CompletableFuture; | |||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
| import java.util.zip.ZipOutputStream; | import java.util.zip.ZipOutputStream; | ||||||
|  |  | ||||||
|  | import static org.dromara.common.core.constant.TenantConstants.SUPER_ADMIN_ID; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 安全巡检工单Service业务层处理 |  * 安全巡检工单Service业务层处理 | ||||||
|  * |  * | ||||||
| @ -519,7 +521,7 @@ public class HseSafetyInspectionServiceImpl extends ServiceImpl<HseSafetyInspect | |||||||
|         Long correctorId = safetyInspection.getCorrectorId(); |         Long correctorId = safetyInspection.getCorrectorId(); | ||||||
|         // 只有指定用户可以整改 |         // 只有指定用户可以整改 | ||||||
|         Long userId = LoginHelper.getUserId(); |         Long userId = LoginHelper.getUserId(); | ||||||
|         if (!correctorId.equals(userId)) { |         if (!correctorId.equals(userId) && !SUPER_ADMIN_ID.equals(userId)) { | ||||||
|             throw new ServiceException("当前用户不是指定整改人", HttpStatus.BAD_REQUEST); |             throw new ServiceException("当前用户不是指定整改人", HttpStatus.BAD_REQUEST); | ||||||
|         } |         } | ||||||
|         HseSafetyInspection updateInspection = new HseSafetyInspection(); |         HseSafetyInspection updateInspection = new HseSafetyInspection(); | ||||||
| @ -534,7 +536,6 @@ public class HseSafetyInspectionServiceImpl extends ServiceImpl<HseSafetyInspect | |||||||
|                 } |                 } | ||||||
|             }); |             }); | ||||||
|  |  | ||||||
|  |  | ||||||
|         } |         } | ||||||
|         // 填充默认值 |         // 填充默认值 | ||||||
|         updateInspection.setId(id); |         updateInspection.setId(id); | ||||||
|  | |||||||
| @ -218,4 +218,7 @@ public interface ISysRoleService { | |||||||
|  |  | ||||||
|  |  | ||||||
|     List<Long> selectRoleIdsByUserIdAndProjectId(Long userId,Long projectId); |     List<Long> selectRoleIdsByUserIdAndProjectId(Long userId,Long projectId); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     List<Long> selectRoleIdsByName(String roleName); | ||||||
| } | } | ||||||
|  | |||||||
| @ -276,4 +276,8 @@ public interface ISysUserService { | |||||||
|     List<SysUserVo> selectUserListByAppUserType(String appUserType,Long projectId,Long contractorId); |     List<SysUserVo> selectUserListByAppUserType(String appUserType,Long projectId,Long contractorId); | ||||||
|  |  | ||||||
|     Boolean updateFb(Long userId,Long contractorId); |     Boolean updateFb(Long userId,Long contractorId); | ||||||
|  |  | ||||||
|  |     List<SysUser> selectUserByRoleIdAndProjectId(Long roleId,Long projectId); | ||||||
|  |  | ||||||
|  |     List<SysUser> selectUserByRoleIdsAndProjectId(List<Long> roleIds,Long projectId); | ||||||
| } | } | ||||||
|  | |||||||
| @ -653,4 +653,11 @@ public class SysRoleServiceImpl implements ISysRoleService, RoleService { | |||||||
|         } |         } | ||||||
|         return List.of(); |         return List.of(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<Long> selectRoleIdsByName(String roleName) { | ||||||
|  |         return baseMapper.selectList(Wrappers.lambdaQuery(SysRole.class) | ||||||
|  |             .eq(SysRole::getRoleName, roleName) | ||||||
|  |         ).stream().map(SysRole::getRoleId).toList(); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -940,6 +940,17 @@ public class SysUserServiceImpl implements ISysUserService, UserService { | |||||||
|         } |         } | ||||||
|         userRoleMapper.insertBatch(sysUserRoles); |         userRoleMapper.insertBatch(sysUserRoles); | ||||||
|  |  | ||||||
|  |         if(CollectionUtil.isNotEmpty(projectIds)){ | ||||||
|  |             List<BusUserProjectRelevancy> relevancies = new ArrayList<>(); | ||||||
|  |             for (Long project : projectIds) { | ||||||
|  |                 BusUserProjectRelevancy relevancy = new BusUserProjectRelevancy(); | ||||||
|  |                 relevancy.setProjectId(project); | ||||||
|  |                 relevancy.setUserId(userId); | ||||||
|  |                 relevancies.add(relevancy); | ||||||
|  |             } | ||||||
|  |             userProjectRelevancyService.saveBatch(relevancies); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         return baseMapper.update(null, |         return baseMapper.update(null, | ||||||
|             new LambdaUpdateWrapper<SysUser>() |             new LambdaUpdateWrapper<SysUser>() | ||||||
|                 .set(SysUser::getAppUserType, appUserType) |                 .set(SysUser::getAppUserType, appUserType) | ||||||
| @ -1226,6 +1237,41 @@ public class SysUserServiceImpl implements ISysUserService, UserService { | |||||||
|         return baseMapper.updateById(sysUser)>0; |         return baseMapper.updateById(sysUser)>0; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<SysUser> selectUserByRoleIdAndProjectId(Long roleId, Long projectId) { | ||||||
|  |  | ||||||
|  |         List<SysUserRole> sysUserRoles = userRoleMapper.selectList(Wrappers.lambdaQuery(SysUserRole.class) | ||||||
|  |             .eq(SysUserRole::getRoleId, roleId) | ||||||
|  |             .eq(SysUserRole::getProjectId, projectId) | ||||||
|  |         ); | ||||||
|  |         List<Long> list1 = sysUserRoles.stream().map(SysUserRole::getUserId).toList(); | ||||||
|  |         if (CollUtil.isNotEmpty(list1)) { | ||||||
|  |             return baseMapper.selectList(new LambdaQueryWrapper<SysUser>() | ||||||
|  |                 .select(SysUser::getUserId,  SysUser::getNickName, SysUser::getAvatar,SysUser::getPhonenumber) | ||||||
|  |                 .eq(SysUser::getStatus, SystemConstants.NORMAL) | ||||||
|  |                 .in(SysUser::getUserId, list1) | ||||||
|  |             ); | ||||||
|  |         } | ||||||
|  |         return List.of(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<SysUser> selectUserByRoleIdsAndProjectId(List<Long> roleIds, Long projectId) { | ||||||
|  |         List<SysUserRole> sysUserRoles = userRoleMapper.selectList(Wrappers.lambdaQuery(SysUserRole.class) | ||||||
|  |             .in(SysUserRole::getRoleId, roleIds) | ||||||
|  |             .eq(SysUserRole::getProjectId, projectId) | ||||||
|  |         ); | ||||||
|  |         List<Long> list1 = sysUserRoles.stream().map(SysUserRole::getUserId).toList(); | ||||||
|  |         if (CollUtil.isNotEmpty(list1)) { | ||||||
|  |             return baseMapper.selectList(new LambdaQueryWrapper<SysUser>() | ||||||
|  |                 .select(SysUser::getUserId,  SysUser::getNickName, SysUser::getAvatar,SysUser::getPhonenumber) | ||||||
|  |                 .eq(SysUser::getStatus, SystemConstants.NORMAL) | ||||||
|  |                 .in(SysUser::getUserId, list1) | ||||||
|  |             ); | ||||||
|  |         } | ||||||
|  |         return List.of(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public UserDTO selectUser(Long userId) { |     public UserDTO selectUser(Long userId) { | ||||||
|  |  | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 zt
					zt