package com.doumee.service.business.impl;
|
|
import com.doumee.biz.system.SystemDictDataBiz;
|
import com.doumee.core.constants.ResponseStatus;
|
import com.doumee.core.exception.BusinessException;
|
import com.doumee.core.model.LoginUserInfo;
|
import com.doumee.core.model.PageData;
|
import com.doumee.core.model.PageWrap;
|
import com.doumee.core.utils.Constants;
|
import com.doumee.core.utils.Utils;
|
import com.doumee.dao.business.*;
|
import com.doumee.dao.business.join.CompanyUserApplyJoinMapper;
|
import com.doumee.dao.business.model.*;
|
import com.doumee.dao.system.SystemUserMapper;
|
import com.doumee.dao.system.model.SystemDictData;
|
import com.doumee.dao.system.model.SystemUser;
|
import com.doumee.service.business.CompanyUserApplyService;
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
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.base.MPJBaseMapper;
|
import com.github.yulichang.query.MPJQueryWrapper;
|
import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
import org.apache.commons.lang.StringUtils;
|
import org.apache.shiro.SecurityUtils;
|
import org.checkerframework.checker.units.qual.A;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Service;
|
import org.springframework.util.CollectionUtils;
|
|
import java.util.*;
|
|
/**
|
* 集团申请记录表Service实现
|
* @author 江蹄蹄
|
* @date 2024/10/28 19:16
|
*/
|
@Service
|
public class CompanyUserApplyServiceImpl implements CompanyUserApplyService {
|
|
@Autowired
|
private CompanyUserApplyMapper companyUserApplyMapper;
|
@Autowired
|
private SystemUserMapper systemUserMapper;
|
@Autowired
|
private CompanyMapper companyMapper;
|
@Autowired
|
private MultifileMapper multifileMapper;
|
@Autowired
|
private CompanyUserApplyJoinMapper companyUserApplyJoinMapper;
|
@Autowired
|
private SystemDictDataBiz systemDictDataBiz;
|
@Autowired
|
private CompanyPermissionMapper companyPermissionMapper;
|
@Autowired
|
private NoticesMapper noticesMapper;
|
|
|
@Override
|
public Integer create(CompanyUserApply companyUserApply) {
|
LoginUserInfo loginUserInfo =(LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
|
if(Objects.isNull(companyUserApply)
|
|| Objects.isNull(companyUserApply.getUserId())
|
|| CollectionUtils.isEmpty(companyUserApply.getMultifileList())
|
|| StringUtils.isBlank(companyUserApply.getCompanyIds())
|
|| StringUtils.isBlank(companyUserApply.getCompanyNames())){
|
throw new BusinessException(ResponseStatus.BAD_REQUEST);
|
}
|
if(!Constants.equalsInteger(loginUserInfo.getType(),Constants.ONE)){
|
throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"登录用户不允许当前操作");
|
}
|
//查询当前用户是否存在申请中
|
if(companyUserApplyMapper.selectCount(new QueryWrapper<CompanyUserApply>().lambda()
|
.eq(CompanyUserApply::getUserId,companyUserApply.getUserId())
|
.eq(CompanyUserApply::getIsdeleted, Constants.ZERO)
|
.eq(CompanyUserApply::getStatus,Constants.ZERO))>Constants.ZERO){
|
throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"当前账户存在待审批数据,无法进行申请");
|
};
|
SystemUser applyUser = systemUserMapper.selectById(companyUserApply.getUserId());
|
if(Objects.isNull(applyUser)){
|
throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到申请用户信息");
|
}
|
Company applyCompany = companyMapper.selectById(applyUser.getCompanyId());
|
if(Objects.isNull(applyCompany)){
|
throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"未查询到申请用户企业信息");
|
}
|
|
List<String> companyIds = Arrays.asList(companyUserApply.getCompanyIds().split(","));
|
for (String companyId:companyIds) {
|
if(Constants.equalsInteger(loginUserInfo.getCompanyId(),Integer.valueOf(companyId))){
|
throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"无法申请归属公司权限");
|
}
|
if(companyPermissionMapper.selectCount(new QueryWrapper<CompanyPermission>().lambda()
|
.eq(CompanyPermission::getCompanyId,companyId)
|
.eq(CompanyPermission::getIsdeleted,Constants.ZERO)
|
.eq(CompanyPermission::getUserId,companyUserApply.getUserId()))>Constants.ZERO
|
){
|
Company company = companyMapper.selectById(companyId);
|
throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"企业【"+company.getName()+"】已申请,请勿重复申请!");
|
};
|
}
|
List<Company> companyList = companyMapper.selectList(new QueryWrapper<Company>().lambda()
|
.eq(Company::getIsdeleted, Constants.ZERO)
|
.eq(Company::getType,Constants.ZERO)
|
.in(Company::getId, companyIds)
|
);
|
if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isEmpty(companyList) || !Constants.equalsInteger(companyList.size(),companyIds.size())){
|
throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"企业信息异常,请检查选择企业信息");
|
}
|
companyUserApply.setStatus(Constants.ZERO);
|
companyUserApply.setIsdeleted(Constants.ZERO);
|
companyUserApply.setCreateDate(new Date());
|
companyUserApply.setCreator(loginUserInfo.getId());
|
companyUserApplyMapper.insert(companyUserApply);
|
|
List<Multifile> multifileList = companyUserApply.getMultifileList();
|
for (Multifile multifile:multifileList) {
|
multifile.setIsdeleted(Constants.ZERO);
|
multifile.setCreator(loginUserInfo.getId());
|
multifile.setCreateDate(new Date());
|
multifile.setObjId(companyUserApply.getId());
|
multifile.setObjType(Constants.MultiFile.COMPANY_USER_APPLY.getKey());
|
multifileMapper.insert(multifile);
|
}
|
|
//存储待办信息
|
Constants.NoticeObjectType noticeObjectType = Constants.NoticeObjectType.COMPANY_USER_APPLY;
|
//平台待办
|
Notices notices = new Notices(noticeObjectType,
|
Constants.ZERO
|
,companyUserApply.getId(),
|
applyCompany.getName() + " - " + applyUser.getRealname() +"提交集团账号申请" ,
|
null
|
,Constants.NoticeType.ZERO);
|
noticesMapper.insert(notices);
|
|
return companyUserApply.getId();
|
}
|
|
@Override
|
public void deleteById(Integer id) {
|
LoginUserInfo loginUserInfo =(LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
|
CompanyUserApply companyUserApply = companyUserApplyMapper.selectById(id);
|
if(Objects.isNull(companyUserApply)){
|
throw new BusinessException(ResponseStatus.DATA_EMPTY);
|
}
|
if(!Constants.equalsInteger(companyUserApply.getStatus(),Constants.ZERO)){
|
throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"当前业务状态已流转,不允许该操作");
|
}
|
companyUserApplyMapper.update(null,new UpdateWrapper<CompanyUserApply>().lambda()
|
.set(CompanyUserApply::getIsdeleted,Constants.ONE)
|
.set(CompanyUserApply::getEditDate,new Date())
|
.set(CompanyUserApply::getEditor,loginUserInfo.getId())
|
.eq(CompanyUserApply::getId,id)
|
);
|
}
|
|
@Override
|
public void delete(CompanyUserApply companyUserApply) {
|
UpdateWrapper<CompanyUserApply> deleteWrapper = new UpdateWrapper<>(companyUserApply);
|
companyUserApplyMapper.delete(deleteWrapper);
|
}
|
|
@Override
|
public void deleteByIdInBatch(List<Integer> ids) {
|
if (CollectionUtils.isEmpty(ids)) {
|
return;
|
}
|
companyUserApplyMapper.deleteBatchIds(ids);
|
}
|
|
@Override
|
public void updateById(CompanyUserApply companyUserApply) {
|
companyUserApplyMapper.updateById(companyUserApply);
|
}
|
|
@Override
|
public void updateByIdInBatch(List<CompanyUserApply> companyUserApplys) {
|
if (CollectionUtils.isEmpty(companyUserApplys)) {
|
return;
|
}
|
for (CompanyUserApply companyUserApply: companyUserApplys) {
|
this.updateById(companyUserApply);
|
}
|
}
|
|
@Override
|
public CompanyUserApply findById(Integer id) {
|
CompanyUserApply companyUserApply = companyUserApplyJoinMapper.selectJoinOne(CompanyUserApply.class,new MPJLambdaWrapper<CompanyUserApply>()
|
.selectAll(CompanyUserApply.class)
|
.select(" t3.name as companyName ")
|
.select(" t1.REALNAME as realName ")
|
.select(" t2.USERNAME as userName ")
|
.leftJoin(" system_user t1 on t1.id = t.creator ")
|
.leftJoin(" system_user t2 on t2.id = t.user_id ")
|
.leftJoin(" company t3 on t3.id = t2.company_id ")
|
.eq(CompanyUserApply::getId,id));
|
if(Objects.isNull(companyUserApply)){
|
throw new BusinessException(ResponseStatus.DATA_EMPTY);
|
}
|
List<Multifile> multifileList = multifileMapper.selectList(new QueryWrapper<Multifile>().lambda()
|
.eq(Multifile::getObjId,id)
|
.eq(Multifile::getObjType,Constants.MultiFile.COMPANY_USER_APPLY.getKey())
|
.eq(Multifile::getIsdeleted,Constants.ZERO)
|
.orderByDesc(Multifile::getId)
|
);
|
if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(multifileList)){
|
String url = systemDictDataBiz.queryByCode(Constants.OSS,Constants.RESOURCE_PATH).getCode()+
|
systemDictDataBiz.queryByCode(Constants.OSS,Constants.COMPANY_USER_APPLY).getCode();
|
for (Multifile multifile:multifileList) {
|
if(StringUtils.isNotBlank(multifile.getFileurl())){
|
multifile.setFileurlFull(url + multifile.getFileurl());
|
}
|
}
|
companyUserApply.setMultifileList(multifileList);
|
}
|
return companyUserApply;
|
}
|
|
@Override
|
public CompanyUserApply findOne(CompanyUserApply companyUserApply) {
|
QueryWrapper<CompanyUserApply> wrapper = new QueryWrapper<>(companyUserApply);
|
return companyUserApplyMapper.selectOne(wrapper);
|
}
|
|
@Override
|
public List<CompanyUserApply> findList(CompanyUserApply companyUserApply) {
|
QueryWrapper<CompanyUserApply> wrapper = new QueryWrapper<>(companyUserApply);
|
return companyUserApplyMapper.selectList(wrapper);
|
}
|
|
@Override
|
public PageData<CompanyUserApply> findPage(PageWrap<CompanyUserApply> pageWrap) {
|
IPage<CompanyUserApply> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
|
MPJLambdaWrapper<CompanyUserApply> queryWrapper = new MPJLambdaWrapper<CompanyUserApply>();
|
Utils.MP.blankToNull(pageWrap.getModel());
|
queryWrapper.selectAll(CompanyUserApply.class);
|
queryWrapper.select(" t3.name as companyName ");
|
queryWrapper.select(" t1.REALNAME as realName ");
|
queryWrapper.select(" t2.USERNAME as userName ");
|
queryWrapper.leftJoin(" system_user t1 on t1.id = t.creator ");
|
queryWrapper.leftJoin(" system_user t2 on t2.id = t.user_id ");
|
queryWrapper.leftJoin(" company t3 on t3.id = t2.company_id ");
|
queryWrapper.eq(CompanyUserApply::getIsdeleted,Constants.ZERO);
|
|
|
if (pageWrap.getModel().getCompanyId() != null) {
|
queryWrapper.apply(" t3.id = "+pageWrap.getModel().getCompanyId()+" ");
|
}
|
|
if (pageWrap.getModel().getStatus() != null) {
|
queryWrapper.eq(CompanyUserApply::getStatus, pageWrap.getModel().getStatus());
|
}
|
|
if (pageWrap.getModel().getUserId() != null) {
|
queryWrapper.eq(CompanyUserApply::getUserId, pageWrap.getModel().getUserId());
|
}
|
|
queryWrapper.orderByDesc(CompanyUserApply::getCreateDate);
|
IPage<CompanyUserApply> iPage = companyUserApplyJoinMapper.selectJoinPage(page,CompanyUserApply.class,queryWrapper);
|
return PageData.from(iPage);
|
}
|
|
@Override
|
public long count(CompanyUserApply companyUserApply) {
|
QueryWrapper<CompanyUserApply> wrapper = new QueryWrapper<>(companyUserApply);
|
return companyUserApplyMapper.selectCount(wrapper);
|
}
|
|
@Override
|
public void audit(CompanyUserApply companyUserApply){
|
LoginUserInfo loginUserInfo =(LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
|
if(Objects.isNull(companyUserApply)
|
||Objects.isNull(companyUserApply.getId())
|
|| Objects.isNull(companyUserApply.getStatus())
|
|| !(Constants.equalsInteger(companyUserApply.getStatus(),Constants.ONE) || Constants.equalsInteger(companyUserApply.getStatus(),Constants.TWO))
|
|| (StringUtils.isBlank(companyUserApply.getCheckInfo()) && Constants.equalsInteger(companyUserApply.getStatus(),Constants.TWO))
|
){
|
throw new BusinessException(ResponseStatus.BAD_REQUEST);
|
}
|
CompanyUserApply userApply = companyUserApplyJoinMapper.selectById(companyUserApply.getId());
|
if(Objects.isNull(userApply)){
|
throw new BusinessException(ResponseStatus.DATA_EMPTY);
|
}
|
if(!Constants.equalsInteger(userApply.getStatus(),Constants.ZERO)){
|
throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"业务状态已流转");
|
}
|
CompanyUserApply update = new CompanyUserApply();
|
update.setId(companyUserApply.getId());
|
update.setEditDate(new Date());
|
update.setEditor(loginUserInfo.getId());
|
update.setStatus(companyUserApply.getStatus());
|
update.setCheckInfo(companyUserApply.getCheckInfo());
|
update.setCheckDate(new Date());
|
update.setCheckorId(loginUserInfo.getId());
|
companyUserApplyJoinMapper.updateById(update);
|
if(Constants.equalsInteger(companyUserApply.getStatus(),Constants.ONE) && StringUtils.isNotBlank(userApply.getCompanyIds())){
|
List<String> ids = Arrays.asList(userApply.getCompanyIds().split(","));
|
List<CompanyPermission> companyPermissionList = new ArrayList<>();
|
for (String id:ids) {
|
CompanyPermission companyPermission = new CompanyPermission();
|
companyPermission.setCreator(loginUserInfo.getId());
|
companyPermission.setCreateDate(new Date());
|
companyPermission.setIsdeleted(Constants.ZERO);
|
companyPermission.setUserId(userApply.getUserId());
|
companyPermission.setCompanyId(Integer.valueOf(id));
|
companyPermission.setType(Constants.ONE);
|
companyPermissionList.add(companyPermission);
|
}
|
companyPermissionMapper.insertBatchSomeColumn(companyPermissionList);
|
}
|
|
|
//存储待办信息
|
Constants.NoticeObjectType noticeObjectType = Constants.NoticeObjectType.COMPANY_USER_APPLY;
|
//删除其他待办
|
noticesMapper.delete(new QueryWrapper<Notices>().lambda().eq(Notices::getObjType,noticeObjectType.getKey())
|
.ne(Notices::getType,Constants.NoticeType.SIX.getStatus())
|
.eq(Notices::getObjId,update.getId()));
|
|
}
|
}
|