物资领料逻辑修改 app人员管理接口
This commit is contained in:
		| @ -50,6 +50,19 @@ public class SubConstructionUserAppController { | |||||||
|         return R.ok(constructionUserService.getVo(constructionUser)); |         return R.ok(constructionUserService.getVo(constructionUser)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 根据用户id查询施工人员信息 | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/user/{userId}") | ||||||
|  |     public R<SubConstructionUserVo> queryByUserId(@NotNull(message = "用户主键不能为空") | ||||||
|  |                                                   @PathVariable Long userId) { | ||||||
|  |         SubConstructionUser constructionUser = constructionUserService.getBySysUserId(userId); | ||||||
|  |         if (constructionUser == null) { | ||||||
|  |             return R.fail("查询施工人员不存在"); | ||||||
|  |         } | ||||||
|  |         return R.ok(constructionUserService.getVo(constructionUser)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 根据id查询施工人员信息 |      * 根据id查询施工人员信息 | ||||||
|      */ |      */ | ||||||
|  | |||||||
| @ -0,0 +1,38 @@ | |||||||
|  | package org.dromara.contractor.controller.app; | ||||||
|  |  | ||||||
|  | import jakarta.annotation.Resource; | ||||||
|  | import org.dromara.common.core.domain.R; | ||||||
|  | import org.dromara.common.web.core.BaseController; | ||||||
|  | import org.dromara.contractor.domain.dto.constructionuserfile.SubConstructionUserFileQueryReq; | ||||||
|  | import org.dromara.contractor.domain.vo.constructionuserfile.SubConstructionUserFileVo; | ||||||
|  | import org.dromara.contractor.service.ISubConstructionUserFileService; | ||||||
|  | import org.springframework.validation.annotation.Validated; | ||||||
|  | import org.springframework.web.bind.annotation.GetMapping; | ||||||
|  | import org.springframework.web.bind.annotation.RequestMapping; | ||||||
|  | import org.springframework.web.bind.annotation.RestController; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 施工人员文件存储 app 接口 | ||||||
|  |  * | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025-09-02 17:20 | ||||||
|  |  */ | ||||||
|  | @Validated | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/app/contractor/constructionUserFile") | ||||||
|  | public class SubConstructionUserFileAppController extends BaseController { | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private ISubConstructionUserFileService constructionUserFileService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询施工人员文件存储列表 | ||||||
|  |      */ | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public R<List<SubConstructionUserFileVo>> list(SubConstructionUserFileQueryReq req) { | ||||||
|  |         return R.ok(constructionUserFileService.queryList(req)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -15,11 +15,6 @@ public class SubConstructionUserFileQueryReq implements Serializable { | |||||||
|     @Serial |     @Serial | ||||||
|     private static final long serialVersionUID = 552027602186820020L; |     private static final long serialVersionUID = 552027602186820020L; | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 主键id |  | ||||||
|      */ |  | ||||||
|     private Long id; |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 用户id |      * 用户id | ||||||
|      */ |      */ | ||||||
| @ -30,9 +25,4 @@ public class SubConstructionUserFileQueryReq implements Serializable { | |||||||
|      */ |      */ | ||||||
|     private String fileType; |     private String fileType; | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 备注 |  | ||||||
|      */ |  | ||||||
|     private String remark; |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -58,6 +58,11 @@ public class SubConstructionUserVo implements Serializable { | |||||||
|     @ExcelProperty(value = "项目id") |     @ExcelProperty(value = "项目id") | ||||||
|     private Long projectId; |     private Long projectId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目名称 | ||||||
|  |      */ | ||||||
|  |     private String projectName; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 分包公司id |      * 分包公司id | ||||||
|      */ |      */ | ||||||
|  | |||||||
| @ -17,21 +17,20 @@ import org.dromara.common.core.utils.DateUtils; | |||||||
| import org.dromara.common.core.utils.ObjectUtils; | import org.dromara.common.core.utils.ObjectUtils; | ||||||
| import org.dromara.common.core.utils.StringUtils; | import org.dromara.common.core.utils.StringUtils; | ||||||
| import org.dromara.common.core.utils.file.FileUtils; | import org.dromara.common.core.utils.file.FileUtils; | ||||||
| import org.dromara.common.satoken.utils.LoginHelper; |  | ||||||
| import org.dromara.contractor.domain.SubConstructionUserFile; |  | ||||||
| import org.dromara.contractor.constant.SubConstructionUserConstant; | import org.dromara.contractor.constant.SubConstructionUserConstant; | ||||||
| import org.dromara.project.domain.BusConstructionBlacklist; |  | ||||||
| import org.dromara.contractor.domain.SubConstructionUser; | import org.dromara.contractor.domain.SubConstructionUser; | ||||||
| import org.dromara.project.domain.BusProject; | import org.dromara.contractor.domain.SubConstructionUserFile; | ||||||
| import org.dromara.contractor.domain.dto.constructionuserfile.SubConstructionUserFileQueryReq; | import org.dromara.contractor.domain.dto.constructionuserfile.SubConstructionUserFileQueryReq; | ||||||
| import org.dromara.contractor.domain.dto.constructionuserfile.SubConstructionUserFileReq; | import org.dromara.contractor.domain.dto.constructionuserfile.SubConstructionUserFileReq; | ||||||
| import org.dromara.contractor.domain.dto.constructionuserfile.SubConstructionUserFileSaveReq; | import org.dromara.contractor.domain.dto.constructionuserfile.SubConstructionUserFileSaveReq; | ||||||
| import org.dromara.contractor.domain.dto.constructionuserfile.SubConstructionUserFileTemplateReq; | import org.dromara.contractor.domain.dto.constructionuserfile.SubConstructionUserFileTemplateReq; | ||||||
| import org.dromara.contractor.domain.vo.constructionuserfile.SubConstructionUserFileVo; | import org.dromara.contractor.domain.vo.constructionuserfile.SubConstructionUserFileVo; | ||||||
| import org.dromara.contractor.mapper.SubConstructionUserFileMapper; | import org.dromara.contractor.mapper.SubConstructionUserFileMapper; | ||||||
| import org.dromara.project.service.IBusConstructionBlacklistService; |  | ||||||
| import org.dromara.contractor.service.ISubConstructionUserFileService; | import org.dromara.contractor.service.ISubConstructionUserFileService; | ||||||
| import org.dromara.contractor.service.ISubConstructionUserService; | import org.dromara.contractor.service.ISubConstructionUserService; | ||||||
|  | import org.dromara.project.domain.BusConstructionBlacklist; | ||||||
|  | import org.dromara.project.domain.BusProject; | ||||||
|  | import org.dromara.project.service.IBusConstructionBlacklistService; | ||||||
| import org.dromara.project.service.IBusProjectService; | import org.dromara.project.service.IBusProjectService; | ||||||
| import org.dromara.system.domain.vo.SysDictDataVo; | import org.dromara.system.domain.vo.SysDictDataVo; | ||||||
| import org.dromara.system.domain.vo.SysOssVo; | import org.dromara.system.domain.vo.SysOssVo; | ||||||
| @ -132,7 +131,7 @@ public class SubConstructionUserFileServiceImpl extends ServiceImpl<SubConstruct | |||||||
|             zipOut.closeEntry(); |             zipOut.closeEntry(); | ||||||
|             // 7. 对每个人,创建其文件夹,再在其中创建子文件夹(如“三级安全教育”、“体检报告”...)及文件 |             // 7. 对每个人,创建其文件夹,再在其中创建子文件夹(如“三级安全教育”、“体检报告”...)及文件 | ||||||
|             for (SubConstructionUser constructionUser : constructionUserList) { |             for (SubConstructionUser constructionUser : constructionUserList) { | ||||||
|                 String personFolder = rootFolder + constructionUser.getUserName() + "-" + constructionUser.getId() + "/"; |                 String personFolder = rootFolder + constructionUser.getUserName() + "-" + constructionUser.getSysUserId() + "/"; | ||||||
|                 // 7.1. 写入个人文件夹条目 |                 // 7.1. 写入个人文件夹条目 | ||||||
|                 zipOut.putNextEntry(new ZipEntry(personFolder)); |                 zipOut.putNextEntry(new ZipEntry(personFolder)); | ||||||
|                 zipOut.closeEntry(); |                 zipOut.closeEntry(); | ||||||
| @ -316,18 +315,16 @@ public class SubConstructionUserFileServiceImpl extends ServiceImpl<SubConstruct | |||||||
|             throw new ServiceException("施工人员文件存储参数错误", HttpStatus.BAD_REQUEST); |             throw new ServiceException("施工人员文件存储参数错误", HttpStatus.BAD_REQUEST); | ||||||
|         } |         } | ||||||
|         // 校验修改用户是否存在 |         // 校验修改用户是否存在 | ||||||
|         SubConstructionUser constructionUser = constructionUserService.getById(userId); |         SubConstructionUser constructionUser = constructionUserService.getBySysUserId(userId); | ||||||
|         if (constructionUser == null) { |         if (constructionUser == null) { | ||||||
|             throw new ServiceException("施工人员不存在", HttpStatus.NOT_FOUND); |             throw new ServiceException("施工人员不存在", HttpStatus.NOT_FOUND); | ||||||
|         } |         } | ||||||
|         // 判断登录用户是否有用户所在项目的操作权限 |  | ||||||
|         Long projectId = constructionUser.getProjectId(); |  | ||||||
|         Long loginUser = LoginHelper.getUserId(); |  | ||||||
|         projectService.validAuth(projectId, loginUser); |  | ||||||
|         // 2. 查询当前用户的所有文件记录(一次性查询,避免多次访问数据库) |         // 2. 查询当前用户的所有文件记录(一次性查询,避免多次访问数据库) | ||||||
|         LambdaQueryWrapper<SubConstructionUserFile> lqw = Wrappers.lambdaQuery(SubConstructionUserFile.class) |         LambdaQueryWrapper<SubConstructionUserFile> lqw = Wrappers.lambdaQuery(SubConstructionUserFile.class) | ||||||
|             .eq(SubConstructionUserFile::getUserId, userId); |             .eq(SubConstructionUserFile::getUserId, userId); | ||||||
|         List<SubConstructionUserFile> constructionUserFileList = this.list(lqw); |         List<SubConstructionUserFile> constructionUserFileList = this.lambdaQuery() | ||||||
|  |             .eq(SubConstructionUserFile::getUserId, userId) | ||||||
|  |             .list(); | ||||||
|         // 3. 构建 Map<fileType, BusConstructionUserFile> 方便查找 |         // 3. 构建 Map<fileType, BusConstructionUserFile> 方便查找 | ||||||
|         Map<String, SubConstructionUserFile> existingFileMap = constructionUserFileList.stream() |         Map<String, SubConstructionUserFile> existingFileMap = constructionUserFileList.stream() | ||||||
|             .collect(Collectors.toMap(SubConstructionUserFile::getFileType, Function.identity())); |             .collect(Collectors.toMap(SubConstructionUserFile::getFileType, Function.identity())); | ||||||
| @ -392,14 +389,9 @@ public class SubConstructionUserFileServiceImpl extends ServiceImpl<SubConstruct | |||||||
|         if (req == null) { |         if (req == null) { | ||||||
|             return lqw; |             return lqw; | ||||||
|         } |         } | ||||||
|         Long id = req.getId(); |  | ||||||
|         Long userId = req.getUserId(); |         Long userId = req.getUserId(); | ||||||
|         String fileType = req.getFileType(); |         String fileType = req.getFileType(); | ||||||
|         String remark = req.getRemark(); |  | ||||||
|         // 模糊查询 |  | ||||||
|         lqw.like(StringUtils.isNotBlank(remark), SubConstructionUserFile::getRemark, remark); |  | ||||||
|         // 精确查询 |         // 精确查询 | ||||||
|         lqw.eq(ObjectUtils.isNotEmpty(id), SubConstructionUserFile::getId, id); |  | ||||||
|         lqw.eq(ObjectUtils.isNotEmpty(userId), SubConstructionUserFile::getUserId, userId); |         lqw.eq(ObjectUtils.isNotEmpty(userId), SubConstructionUserFile::getUserId, userId); | ||||||
|         lqw.eq(StringUtils.isNotBlank(fileType), SubConstructionUserFile::getFileType, fileType); |         lqw.eq(StringUtils.isNotBlank(fileType), SubConstructionUserFile::getFileType, fileType); | ||||||
|         return lqw; |         return lqw; | ||||||
| @ -440,7 +432,7 @@ public class SubConstructionUserFileServiceImpl extends ServiceImpl<SubConstruct | |||||||
|             .eq(BusConstructionBlacklist::getProjectId, projectId) |             .eq(BusConstructionBlacklist::getProjectId, projectId) | ||||||
|             .list().stream().map(BusConstructionBlacklist::getUserId).toList(); |             .list().stream().map(BusConstructionBlacklist::getUserId).toList(); | ||||||
|         if (CollUtil.isNotEmpty(blacklistUserIdList)) { |         if (CollUtil.isNotEmpty(blacklistUserIdList)) { | ||||||
|             lqw.notIn(SubConstructionUser::getId, blacklistUserIdList); |             lqw.notIn(SubConstructionUser::getSysUserId, blacklistUserIdList); | ||||||
|         } |         } | ||||||
|         return lqw; |         return lqw; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -646,6 +646,11 @@ public class SubConstructionUserServiceImpl extends ServiceImpl<SubConstructionU | |||||||
|             return constructionUserVo; |             return constructionUserVo; | ||||||
|         } |         } | ||||||
|         BeanUtils.copyProperties(constructionUser, constructionUserVo); |         BeanUtils.copyProperties(constructionUser, constructionUserVo); | ||||||
|  |         // 关联项目名称 | ||||||
|  |         Long projectId = constructionUser.getProjectId(); | ||||||
|  |         if (projectId != null) { | ||||||
|  |             constructionUserVo.setProjectName(projectService.getById(projectId).getProjectName()); | ||||||
|  |         } | ||||||
|         // 关联查询分包公司信息信息 |         // 关联查询分包公司信息信息 | ||||||
|         Long contractorId = constructionUser.getContractorId(); |         Long contractorId = constructionUser.getContractorId(); | ||||||
|         if (contractorId != null) { |         if (contractorId != null) { | ||||||
| @ -657,7 +662,6 @@ public class SubConstructionUserServiceImpl extends ServiceImpl<SubConstructionU | |||||||
|             constructionUserVo.setFacePicUrl(ossService.getById(Long.parseLong(facePic)).getUrl()); |             constructionUserVo.setFacePicUrl(ossService.getById(Long.parseLong(facePic)).getUrl()); | ||||||
|         } |         } | ||||||
|         // 关联查询薪水标准 |         // 关联查询薪水标准 | ||||||
|         Long projectId = constructionUser.getProjectId(); |  | ||||||
|         String typeOfWork = constructionUser.getTypeOfWork(); |         String typeOfWork = constructionUser.getTypeOfWork(); | ||||||
|         String wageMeasureUnit = constructionUser.getWageMeasureUnit(); |         String wageMeasureUnit = constructionUser.getWageMeasureUnit(); | ||||||
|         if (projectId != null && StringUtils.isNotEmpty(typeOfWork) && StringUtils.isNotEmpty(wageMeasureUnit)) { |         if (projectId != null && StringUtils.isNotEmpty(typeOfWork) && StringUtils.isNotEmpty(wageMeasureUnit)) { | ||||||
| @ -739,7 +743,7 @@ public class SubConstructionUserServiceImpl extends ServiceImpl<SubConstructionU | |||||||
|             List<Long> blackUserIdList = constructionBlacklistService.queryIdListByProjectId(projectId); |             List<Long> blackUserIdList = constructionBlacklistService.queryIdListByProjectId(projectId); | ||||||
|             // 查询结果移除黑名单人员 |             // 查询结果移除黑名单人员 | ||||||
|             if (CollUtil.isNotEmpty(blackUserIdList)) { |             if (CollUtil.isNotEmpty(blackUserIdList)) { | ||||||
|                 lqw.notIn(SubConstructionUser::getId, blackUserIdList); |                 lqw.notIn(SubConstructionUser::getSysUserId, blackUserIdList); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         lqw.ne(StringUtils.isNotBlank(notUserRole), SubConstructionUser::getUserRole, notUserRole); |         lqw.ne(StringUtils.isNotBlank(notUserRole), SubConstructionUser::getUserRole, notUserRole); | ||||||
| @ -887,7 +891,7 @@ public class SubConstructionUserServiceImpl extends ServiceImpl<SubConstructionU | |||||||
|         List<Long> blackUserIdList = constructionBlacklistService.queryIdListByProjectId(projectId); |         List<Long> blackUserIdList = constructionBlacklistService.queryIdListByProjectId(projectId); | ||||||
|         // 查询结果移除黑名单人员 |         // 查询结果移除黑名单人员 | ||||||
|         if (CollUtil.isNotEmpty(blackUserIdList)) { |         if (CollUtil.isNotEmpty(blackUserIdList)) { | ||||||
|             lqw.notIn(SubConstructionUser::getId, blackUserIdList); |             lqw.notIn(SubConstructionUser::getSysUserId, blackUserIdList); | ||||||
|         } |         } | ||||||
|         // 分页查询获取数据 |         // 分页查询获取数据 | ||||||
|         Page<SubConstructionUser> constructionUserPage = this.page(pageQuery.build(), lqw); |         Page<SubConstructionUser> constructionUserPage = this.page(pageQuery.build(), lqw); | ||||||
|  | |||||||
| @ -84,6 +84,11 @@ public class MatMaterialsInventory extends BaseEntity { | |||||||
|      */ |      */ | ||||||
|     private String shipper; |     private String shipper; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 是否领用(0未领用 1已领用) | ||||||
|  |      */ | ||||||
|  |     private String isReceive; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 备注 |      * 备注 | ||||||
|      */ |      */ | ||||||
|  | |||||||
| @ -0,0 +1,23 @@ | |||||||
|  | package org.dromara.materials.domain.enums; | ||||||
|  |  | ||||||
|  | import lombok.Getter; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025-09-02 15:47 | ||||||
|  |  */ | ||||||
|  | @Getter | ||||||
|  | public enum MatMaterialsInventoryReceiveStatusEnum { | ||||||
|  |  | ||||||
|  |     NOT("未领用", "0"), | ||||||
|  |     USED("已领用", "1"); | ||||||
|  |  | ||||||
|  |     private final String text; | ||||||
|  |  | ||||||
|  |     private final String value; | ||||||
|  |  | ||||||
|  |     MatMaterialsInventoryReceiveStatusEnum(String text, String value) { | ||||||
|  |         this.text = text; | ||||||
|  |         this.value = value; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -1,10 +1,13 @@ | |||||||
| package org.dromara.materials.domain.vo.materials; | package org.dromara.materials.domain.vo.materials; | ||||||
|  |  | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
|  | import org.dromara.materials.domain.vo.materialsinventory.MatMaterialsInventoryOutVo; | ||||||
|  |  | ||||||
| import java.io.Serial; | import java.io.Serial; | ||||||
| import java.io.Serializable; | import java.io.Serializable; | ||||||
| import java.math.BigDecimal; | import java.math.BigDecimal; | ||||||
|  | import java.util.Date; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * @author lilemy |  * @author lilemy | ||||||
| @ -40,4 +43,14 @@ public class MatMaterialsNumberVo implements Serializable { | |||||||
|      * 库存数量 |      * 库存数量 | ||||||
|      */ |      */ | ||||||
|     private BigDecimal inventoryNumber; |     private BigDecimal inventoryNumber; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 创建时间 | ||||||
|  |      */ | ||||||
|  |     private Date createTime; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出库列表 | ||||||
|  |      */ | ||||||
|  |     private List<MatMaterialsInventoryOutVo> outList; | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,34 @@ | |||||||
|  | package org.dromara.materials.domain.vo.materialsinventory; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | import java.io.Serial; | ||||||
|  | import java.io.Serializable; | ||||||
|  | import java.util.Date; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @author lilemy | ||||||
|  |  * @date 2025-09-02 15:29 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | public class MatMaterialsInventoryOutVo implements Serializable { | ||||||
|  |  | ||||||
|  |     @Serial | ||||||
|  |     private static final long serialVersionUID = -5887469045010555290L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 出/入库的数量 | ||||||
|  |      */ | ||||||
|  |     private Long number; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 剩余库存数量(记录最后一次操作留下的库存数) | ||||||
|  |      */ | ||||||
|  |     private Long residue; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 创建时间 | ||||||
|  |      */ | ||||||
|  |     private Date createTime; | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -36,7 +36,6 @@ import org.dromara.materials.domain.dto.materialissue.MatMaterialIssueUpdateReq; | |||||||
| import org.dromara.materials.domain.dto.materialissue.MatMaterialIssueWordDto; | import org.dromara.materials.domain.dto.materialissue.MatMaterialIssueWordDto; | ||||||
| import org.dromara.materials.domain.dto.materialissueitem.MatMaterialIssueItemDto; | import org.dromara.materials.domain.dto.materialissueitem.MatMaterialIssueItemDto; | ||||||
| import org.dromara.materials.domain.dto.materialissueitem.MatMaterialIssueItemWordDto; | import org.dromara.materials.domain.dto.materialissueitem.MatMaterialIssueItemWordDto; | ||||||
| import org.dromara.materials.domain.enums.MatMaterialsInventoryOutPutEnum; |  | ||||||
| import org.dromara.materials.domain.vo.materialissue.MatMaterialIssueVo; | import org.dromara.materials.domain.vo.materialissue.MatMaterialIssueVo; | ||||||
| import org.dromara.materials.domain.vo.materialsinventory.MatMaterialsInventoryListVo; | import org.dromara.materials.domain.vo.materialsinventory.MatMaterialsInventoryListVo; | ||||||
| import org.dromara.materials.mapper.MatMaterialIssueMapper; | import org.dromara.materials.mapper.MatMaterialIssueMapper; | ||||||
| @ -260,13 +259,15 @@ public class MatMaterialIssueServiceImpl extends ServiceImpl<MatMaterialIssueMap | |||||||
|                 BeanUtils.copyProperties(item, materialIssueItem); |                 BeanUtils.copyProperties(item, materialIssueItem); | ||||||
|                 materialIssueItem.setIssueId(materialIssue.getId()); |                 materialIssueItem.setIssueId(materialIssue.getId()); | ||||||
|                 materialIssueItem.setProjectId(materialIssue.getProjectId()); |                 materialIssueItem.setProjectId(materialIssue.getProjectId()); | ||||||
|  |                 // 截取名称 | ||||||
|  |                 materialIssueItem.setName(item.getName().split("_")[0]); | ||||||
|                 return materialIssueItem; |                 return materialIssueItem; | ||||||
|             }).toList(); |             }).toList(); | ||||||
|             boolean result = materialIssueItemService.saveBatch(materialIssueItemList); |             boolean result = materialIssueItemService.saveBatch(materialIssueItemList); | ||||||
|             if (!result) { |             if (!result) { | ||||||
|                 throw new ServiceException("物料领料单明细项新增失败", HttpStatus.ERROR); |                 throw new ServiceException("物料领料单明细项新增失败", HttpStatus.ERROR); | ||||||
|             } |             } | ||||||
|             // 创建设备材料出库记录 | /*            // 创建设备材料出库记录 | ||||||
|             List<MatMaterialsInventory> inventoryList = itemList.stream().map(item -> { |             List<MatMaterialsInventory> inventoryList = itemList.stream().map(item -> { | ||||||
|                 MatMaterialsInventory inventory = new MatMaterialsInventory(); |                 MatMaterialsInventory inventory = new MatMaterialsInventory(); | ||||||
|                 inventory.setNumber(item.getIssuedQuantity().longValue()); |                 inventory.setNumber(item.getIssuedQuantity().longValue()); | ||||||
| @ -284,7 +285,7 @@ public class MatMaterialIssueServiceImpl extends ServiceImpl<MatMaterialIssueMap | |||||||
|             boolean saved = materialsInventoryService.saveBatch(inventoryList); |             boolean saved = materialsInventoryService.saveBatch(inventoryList); | ||||||
|             if (!saved) { |             if (!saved) { | ||||||
|                 throw new ServiceException("物料出库记录新增失败", HttpStatus.ERROR); |                 throw new ServiceException("物料出库记录新增失败", HttpStatus.ERROR); | ||||||
|             } |             }*/ | ||||||
|         } |         } | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -26,10 +26,12 @@ import org.dromara.materials.domain.dto.materials.MatMaterialsQueryReq; | |||||||
| import org.dromara.materials.domain.dto.materials.MatMaterialsUpdateReq; | import org.dromara.materials.domain.dto.materials.MatMaterialsUpdateReq; | ||||||
| import org.dromara.materials.domain.dto.materialsinventory.MatMaterialsInventoryCreateReq; | import org.dromara.materials.domain.dto.materialsinventory.MatMaterialsInventoryCreateReq; | ||||||
| import org.dromara.materials.domain.enums.MatMaterialsInventoryOutPutEnum; | import org.dromara.materials.domain.enums.MatMaterialsInventoryOutPutEnum; | ||||||
|  | import org.dromara.materials.domain.enums.MatMaterialsInventoryReceiveStatusEnum; | ||||||
| import org.dromara.materials.domain.vo.materials.MatMaterialsByFormCodeVo; | import org.dromara.materials.domain.vo.materials.MatMaterialsByFormCodeVo; | ||||||
| import org.dromara.materials.domain.vo.materials.MatMaterialsGisVo; | import org.dromara.materials.domain.vo.materials.MatMaterialsGisVo; | ||||||
| import org.dromara.materials.domain.vo.materials.MatMaterialsNumberVo; | import org.dromara.materials.domain.vo.materials.MatMaterialsNumberVo; | ||||||
| import org.dromara.materials.domain.vo.materials.MatMaterialsVo; | import org.dromara.materials.domain.vo.materials.MatMaterialsVo; | ||||||
|  | import org.dromara.materials.domain.vo.materialsinventory.MatMaterialsInventoryOutVo; | ||||||
| import org.dromara.materials.mapper.MatMaterialsMapper; | import org.dromara.materials.mapper.MatMaterialsMapper; | ||||||
| import org.dromara.materials.service.IMatCompanyService; | import org.dromara.materials.service.IMatCompanyService; | ||||||
| import org.dromara.materials.service.IMatMaterialReceiveService; | import org.dromara.materials.service.IMatMaterialReceiveService; | ||||||
| @ -419,55 +421,74 @@ public class MatMaterialsServiceImpl extends ServiceImpl<MatMaterialsMapper, Mat | |||||||
|             .eq(MatMaterials::getStatus, "0") |             .eq(MatMaterials::getStatus, "0") | ||||||
|             .list(); |             .list(); | ||||||
|         if (CollUtil.isEmpty(materials)) { |         if (CollUtil.isEmpty(materials)) { | ||||||
|             return null; |             return Collections.emptyList(); | ||||||
|         } |         } | ||||||
|  |         // 过滤出有 formCode 的材料 | ||||||
|         List<Long> materialIds = materials.stream() |         List<Long> materialIds = materials.stream() | ||||||
|             .filter(material -> StringUtils.isNotBlank(material.getFormCode())) |             .filter(m -> StringUtils.isNotBlank(m.getFormCode())) | ||||||
|             .map(MatMaterials::getId) |             .map(MatMaterials::getId) | ||||||
|             .toList(); |             .toList(); | ||||||
|         List<MatMaterialsInventory> materialsInventories = materialsInventoryService.selectLatestByMaterialIds(materialIds); |         // 查询最新库存 | ||||||
|         Map<Long, MatMaterialsInventory> inventoryMap = materialsInventories.stream().collect(Collectors.toMap( |         Map<Long, MatMaterialsInventory> inventoryMap = materialsInventoryService | ||||||
|             MatMaterialsInventory::getMaterialsId, |             .selectLatestByMaterialIds(materialIds) | ||||||
|             Function.identity(), |             .stream() | ||||||
|             (a, b) -> a)); |             .collect(Collectors.toMap(MatMaterialsInventory::getMaterialsId, Function.identity(), (a, b) -> a)); | ||||||
|  |         // 查询出库记录 | ||||||
|  |         List<MatMaterialsInventory> outList = materialsInventoryService.lambdaQuery() | ||||||
|  |             .in(MatMaterialsInventory::getMaterialsId, materialIds) | ||||||
|  |             .eq(MatMaterialsInventory::getOutPut, MatMaterialsInventoryOutPutEnum.OUT.getValue()) | ||||||
|  |             .eq(MatMaterialsInventory::getIsReceive, MatMaterialsInventoryReceiveStatusEnum.NOT.getValue()) | ||||||
|  |             .list(); | ||||||
|  |         Map<Long, List<MatMaterialsInventory>> outMap = new HashMap<>(); | ||||||
|  |         if (CollUtil.isNotEmpty(outList)) { | ||||||
|  |             outMap = outList.stream() | ||||||
|  |                 .collect(Collectors.groupingBy(MatMaterialsInventory::getMaterialsId)); | ||||||
|  |         } | ||||||
|  |         Map<Long, List<MatMaterialsInventory>> finalOutMap = outMap; | ||||||
|  |         // 按 formCode 分组 | ||||||
|         Map<String, List<MatMaterials>> formCodeMap = materials.stream() |         Map<String, List<MatMaterials>> formCodeMap = materials.stream() | ||||||
|             .collect(Collectors.groupingBy(MatMaterials::getFormCode)); |             .collect(Collectors.groupingBy(MatMaterials::getFormCode)); | ||||||
|         Set<String> formCodeList = materials.stream().map(MatMaterials::getFormCode).collect(Collectors.toSet()); |         // 查询入库单 | ||||||
|         List<MatMaterialReceive> receiveList = materialReceiveService.lambdaQuery() |         Set<String> formCodeList = formCodeMap.keySet(); | ||||||
|  |         Map<String, MatMaterialReceive> receiveMap = materialReceiveService.lambdaQuery() | ||||||
|             .in(MatMaterialReceive::getFormCode, formCodeList) |             .in(MatMaterialReceive::getFormCode, formCodeList) | ||||||
|             .list(); |             .list() | ||||||
|         Map<String, MatMaterialReceive> receiveMap = receiveList.stream().collect(Collectors.toMap( |             .stream() | ||||||
|             MatMaterialReceive::getFormCode, |             .collect(Collectors.toMap(MatMaterialReceive::getFormCode, Function.identity(), (a, b) -> a)); | ||||||
|             Function.identity(), |  | ||||||
|             (a, b) -> a)); |  | ||||||
|         List<MatMaterialsByFormCodeVo> resultList = new ArrayList<>(); |         List<MatMaterialsByFormCodeVo> resultList = new ArrayList<>(); | ||||||
|         for (Map.Entry<String, List<MatMaterials>> entry : formCodeMap.entrySet()) { |         for (Map.Entry<String, List<MatMaterials>> entry : formCodeMap.entrySet()) { | ||||||
|             String key = entry.getKey(); |             String formCode = entry.getKey(); | ||||||
|             List<MatMaterials> value = entry.getValue(); |             // 过滤库存为 0 的材料 | ||||||
|             List<MatMaterials> list = value.stream().filter(material -> { |             List<MatMaterials> validMaterials = entry.getValue().stream() | ||||||
|                 Long materialId = material.getId(); |                 .filter(m -> { | ||||||
|                 if (inventoryMap.containsKey(materialId)) { |                     MatMaterialsInventory inv = inventoryMap.get(m.getId()); | ||||||
|                     MatMaterialsInventory inventory = inventoryMap.get(materialId); |                     return inv != null && inv.getResidue() > 0; | ||||||
|                     Long residue = inventory.getResidue(); |                 }) | ||||||
|                     return residue > 0; |                 .toList(); | ||||||
|                 } |             if (CollUtil.isEmpty(validMaterials)) { | ||||||
|                 return false; |  | ||||||
|             }).toList(); |  | ||||||
|             if (CollUtil.isEmpty(list)) { |  | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|  |             // 组装结果 | ||||||
|             MatMaterialsByFormCodeVo vo = new MatMaterialsByFormCodeVo(); |             MatMaterialsByFormCodeVo vo = new MatMaterialsByFormCodeVo(); | ||||||
|             vo.setFormCode(key); |             vo.setFormCode(formCode); | ||||||
|             if (receiveMap.containsKey(key)) { |             MatMaterialReceive receive = receiveMap.get(formCode); | ||||||
|                 MatMaterialReceive receive = receiveMap.get(key); |             if (receive != null) { | ||||||
|                 BeanUtils.copyProperties(receive, vo); |                 BeanUtils.copyProperties(receive, vo); | ||||||
|             } |             } | ||||||
|             List<MatMaterialsNumberVo> numberVos = value.stream().map(material -> { |             List<MatMaterialsNumberVo> numberVos = validMaterials.stream().map(m -> { | ||||||
|                 MatMaterialsNumberVo numberVo = new MatMaterialsNumberVo(); |                 MatMaterialsNumberVo numberVo = new MatMaterialsNumberVo(); | ||||||
|                 BeanUtils.copyProperties(material, numberVo); |                 BeanUtils.copyProperties(m, numberVo); | ||||||
|                 Long materialId = material.getId(); |                 MatMaterialsInventory inv = inventoryMap.get(m.getId()); | ||||||
|                 if (inventoryMap.containsKey(materialId)) { |                 if (inv != null) { | ||||||
|                     numberVo.setInventoryNumber(BigDecimal.valueOf(inventoryMap.get(materialId).getNumber())); |                     numberVo.setInventoryNumber(BigDecimal.valueOf(inv.getNumber())); | ||||||
|  |                 } | ||||||
|  |                 if (CollUtil.isNotEmpty(finalOutMap) && finalOutMap.containsKey(m.getId())) { | ||||||
|  |                     List<MatMaterialsInventory> outs = finalOutMap.get(m.getId()); | ||||||
|  |                     numberVo.setOutList(outs.stream().map(out -> { | ||||||
|  |                         MatMaterialsInventoryOutVo outVo = new MatMaterialsInventoryOutVo(); | ||||||
|  |                         BeanUtils.copyProperties(out, outVo); | ||||||
|  |                         return outVo; | ||||||
|  |                     }).toList()); | ||||||
|                 } |                 } | ||||||
|                 return numberVo; |                 return numberVo; | ||||||
|             }).toList(); |             }).toList(); | ||||||
|  | |||||||
| @ -15,11 +15,6 @@ public class BusConstructionBlacklistQueryReq implements Serializable { | |||||||
|     @Serial |     @Serial | ||||||
|     private static final long serialVersionUID = 5638694783769399209L; |     private static final long serialVersionUID = 5638694783769399209L; | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * 主键id |  | ||||||
|      */ |  | ||||||
|     private Long id; |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 项目id |      * 项目id | ||||||
|      */ |      */ | ||||||
|  | |||||||
| @ -1,5 +1,6 @@ | |||||||
| package org.dromara.project.domain.dto.constructionuserexit; | package org.dromara.project.domain.dto.constructionuserexit; | ||||||
|  |  | ||||||
|  | import jakarta.validation.constraints.NotNull; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
|  |  | ||||||
| import java.io.Serial; | import java.io.Serial; | ||||||
| @ -16,8 +17,9 @@ public class BusConstructionUserExitCreateReq implements Serializable { | |||||||
|     private static final long serialVersionUID = -722474400854585360L; |     private static final long serialVersionUID = -722474400854585360L; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 主键id |      * 用户id | ||||||
|      */ |      */ | ||||||
|  |     @NotNull(message = "用户id不能为空") | ||||||
|     private Long userId; |     private Long userId; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|  | |||||||
| @ -4,50 +4,41 @@ import cn.hutool.core.collection.CollUtil; | |||||||
| import cn.hutool.core.collection.CollectionUtil; | import cn.hutool.core.collection.CollectionUtil; | ||||||
| import cn.hutool.json.JSONArray; | import cn.hutool.json.JSONArray; | ||||||
| import cn.hutool.json.JSONUtil; | import cn.hutool.json.JSONUtil; | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import jakarta.annotation.Resource; | import lombok.RequiredArgsConstructor; | ||||||
| import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||||
| import org.dromara.common.core.domain.R; | import org.dromara.common.core.constant.HttpStatus; | ||||||
| import org.dromara.common.core.enums.FormatsType; |  | ||||||
| import org.dromara.common.core.exception.ServiceException; | import org.dromara.common.core.exception.ServiceException; | ||||||
| import org.dromara.common.core.utils.DateUtils; |  | ||||||
| import org.dromara.common.core.utils.MapstructUtils; | import org.dromara.common.core.utils.MapstructUtils; | ||||||
| import org.dromara.common.core.utils.StringUtils; | import org.dromara.common.core.utils.StringUtils; | ||||||
| import org.dromara.common.domain.GeoPoint; | import org.dromara.common.domain.GeoPoint; | ||||||
| import org.dromara.common.mybatis.core.page.TableDataInfo; |  | ||||||
| import org.dromara.common.mybatis.core.page.PageQuery; | import org.dromara.common.mybatis.core.page.PageQuery; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import org.dromara.common.mybatis.core.page.TableDataInfo; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |  | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; |  | ||||||
| import lombok.RequiredArgsConstructor; |  | ||||||
| import org.dromara.common.satoken.utils.LoginHelper; | import org.dromara.common.satoken.utils.LoginHelper; | ||||||
| import org.dromara.common.utils.JSTUtil; | import org.dromara.common.utils.JSTUtil; | ||||||
| import org.dromara.contractor.domain.SubConstructionUser; | import org.dromara.contractor.domain.SubConstructionUser; | ||||||
| import org.dromara.contractor.service.ISubConstructionUserService; | import org.dromara.contractor.service.ISubConstructionUserService; | ||||||
| import org.dromara.project.domain.*; | import org.dromara.project.domain.*; | ||||||
| import org.dromara.project.domain.bo.BusProjectPunchrangeBo; | import org.dromara.project.domain.bo.BusAttendanceBo; | ||||||
| import org.dromara.project.domain.dto.attendance.BusAttendancePunchCardByFaceReq; | import org.dromara.project.domain.dto.attendance.BusAttendancePunchCardByFaceReq; | ||||||
| import org.dromara.project.domain.enums.BusAttendanceClockStatusEnum; | import org.dromara.project.domain.enums.BusAttendanceClockStatusEnum; | ||||||
| import org.dromara.project.domain.enums.BusAttendanceCommuterEnum; | import org.dromara.project.domain.enums.BusAttendanceCommuterEnum; | ||||||
| import org.dromara.project.domain.vo.BusAttendanceRuleVo; | import org.dromara.project.domain.vo.BusAttendanceRuleVo; | ||||||
|  | import org.dromara.project.domain.vo.BusAttendanceVo; | ||||||
| import org.dromara.project.domain.vo.BusMonthAttendanceVo; | import org.dromara.project.domain.vo.BusMonthAttendanceVo; | ||||||
| import org.dromara.project.domain.vo.BusProjectPunchrangeVo; | import org.dromara.project.mapper.BusAttendanceMapper; | ||||||
| import org.dromara.project.service.*; | import org.dromara.project.service.*; | ||||||
| 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.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.dromara.project.domain.bo.BusAttendanceBo; |  | ||||||
| import org.dromara.project.domain.vo.BusAttendanceVo; |  | ||||||
| import org.dromara.project.mapper.BusAttendanceMapper; |  | ||||||
| import org.springframework.web.multipart.MultipartFile; | import org.springframework.web.multipart.MultipartFile; | ||||||
| import org.dromara.common.core.constant.HttpStatus; |  | ||||||
|  |  | ||||||
| import java.time.LocalDate; | import java.time.LocalDate; | ||||||
| import java.time.LocalDateTime; | import java.time.LocalDateTime; | ||||||
| import java.time.LocalTime; | import java.time.LocalTime; | ||||||
| import java.time.ZoneId; |  | ||||||
| import java.time.format.DateTimeFormatter; |  | ||||||
| import java.time.temporal.ChronoUnit; |  | ||||||
| import java.util.*; | import java.util.*; | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
| @ -231,7 +222,7 @@ public class BusAttendanceServiceImpl extends ServiceImpl<BusAttendanceMapper, B | |||||||
|                 throw new ServiceException("当前用户已被禁止打卡", HttpStatus.BAD_REQUEST); |                 throw new ServiceException("当前用户已被禁止打卡", HttpStatus.BAD_REQUEST); | ||||||
|             } |             } | ||||||
|             // 判断用户是否已经被拉黑 |             // 判断用户是否已经被拉黑 | ||||||
|             constructionBlacklistService.validUserInBlacklist(constructionUser.getId(), req.getProjectId()); |             constructionBlacklistService.validUserInBlacklist(constructionUser.getSysUserId(), req.getProjectId()); | ||||||
|  |  | ||||||
|             // 进行人脸比对 |             // 进行人脸比对 | ||||||
|             Boolean result = constructionUserService.faceComparison(file); |             Boolean result = constructionUserService.faceComparison(file); | ||||||
| @ -250,7 +241,7 @@ public class BusAttendanceServiceImpl extends ServiceImpl<BusAttendanceMapper, B | |||||||
|             //确定考勤日期 |             //确定考勤日期 | ||||||
|             LocalDate localDate = calculateAttendanceDate(now, busAttendanceRuleVo); |             LocalDate localDate = calculateAttendanceDate(now, busAttendanceRuleVo); | ||||||
|  |  | ||||||
|             if(leaveService.isLeave(localDate, userId)){ |             if (leaveService.isLeave(localDate, userId)) { | ||||||
|                 throw new ServiceException("当前用户正在请假中", HttpStatus.BAD_REQUEST); |                 throw new ServiceException("当前用户正在请假中", HttpStatus.BAD_REQUEST); | ||||||
|             } |             } | ||||||
|  |  | ||||||
| @ -379,11 +370,11 @@ public class BusAttendanceServiceImpl extends ServiceImpl<BusAttendanceMapper, B | |||||||
|             throw new ServiceException("项目未配置考勤范围", HttpStatus.BAD_REQUEST); |             throw new ServiceException("项目未配置考勤范围", HttpStatus.BAD_REQUEST); | ||||||
|         } |         } | ||||||
|         List<GeoPoint> matchingRange = JSTUtil.findMatchingRange(req.getLat(), req.getLng(), punchRangeList); |         List<GeoPoint> matchingRange = JSTUtil.findMatchingRange(req.getLat(), req.getLng(), punchRangeList); | ||||||
|         return matchingRange !=  null; |         return matchingRange != null; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public List<BusAttendanceVo> getTodayAttendance( Long projectId) { |     public List<BusAttendanceVo> getTodayAttendance(Long projectId) { | ||||||
|  |  | ||||||
|         Long userId = LoginHelper.getUserId(); |         Long userId = LoginHelper.getUserId(); | ||||||
|         BusAttendanceRuleVo busAttendanceRuleVo = attendanceRuleService.queryByProjectId(projectId); |         BusAttendanceRuleVo busAttendanceRuleVo = attendanceRuleService.queryByProjectId(projectId); | ||||||
| @ -397,8 +388,8 @@ public class BusAttendanceServiceImpl extends ServiceImpl<BusAttendanceMapper, B | |||||||
|         LocalDate localDate = calculateAttendanceDate(LocalDateTime.now(), busAttendanceRuleVo); |         LocalDate localDate = calculateAttendanceDate(LocalDateTime.now(), busAttendanceRuleVo); | ||||||
|  |  | ||||||
|         return baseMapper.selectVoList(new LambdaQueryWrapper<BusAttendance>() |         return baseMapper.selectVoList(new LambdaQueryWrapper<BusAttendance>() | ||||||
|                 .eq(BusAttendance::getUserId, userId) |             .eq(BusAttendance::getUserId, userId) | ||||||
|                 .eq(BusAttendance::getClockDate, localDate) |             .eq(BusAttendance::getClockDate, localDate) | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | |||||||
| @ -157,7 +157,7 @@ public class BusConstructionBlacklistServiceImpl extends ServiceImpl<BusConstruc | |||||||
|         if (userId == null) { |         if (userId == null) { | ||||||
|             throw new ServiceException("用户 id 不能为空", HttpStatus.BAD_REQUEST); |             throw new ServiceException("用户 id 不能为空", HttpStatus.BAD_REQUEST); | ||||||
|         } |         } | ||||||
|         SubConstructionUser constructionUser = constructionUserService.getById(userId); |         SubConstructionUser constructionUser = constructionUserService.getBySysUserId(userId); | ||||||
|         if (constructionUser == null) { |         if (constructionUser == null) { | ||||||
|             throw new ServiceException("对应用户不存在", HttpStatus.NOT_FOUND); |             throw new ServiceException("对应用户不存在", HttpStatus.NOT_FOUND); | ||||||
|         } |         } | ||||||
| @ -241,7 +241,6 @@ public class BusConstructionBlacklistServiceImpl extends ServiceImpl<BusConstruc | |||||||
|     @Override |     @Override | ||||||
|     public LambdaQueryWrapper<BusConstructionBlacklist> buildQueryWrapper(BusConstructionBlacklistQueryReq req) { |     public LambdaQueryWrapper<BusConstructionBlacklist> buildQueryWrapper(BusConstructionBlacklistQueryReq req) { | ||||||
|         LambdaQueryWrapper<BusConstructionBlacklist> lqw = new LambdaQueryWrapper<>(); |         LambdaQueryWrapper<BusConstructionBlacklist> lqw = new LambdaQueryWrapper<>(); | ||||||
|         Long id = req.getId(); |  | ||||||
|         Long userId = req.getUserId(); |         Long userId = req.getUserId(); | ||||||
|         Long projectId = req.getProjectId(); |         Long projectId = req.getProjectId(); | ||||||
|         String userName = req.getUserName(); |         String userName = req.getUserName(); | ||||||
| @ -250,7 +249,6 @@ public class BusConstructionBlacklistServiceImpl extends ServiceImpl<BusConstruc | |||||||
|         lqw.like(StringUtils.isNotBlank(userName), BusConstructionBlacklist::getUserName, userName); |         lqw.like(StringUtils.isNotBlank(userName), BusConstructionBlacklist::getUserName, userName); | ||||||
|         lqw.like(StringUtils.isNotBlank(sfzNumber), BusConstructionBlacklist::getSfzNumber, sfzNumber); |         lqw.like(StringUtils.isNotBlank(sfzNumber), BusConstructionBlacklist::getSfzNumber, sfzNumber); | ||||||
|         // 精确查询 |         // 精确查询 | ||||||
|         lqw.eq(ObjectUtils.isNotEmpty(id), BusConstructionBlacklist::getId, id); |  | ||||||
|         lqw.eq(ObjectUtils.isNotEmpty(userId), BusConstructionBlacklist::getUserId, userId); |         lqw.eq(ObjectUtils.isNotEmpty(userId), BusConstructionBlacklist::getUserId, userId); | ||||||
|         lqw.eq(ObjectUtils.isNotEmpty(projectId), BusConstructionBlacklist::getProjectId, projectId); |         lqw.eq(ObjectUtils.isNotEmpty(projectId), BusConstructionBlacklist::getProjectId, projectId); | ||||||
|         return lqw; |         return lqw; | ||||||
|  | |||||||
| @ -2,26 +2,36 @@ package org.dromara.project.service.impl; | |||||||
|  |  | ||||||
| import cn.hutool.core.collection.CollUtil; | import cn.hutool.core.collection.CollUtil; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import jakarta.annotation.Resource; | import jakarta.annotation.Resource; | ||||||
|  | import org.dromara.common.core.constant.HttpStatus; | ||||||
|  | import org.dromara.common.core.exception.ServiceException; | ||||||
| import org.dromara.common.core.utils.ObjectUtils; | import org.dromara.common.core.utils.ObjectUtils; | ||||||
| import org.dromara.common.core.utils.StringUtils; | import org.dromara.common.core.utils.StringUtils; | ||||||
| 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.contractor.domain.SubConstructionUser; | ||||||
|  | import org.dromara.contractor.service.ISubConstructionUserService; | ||||||
| import org.dromara.project.domain.BusConstructionUserExit; | import org.dromara.project.domain.BusConstructionUserExit; | ||||||
|  | import org.dromara.project.domain.BusProjectTeamMember; | ||||||
| import org.dromara.project.domain.dto.constructionuserexit.BusConstructionUserExitCreateReq; | import org.dromara.project.domain.dto.constructionuserexit.BusConstructionUserExitCreateReq; | ||||||
| import org.dromara.project.domain.dto.constructionuserexit.BusConstructionUserExitQueryReq; | import org.dromara.project.domain.dto.constructionuserexit.BusConstructionUserExitQueryReq; | ||||||
| import org.dromara.project.domain.vo.constructionuserexit.BusConstructionUserExitVo; | import org.dromara.project.domain.vo.constructionuserexit.BusConstructionUserExitVo; | ||||||
| import org.dromara.project.mapper.BusConstructionUserExitMapper; | import org.dromara.project.mapper.BusConstructionUserExitMapper; | ||||||
| import org.dromara.project.service.IBusConstructionUserExitService; | import org.dromara.project.service.IBusConstructionUserExitService; | ||||||
|  | import org.dromara.project.service.IBusProjectTeamMemberService; | ||||||
| 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.springframework.beans.BeanUtils; | import org.springframework.beans.BeanUtils; | ||||||
|  | import org.springframework.context.annotation.Lazy; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  | import org.springframework.transaction.annotation.Transactional; | ||||||
|  |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
|  | import java.util.Date; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @ -37,6 +47,13 @@ public class BusConstructionUserExitServiceImpl extends ServiceImpl<BusConstruct | |||||||
|     @Resource |     @Resource | ||||||
|     private ISysOssService ossService; |     private ISysOssService ossService; | ||||||
|  |  | ||||||
|  |     @Lazy | ||||||
|  |     @Resource | ||||||
|  |     private IBusProjectTeamMemberService projectTeamMemberService; | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     private ISubConstructionUserService constructionUserService; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 查询施工人员入场退场记录信息 |      * 查询施工人员入场退场记录信息 | ||||||
|      * |      * | ||||||
| @ -163,8 +180,50 @@ public class BusConstructionUserExitServiceImpl extends ServiceImpl<BusConstruct | |||||||
|      * @return 新增结果 |      * @return 新增结果 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|  |     @Transactional(rollbackFor = Exception.class) | ||||||
|     public Boolean addRecord(BusConstructionUserExitCreateReq req) { |     public Boolean addRecord(BusConstructionUserExitCreateReq req) { | ||||||
|         return null; |         String salaryVoucherFile = req.getSalaryVoucherFile(); | ||||||
|  |         String salaryConfirmationFile = req.getSalaryConfirmationFile(); | ||||||
|  |         if (StringUtils.isAnyBlank(salaryVoucherFile, salaryConfirmationFile)) { | ||||||
|  |             throw new ServiceException("请上传退场文件", HttpStatus.BAD_REQUEST); | ||||||
|  |         } | ||||||
|  |         Long userId = req.getUserId(); | ||||||
|  |         BusProjectTeamMember projectTeamMember = projectTeamMemberService.lambdaQuery() | ||||||
|  |             .eq(BusProjectTeamMember::getMemberId, userId) | ||||||
|  |             .one(); | ||||||
|  |         if (projectTeamMember == null) { | ||||||
|  |             throw new ServiceException("对应项目班组下的成员不存在", HttpStatus.NOT_FOUND); | ||||||
|  |         } | ||||||
|  |         boolean result = projectTeamMemberService.removeById(projectTeamMember.getId()); | ||||||
|  |         if (!result) { | ||||||
|  |             throw new ServiceException("施工人员退场失败,数据库异常", HttpStatus.ERROR); | ||||||
|  |         } | ||||||
|  |         // 将文件信息保存到数据库 | ||||||
|  |         SubConstructionUser constructionUser = constructionUserService.getBySysUserId(userId); | ||||||
|  |         BusConstructionUserExit constructionUserExit = new BusConstructionUserExit(); | ||||||
|  |         constructionUserExit.setProjectId(constructionUser.getProjectId()); | ||||||
|  |         constructionUserExit.setUserId(constructionUser.getId()); | ||||||
|  |         constructionUserExit.setSalaryVoucherFile(salaryVoucherFile); | ||||||
|  |         constructionUserExit.setSalaryConfirmationFile(salaryConfirmationFile); | ||||||
|  |         constructionUserExit.setTeamId(constructionUser.getTeamId()); | ||||||
|  |         constructionUserExit.setSfzNumber(constructionUser.getSfzNumber()); | ||||||
|  |         constructionUserExit.setEntryDate(constructionUser.getEntryDate()); | ||||||
|  |         constructionUserExit.setLeaveDate(new Date()); | ||||||
|  |         constructionUserExit.setRemark(req.getRemark()); | ||||||
|  |         boolean save = this.save(constructionUserExit); | ||||||
|  |         if (!save) { | ||||||
|  |             throw new ServiceException("施工人员退场失败,数据库异常", HttpStatus.ERROR); | ||||||
|  |         } | ||||||
|  |         // 同步修改用户表的team_id字段 | ||||||
|  |         LambdaUpdateWrapper<SubConstructionUser> constructionUserLuw = Wrappers.lambdaUpdate(SubConstructionUser.class) | ||||||
|  |             .eq(SubConstructionUser::getId, constructionUser.getId()) | ||||||
|  |             .set(SubConstructionUser::getTeamId, null) | ||||||
|  |             .set(SubConstructionUser::getLeaveDate, new Date()); | ||||||
|  |         boolean update = constructionUserService.update(constructionUserLuw); | ||||||
|  |         if (!update) { | ||||||
|  |             throw new ServiceException("施工人员退场失败,数据库异常", HttpStatus.ERROR); | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -133,7 +133,7 @@ public class BusProjectTeamMemberServiceImpl extends ServiceImpl<BusProjectTeamM | |||||||
|         Long memberId = projectTeamMember.getMemberId(); |         Long memberId = projectTeamMember.getMemberId(); | ||||||
|         SubConstructionUser constructionUser = constructionUserService.getBySysUserId(memberId); |         SubConstructionUser constructionUser = constructionUserService.getBySysUserId(memberId); | ||||||
|         // 判断用户是否已经被拉黑 |         // 判断用户是否已经被拉黑 | ||||||
|         constructionBlacklistService.validUserInBlacklist(constructionUser.getId(), projectTeamMember.getProjectId()); |         constructionBlacklistService.validUserInBlacklist(constructionUser.getSysUserId(), projectTeamMember.getProjectId()); | ||||||
|         // 判断对应的用户与项目关联是否存在 |         // 判断对应的用户与项目关联是否存在 | ||||||
|         BusProjectTeamMember teamMember = this.getOne(new LambdaQueryWrapper<BusProjectTeamMember>() |         BusProjectTeamMember teamMember = this.getOne(new LambdaQueryWrapper<BusProjectTeamMember>() | ||||||
|             .eq(BusProjectTeamMember::getMemberId, memberId) |             .eq(BusProjectTeamMember::getMemberId, memberId) | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user