优化部门父级启用状态
This commit is contained in:
		
							parent
							
								
									2ace3257f9
								
							
						
					
					
						commit
						a3116cd27d
					
				| @ -94,11 +94,11 @@ public interface SysDeptMapper | ||||
|     public int updateDept(SysDept dept); | ||||
| 
 | ||||
|     /** | ||||
|      * 修改所在部门的父级部门状态 | ||||
|      * 修改所在部门正常状态 | ||||
|      *  | ||||
|      * @param dept 部门 | ||||
|      * @param deptIds 部门ID组 | ||||
|      */ | ||||
|     public void updateDeptStatus(SysDept dept); | ||||
|     public void updateDeptStatusNormal(Long[] deptIds); | ||||
| 
 | ||||
|     /** | ||||
|      * 修改子元素关系 | ||||
|  | ||||
| @ -11,6 +11,7 @@ import com.ruoyi.common.constant.UserConstants; | ||||
| import com.ruoyi.common.core.domain.TreeSelect; | ||||
| import com.ruoyi.common.core.domain.entity.SysDept; | ||||
| import com.ruoyi.common.core.domain.entity.SysRole; | ||||
| import com.ruoyi.common.core.text.Convert; | ||||
| import com.ruoyi.common.exception.CustomException; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import com.ruoyi.system.mapper.SysDeptMapper; | ||||
| @ -211,7 +212,7 @@ public class SysDeptServiceImpl implements ISysDeptService | ||||
|         if (UserConstants.DEPT_NORMAL.equals(dept.getStatus())) | ||||
|         { | ||||
|             // 如果该部门是启用状态,则启用该部门的所有上级部门 | ||||
|             updateParentDeptStatus(dept); | ||||
|             updateParentDeptStatusNormal(dept); | ||||
|         } | ||||
|         return result; | ||||
|     } | ||||
| @ -221,12 +222,11 @@ public class SysDeptServiceImpl implements ISysDeptService | ||||
|      *  | ||||
|      * @param dept 当前部门 | ||||
|      */ | ||||
|     private void updateParentDeptStatus(SysDept dept) | ||||
|     private void updateParentDeptStatusNormal(SysDept dept) | ||||
|     { | ||||
|         String updateBy = dept.getUpdateBy(); | ||||
|         dept = deptMapper.selectDeptById(dept.getDeptId()); | ||||
|         dept.setUpdateBy(updateBy); | ||||
|         deptMapper.updateDeptStatus(dept); | ||||
|         String ancestors = dept.getAncestors(); | ||||
|         Long[] deptIds = Convert.toLongArray(ancestors); | ||||
|         deptMapper.updateDeptStatusNormal(deptIds); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|  | ||||
| @ -140,14 +140,11 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
| 	    </foreach> | ||||
| 	</update> | ||||
| 	  | ||||
| 	 <update id="updateDeptStatus" parameterType="SysDept"> | ||||
|  	    update sys_dept | ||||
|  	    <set> | ||||
|  	        <if test="status != null and status != ''">status = #{status},</if> | ||||
|  	        <if test="updateBy != null and updateBy != ''">update_by = #{updateBy},</if> | ||||
|  	        update_time = sysdate() | ||||
|         </set> | ||||
|  	    where find_in_set(#{deptId}, ancestors) | ||||
| 	 <update id="updateDeptStatusNormal" parameterType="Long"> | ||||
|  	    update sys_dept set status = '0' where dept_id in  | ||||
|  	    <foreach collection="array" item="deptId" open="(" separator="," close=")"> | ||||
|         	#{deptId} | ||||
|         </foreach> | ||||
| 	</update> | ||||
| 	 | ||||
| 	<delete id="deleteDeptById" parameterType="Long"> | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 RuoYi
						RuoYi