jiangping
2024-12-27 5506edbe54883b31db3cc8e4a1d9d0795a18a3c9
server/service/src/main/java/com/doumee/service/business/impl/CompanyPermissionServiceImpl.java
@@ -8,6 +8,7 @@
import com.doumee.core.utils.Utils;
import com.doumee.dao.business.CompanyMapper;
import com.doumee.dao.business.CompanyPermissionMapper;
import com.doumee.dao.business.join.CompanyPermissionJoinMapper;
import com.doumee.dao.business.model.Company;
import com.doumee.dao.business.model.CompanyPermission;
import com.doumee.dao.system.SystemUserMapper;
@@ -17,6 +18,7 @@
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.github.yulichang.wrapper.MPJLambdaWrapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
@@ -24,6 +26,7 @@
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Objects;
/**
 * 管理员管理企业权限Service实现
@@ -36,19 +39,24 @@
    @Autowired
    private CompanyPermissionMapper companyPermissionMapper;
    @Autowired
    private CompanyPermissionJoinMapper companyPermissionJoinMapper;
    @Autowired
    private SystemUserMapper systemUserMapper;
    @Autowired
    private CompanyMapper companyMapper;
    @Override
    public Integer create(CompanyPermission companyPermission) {
        if(companyPermission.getUserId() == null || companyPermission.getCompanyIdList() == null || companyPermission.getCompanyIdList().size()==0){
        if(companyPermission.getUserId() == null ){
            throw  new BusinessException(ResponseStatus.BAD_REQUEST);
        }
        SystemUser user =systemUserMapper.selectById(companyPermission.getUserId());
        if(user == null || (user.getDeleted() !=null && user.getDeleted())){
            throw  new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"对不起,用户信息不存在,请尝试刷新页面重试!");
        }
        //刪除原有的,在批量插入新的
        companyPermissionMapper.delete(new QueryWrapper<CompanyPermission>().lambda().eq(CompanyPermission::getUserId,companyPermission.getUserId()));
        if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(companyPermission.getCompanyIdList())){
        List<Company> companieList = companyMapper.selectList(new QueryWrapper<Company>().lambda()
                .in(Company::getId,companyPermission.getCompanyIdList())
                .eq(Company::getIsdeleted, Constants.ZERO));
@@ -65,17 +73,21 @@
            model.setIsdeleted(Constants.ZERO);
            model.setCreator(user.getId());
            model.setUserId(companyPermission.getUserId());
                model.setType(Constants.ZERO);
            model.setCreateDate(date);
            list.add(model);
        }
        //刪除原有的,在批量插入新的
        companyPermissionMapper.delete(new QueryWrapper<CompanyPermission>().lambda().eq(CompanyPermission::getUserId,companyPermission.getUserId()));
        companyPermissionMapper.insertBatchSomeColumn(list);
        }
        return companyPermission.getId();
    }
    @Override
    public void deleteById(Integer id) {
        CompanyPermission companyPermission =  companyPermissionMapper.selectById(id);
        if(Objects.nonNull(companyPermission)&&Constants.equalsInteger(companyPermission.getType(),Constants.ZERO)){
            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"此类数据无法进行删除:基础权限");
        }
        companyPermissionMapper.deleteById(id);
    }
@@ -97,6 +109,7 @@
    public void updateById(CompanyPermission companyPermission) {
        companyPermissionMapper.updateById(companyPermission);
    }
    @Override
    public void updateByIdInBatch(List<CompanyPermission> companyPermissions) {
@@ -121,43 +134,26 @@
    @Override
    public List<CompanyPermission> findList(CompanyPermission companyPermission) {
        QueryWrapper<CompanyPermission> wrapper = new QueryWrapper<>(companyPermission);
        QueryWrapper<CompanyPermission> wrapper = new QueryWrapper<>();
        wrapper.lambda().eq(CompanyPermission::getIsdeleted,Constants.ZERO);
        wrapper.lambda().eq(Objects.nonNull(companyPermission) && Objects.nonNull(companyPermission.getUserId())
                ,CompanyPermission::getUserId,companyPermission.getUserId());
        wrapper.lambda().orderByAsc(CompanyPermission::getId);
        return companyPermissionMapper.selectList(wrapper);
    }
  
    @Override
    public PageData<CompanyPermission> findPage(PageWrap<CompanyPermission> pageWrap) {
        IPage<CompanyPermission> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
        QueryWrapper<CompanyPermission> queryWrapper = new QueryWrapper<>();
        MPJLambdaWrapper<CompanyPermission> queryWrapper = new MPJLambdaWrapper<>();
        Utils.MP.blankToNull(pageWrap.getModel());
        if (pageWrap.getModel().getId() != null) {
            queryWrapper.lambda().eq(CompanyPermission::getId, pageWrap.getModel().getId());
        }
        if (pageWrap.getModel().getCreator() != null) {
            queryWrapper.lambda().eq(CompanyPermission::getCreator, pageWrap.getModel().getCreator());
        }
        if (pageWrap.getModel().getCreateDate() != null) {
            queryWrapper.lambda().ge(CompanyPermission::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate()));
            queryWrapper.lambda().le(CompanyPermission::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate()));
        }
        if (pageWrap.getModel().getEditor() != null) {
            queryWrapper.lambda().eq(CompanyPermission::getEditor, pageWrap.getModel().getEditor());
        }
        if (pageWrap.getModel().getEditDate() != null) {
            queryWrapper.lambda().ge(CompanyPermission::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate()));
            queryWrapper.lambda().le(CompanyPermission::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate()));
        }
        if (pageWrap.getModel().getIsdeleted() != null) {
            queryWrapper.lambda().eq(CompanyPermission::getIsdeleted, pageWrap.getModel().getIsdeleted());
        }
        if (pageWrap.getModel().getRemark() != null) {
            queryWrapper.lambda().eq(CompanyPermission::getRemark, pageWrap.getModel().getRemark());
        }
        if (pageWrap.getModel().getCompanyId() != null) {
            queryWrapper.lambda().eq(CompanyPermission::getCompanyId, pageWrap.getModel().getCompanyId());
        }
        queryWrapper.selectAll(CompanyPermission.class);
        queryWrapper.select(" t1.USERNAME as userName,t1.REALNAME as realName ,t1.mobile,  t2.name as companyName , t3.realName as auditName  ");
        queryWrapper.leftJoin(" system_user t1 on t1.id = t.user_id  ");
        queryWrapper.leftJoin(" company t2 on t2.id = t.company_id  ");
        queryWrapper.leftJoin(" system_user t3 on t3.id = t.creator  ");
        if (pageWrap.getModel().getUserId() != null) {
            queryWrapper.lambda().eq(CompanyPermission::getUserId, pageWrap.getModel().getUserId());
            queryWrapper.eq(CompanyPermission::getUserId, pageWrap.getModel().getUserId());
        }
        for(PageWrap.SortData sortData: pageWrap.getSorts()) {
            if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
@@ -166,7 +162,7 @@
                queryWrapper.orderByAsc(sortData.getProperty());
            }
        }
        return PageData.from(companyPermissionMapper.selectPage(page, queryWrapper));
        return PageData.from(companyPermissionJoinMapper.selectPage(page, queryWrapper));
    }
    @Override
@@ -174,4 +170,16 @@
        QueryWrapper<CompanyPermission> wrapper = new QueryWrapper<>(companyPermission);
        return companyPermissionMapper.selectCount(wrapper);
    }
    @Override
    public List<CompanyPermission> getUserCompanyPermission(Integer userId) {
        return companyPermissionJoinMapper.selectJoinList(CompanyPermission.class,new MPJLambdaWrapper<CompanyPermission>()
                .selectAll(CompanyPermission.class)
                .selectAs(Company::getName,CompanyPermission::getCompanyName)
                .leftJoin(Company.class,Company::getId,CompanyPermission::getCompanyId)
                .eq(CompanyPermission::getUserId,userId)
                .eq(CompanyPermission::getIsdeleted,Constants.ZERO)
        );
    }
}