|
@@ -1,13 +1,12 @@
|
|
|
package com.usky.dxtop.service.impl;
|
|
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
-import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
-import com.usky.dxtop.common.enums.BusinessStatus;
|
|
|
import com.usky.dxtop.common.exception.CustomException;
|
|
|
import com.usky.dxtop.mapper.StaffRadioMapper;
|
|
|
+import com.usky.dxtop.model.Dept;
|
|
|
import com.usky.dxtop.model.Staff;
|
|
|
import com.usky.dxtop.model.StaffRadio;
|
|
|
import com.usky.dxtop.service.DeptService;
|
|
@@ -16,6 +15,7 @@ import com.usky.dxtop.service.StaffService;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
|
+import java.util.ArrayList;
|
|
|
import java.util.List;
|
|
|
import java.util.Map;
|
|
|
import java.util.stream.Collectors;
|
|
@@ -34,6 +34,9 @@ public class StaffRadioServiceImpl extends ServiceImpl<StaffRadioMapper, StaffRa
|
|
|
@Autowired
|
|
|
private StaffService staffService;
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private DeptService deptService;
|
|
|
+
|
|
|
@Override
|
|
|
public void addList(List<StaffRadio> list) {
|
|
|
if (CollectionUtils.isEmpty(list)){
|
|
@@ -59,12 +62,25 @@ public class StaffRadioServiceImpl extends ServiceImpl<StaffRadioMapper, StaffRa
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public boolean addListByDept(Long deptId, Boolean isBinding,Long radioId) {
|
|
|
- LambdaQueryWrapper<Staff> staffLambdaQueryWrapper = Wrappers.lambdaQuery();
|
|
|
- staffLambdaQueryWrapper
|
|
|
- .select(Staff::getSId)
|
|
|
- .eq(Staff::getDeptId,deptId);
|
|
|
- List<Long> list = staffService.list(staffLambdaQueryWrapper).stream().map(Staff::getSId).collect(Collectors.toList());
|
|
|
+ public boolean addListByDept(Long deptId, Boolean isBinding,Long radioId,Boolean isRe) {
|
|
|
+ List<Long> list;
|
|
|
+ if (isRe){
|
|
|
+ List<Long> deptIdList = new ArrayList<>();
|
|
|
+ List<Dept> depts = deptService.list();
|
|
|
+ Dept dept = deptService.getById(deptId);
|
|
|
+ deptIdList.add(dept.getDId());
|
|
|
+ deptService.getChildListByDept(depts,dept,deptIdList);
|
|
|
+ LambdaQueryWrapper<Staff> queryWrapper = Wrappers.lambdaQuery();
|
|
|
+ queryWrapper.select(Staff::getSId)
|
|
|
+ .in(Staff::getDeptId,deptIdList);
|
|
|
+ list = staffService.list(queryWrapper).stream().map(Staff::getSId).collect(Collectors.toList());
|
|
|
+ }else {
|
|
|
+ LambdaQueryWrapper<Staff> staffLambdaQueryWrapper = Wrappers.lambdaQuery();
|
|
|
+ staffLambdaQueryWrapper
|
|
|
+ .select(Staff::getSId)
|
|
|
+ .eq(Staff::getDeptId,deptId);
|
|
|
+ list = staffService.list(staffLambdaQueryWrapper).stream().map(Staff::getSId).collect(Collectors.toList());
|
|
|
+ }
|
|
|
if (CollectionUtils.isNotEmpty(list)){
|
|
|
LambdaQueryWrapper<StaffRadio> queryWrapper = Wrappers.lambdaQuery();
|
|
|
queryWrapper.in(StaffRadio::getStaffId,list);
|