From 9ec2cafd50b513787b5bbbef16009191b184f35a Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期五, 28 三月 2025 19:28:33 +0800 Subject: [PATCH] bug修改 --- medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysDepartmentServiceImpl.java | 51 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 51 insertions(+), 0 deletions(-) diff --git a/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysDepartmentServiceImpl.java b/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysDepartmentServiceImpl.java index c2c1014..6fc2758 100644 --- a/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysDepartmentServiceImpl.java +++ b/medicalWaste-system/src/main/java/com/sinata/system/service/impl/SysDepartmentServiceImpl.java @@ -1,5 +1,6 @@ package com.sinata.system.service.impl; +import com.alibaba.fastjson2.JSONArray; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; @@ -12,6 +13,14 @@ import com.sinata.common.utils.SecurityUtils; import com.sinata.common.utils.StringUtils; import com.sinata.system.domain.MwApplication; +import com.sinata.system.domain.MwContract; +import com.sinata.system.domain.MwMicroEquipment; +import com.sinata.system.domain.MwProtectionEquipment; +import com.sinata.system.domain.MwProtectionRegulation; +import com.sinata.system.domain.MwProtectionTask; +import com.sinata.system.domain.MwStagingRoom; +import com.sinata.system.domain.MwTransitCar; +import com.sinata.system.domain.MwTransitRoute; import com.sinata.system.domain.SysDepartment; import com.sinata.system.domain.SysDepartmentInfo; import com.sinata.system.domain.dto.DisposalUnitDTO; @@ -26,6 +35,15 @@ import com.sinata.system.enums.DepartmentEnum; import com.sinata.system.mapper.SysDepartmentMapper; import com.sinata.system.service.ISysUserService; +import com.sinata.system.service.MwApplicationService; +import com.sinata.system.service.MwContractService; +import com.sinata.system.service.MwMicroEquipmentService; +import com.sinata.system.service.MwProtectionEquipmentService; +import com.sinata.system.service.MwProtectionRegulationService; +import com.sinata.system.service.MwProtectionTaskService; +import com.sinata.system.service.MwStagingRoomService; +import com.sinata.system.service.MwTransitCarService; +import com.sinata.system.service.MwTransitRouteService; import com.sinata.system.service.SysDepartmentInfoService; import com.sinata.system.service.SysDepartmentService; import com.sinata.system.service.SysUserDepartmentService; @@ -61,6 +79,16 @@ private final RedisTemplate<Object, Object> redisTemplate; private final SysDepartmentInfoService sysDepartmentInfoService; private final ISysUserService sysUserService; + + private final MwApplicationService mwApplicationService; + private final MwContractService mwContractService; + private final MwMicroEquipmentService mwMicroEquipmentService; + private final MwProtectionEquipmentService mwProtectionEquipmentService; + private final MwProtectionTaskService mwProtectionTaskService; + private final MwProtectionRegulationService mwProtectionRegulationService; + private final MwStagingRoomService mwStagingRoomService; + private final MwTransitCarService mwTransitCarService; + private final MwTransitRouteService mwTransitRouteService; /** * 获取区域树 * @return @@ -629,6 +657,8 @@ sysDepartmentInfo.setDepartmentId(department.getId()); sysDepartmentInfo.setId(null); sysDepartmentInfoService.save(sysDepartmentInfo); + //处理层级关系 + handleRelation(sysDepartment, parent, dto.getRelation()); } /** @@ -759,6 +789,26 @@ sysDepartmentInfo.setId(null); sysDepartmentInfo.setDepartmentId(department.getId()); sysDepartmentInfoService.save(sysDepartmentInfo); + //如果修改了所属区域 + handleRelation(sysDepartment, parent, dto.getRelation()); + } + + private void handleRelation(SysDepartment sysDepartment, SysDepartment parent, String relation) { + if (!sysDepartment.getParentId().equals(parent.getId())) { + List<Long> relationList = Arrays.stream(relation.split(",")).map(Long::valueOf).collect(Collectors.toList()); + relationList.add(sysDepartment.getId()); + relation = JSONArray.toJSONString(relationList); + //同步该单位所属器具的层级 + mwApplicationService.lambdaUpdate().set(MwApplication::getRelation, relation).eq(MwApplication::getDepartmentId, sysDepartment.getId()).update(); + mwContractService.lambdaUpdate().set(MwContract::getRelation, relation).eq(MwContract::getDepartmentId, sysDepartment.getId()).update(); + mwMicroEquipmentService.lambdaUpdate().set(MwMicroEquipment::getRelation, relation).eq(MwMicroEquipment::getDepartmentId, sysDepartment.getId()).update(); + mwProtectionEquipmentService.lambdaUpdate().set(MwProtectionEquipment::getRelation, relation).eq(MwProtectionEquipment::getDepartmentId, sysDepartment.getId()).update(); + mwProtectionTaskService.lambdaUpdate().set(MwProtectionTask::getRelation, relation).eq(MwProtectionTask::getDepartmentId, sysDepartment.getId()).update(); + mwProtectionRegulationService.lambdaUpdate().set(MwProtectionRegulation::getRelation, relation).eq(MwProtectionRegulation::getDepartmentId, sysDepartment.getId()).update(); + mwStagingRoomService.lambdaUpdate().set(MwStagingRoom::getRelation, relation).eq(MwStagingRoom::getDepartmentId, sysDepartment.getId()).update(); + mwTransitCarService.lambdaUpdate().set(MwTransitCar::getRelation, relation).eq(MwTransitCar::getDepartmentId, sysDepartment.getId()).update(); + mwTransitRouteService.lambdaUpdate().set(MwTransitRoute::getRelation, relation).eq(MwTransitRoute::getDepartmentId, sysDepartment.getId()).update(); + } } /** @@ -879,6 +929,7 @@ department.setRegion(region); } updateById(department); + handleRelation(sysDepartment, parent, dto.getRelation()); } /** -- Gitblit v1.7.1