package com.doumee.service.business.impl;
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.doumee.core.annotation.excel.ExcelColumn;
|
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.admin.response.CompanyDTO;
|
import com.doumee.dao.business.CompanyMapper;
|
import com.doumee.dao.business.join.CompanyJoinMapper;
|
import com.doumee.dao.business.model.Category;
|
import com.doumee.dao.business.model.Company;
|
import com.doumee.dao.business.model.Member;
|
import com.doumee.dao.system.model.SystemUser;
|
import com.doumee.service.business.CompanyService;
|
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.wrapper.MPJLambdaWrapper;
|
import io.swagger.annotations.ApiModelProperty;
|
import org.apache.commons.collections.CollectionUtils;
|
import org.apache.shiro.SecurityUtils;
|
import org.springframework.beans.BeanUtils;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Service;
|
|
import java.util.ArrayList;
|
import java.util.Date;
|
import java.util.List;
|
import java.util.Objects;
|
import java.util.stream.Collectors;
|
|
/**
|
* 企业信息表Service实现
|
* @author 江蹄蹄
|
* @date 2023/11/30 15:33
|
*/
|
@Service
|
public class CompanyServiceImpl implements CompanyService {
|
|
@Autowired
|
private CompanyMapper companyMapper;
|
|
@Autowired
|
private CompanyJoinMapper companyJoinMapper;
|
|
@Override
|
public Integer create(Company company) {
|
companyMapper.insert(company);
|
return company.getId();
|
}
|
|
@Override
|
public Integer createLaborServices(Company company) {
|
LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
|
|
checkUnique(company);
|
Company insert = new Company();
|
insert.setCreator(loginUserInfo.getId());
|
insert.setCreateDate(new Date());
|
insert.setEditor(loginUserInfo.getId());
|
insert.setEditDate(new Date());
|
insert.setIsdeleted(Constants.ZERO);
|
insert.setName(company.getName());
|
insert.setRemark(company.getRemark());
|
insert.setStatus(Constants.ZERO);
|
insert.setSortnum(company.getSortnum());
|
insert.setImgurl(company.getImgurl());
|
insert.setType(Constants.ZERO);
|
insert.setCategoryId(company.getCategoryId());
|
insert.setCode(company.getCode());
|
insert.setParentId(company.getParentId());
|
insert.setLinkName(company.getLinkName());
|
insert.setLinkPhone(company.getLinkPhone());
|
companyMapper.insert(insert);
|
return insert.getId();
|
}
|
|
@Override
|
public void deleteById(Integer id) {
|
companyMapper.deleteById(id);
|
}
|
|
@Override
|
public void delete(Company company) {
|
UpdateWrapper<Company> deleteWrapper = new UpdateWrapper<>(company);
|
companyMapper.delete(deleteWrapper);
|
}
|
|
@Override
|
public void deleteByIdInBatch(List<Integer> ids) {
|
if (CollectionUtils.isEmpty(ids)) {
|
return;
|
}
|
companyMapper.deleteBatchIds(ids);
|
}
|
|
@Override
|
public void updateById(Company company) {
|
companyMapper.updateById(company);
|
}
|
|
@Override
|
public Integer updateLaborServicesById(Company company) {
|
checkUnique(company);
|
companyMapper.updateById(company);
|
return null;
|
}
|
|
@Override
|
public void updateByIdInBatch(List<Company> companys) {
|
if (CollectionUtils.isEmpty(companys)) {
|
return;
|
}
|
for (Company company: companys) {
|
this.updateById(company);
|
}
|
}
|
|
@Override
|
public Company findById(Integer id) {
|
return companyMapper.selectById(id);
|
}
|
|
@Override
|
public Company findOne(Company company) {
|
QueryWrapper<Company> wrapper = new QueryWrapper<>(company);
|
return companyMapper.selectOne(wrapper);
|
}
|
|
@Override
|
public List<Company> findList(Company company) {
|
QueryWrapper<Company> wrapper = new QueryWrapper<>(company);
|
return companyMapper.selectList(wrapper);
|
}
|
|
@Override
|
public PageData<Company> findPage(PageWrap<Company> pageWrap) {
|
IPage<Company> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
|
MPJLambdaWrapper<Company> queryWrapper = new MPJLambdaWrapper<>();
|
Utils.MP.blankToNull(pageWrap.getModel());
|
pageWrap.getModel().setIsdeleted(Constants.ZERO);
|
if (pageWrap.getModel().getId() != null) {
|
queryWrapper.eq(Company::getId, pageWrap.getModel().getId());
|
}
|
if (pageWrap.getModel().getCreator() != null) {
|
queryWrapper.eq(Company::getCreator, pageWrap.getModel().getCreator());
|
}
|
if (pageWrap.getModel().getCreateDate() != null) {
|
queryWrapper.ge(Company::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate()));
|
queryWrapper.le(Company::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate()));
|
}
|
if (pageWrap.getModel().getEditor() != null) {
|
queryWrapper.eq(Company::getEditor, pageWrap.getModel().getEditor());
|
}
|
if (pageWrap.getModel().getEditDate() != null) {
|
queryWrapper.ge(Company::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate()));
|
queryWrapper.le(Company::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate()));
|
}
|
if (pageWrap.getModel().getIsdeleted() != null) {
|
queryWrapper.eq(Company::getIsdeleted, pageWrap.getModel().getIsdeleted());
|
}
|
if (pageWrap.getModel().getName() != null) {
|
queryWrapper.eq(Company::getName, pageWrap.getModel().getName());
|
}
|
if (pageWrap.getModel().getRemark() != null) {
|
queryWrapper.eq(Company::getRemark, pageWrap.getModel().getRemark());
|
}
|
if (pageWrap.getModel().getStatus() != null) {
|
queryWrapper.eq(Company::getStatus, pageWrap.getModel().getStatus());
|
}
|
if (pageWrap.getModel().getSortnum() != null) {
|
queryWrapper.eq(Company::getSortnum, pageWrap.getModel().getSortnum());
|
}
|
if (pageWrap.getModel().getImgurl() != null) {
|
queryWrapper.eq(Company::getImgurl, pageWrap.getModel().getImgurl());
|
}
|
if (pageWrap.getModel().getType() != null) {
|
queryWrapper.eq(Company::getType, pageWrap.getModel().getType());
|
}
|
if (pageWrap.getModel().getCategoryId() != null) {
|
queryWrapper.eq(Company::getCategoryId, pageWrap.getModel().getCategoryId());
|
}
|
if (pageWrap.getModel().getCode() != null) {
|
queryWrapper.eq(Company::getCode, pageWrap.getModel().getCode());
|
}
|
if (pageWrap.getModel().getParentId() != null) {
|
queryWrapper.eq(Company::getParentId, pageWrap.getModel().getParentId());
|
}
|
if (pageWrap.getModel().getLinkName() != null) {
|
queryWrapper.eq(Company::getLinkName, pageWrap.getModel().getLinkName());
|
}
|
if (pageWrap.getModel().getLinkPhone() != null) {
|
queryWrapper.eq(Company::getLinkPhone, pageWrap.getModel().getLinkPhone());
|
}
|
if (pageWrap.getModel().getHkId() != null) {
|
queryWrapper.eq(Company::getHkId, pageWrap.getModel().getHkId());
|
}
|
if (pageWrap.getModel().getHkStatus() != null) {
|
queryWrapper.eq(Company::getHkStatus, pageWrap.getModel().getHkStatus());
|
}
|
if (pageWrap.getModel().getHkDate() != null) {
|
queryWrapper.ge(Company::getHkDate, Utils.Date.getStart(pageWrap.getModel().getHkDate()));
|
queryWrapper.le(Company::getHkDate, Utils.Date.getEnd(pageWrap.getModel().getHkDate()));
|
}
|
if (pageWrap.getModel().getErpId() != null) {
|
queryWrapper.eq(Company::getErpId, pageWrap.getModel().getErpId());
|
}
|
if (pageWrap.getModel().getErpDate() != null) {
|
queryWrapper.ge(Company::getErpDate, Utils.Date.getStart(pageWrap.getModel().getErpDate()));
|
queryWrapper.le(Company::getErpDate, Utils.Date.getEnd(pageWrap.getModel().getErpDate()));
|
}
|
if (pageWrap.getModel().getErpStatus() != null) {
|
queryWrapper.eq(Company::getErpStatus, pageWrap.getModel().getErpStatus());
|
}
|
if (pageWrap.getModel().getDdId() != null) {
|
queryWrapper.eq(Company::getDdId, pageWrap.getModel().getDdId());
|
}
|
if (pageWrap.getModel().getDdDate() != null) {
|
queryWrapper.ge(Company::getDdDate, Utils.Date.getStart(pageWrap.getModel().getDdDate()));
|
queryWrapper.le(Company::getDdDate, Utils.Date.getEnd(pageWrap.getModel().getDdDate()));
|
}
|
if (pageWrap.getModel().getDdStatus() != null) {
|
queryWrapper.eq(Company::getDdStatus, pageWrap.getModel().getDdStatus());
|
}
|
if (pageWrap.getModel().getFsId() != null) {
|
queryWrapper.eq(Company::getFsId, pageWrap.getModel().getFsId());
|
}
|
if (pageWrap.getModel().getFsStatus() != null) {
|
queryWrapper.eq(Company::getFsStatus, pageWrap.getModel().getFsStatus());
|
}
|
if (pageWrap.getModel().getFsDate() != null) {
|
queryWrapper.ge(Company::getFsDate, Utils.Date.getStart(pageWrap.getModel().getFsDate()));
|
queryWrapper.le(Company::getFsDate, Utils.Date.getEnd(pageWrap.getModel().getFsDate()));
|
}
|
queryWrapper.orderByDesc(Company::getCreateDate);
|
queryWrapper.leftJoin(Category.class,Category::getId,Company::getCategoryId)
|
.leftJoin(Member.class, Member::getId,Company::getHeadId);
|
queryWrapper.selectAll(Company.class)
|
.selectAs(Category::getName,Company::getCategoryName)
|
.selectAs(Member::getName,Company::getHeadName)
|
.selectAs(Member::getPhone,Company::getHeadPhone)
|
.select("count(t1.id) as countNum");
|
IPage<Company> companyIPage = companyJoinMapper.selectJoinPage(page, Company.class, queryWrapper);
|
return PageData.from(companyIPage);
|
}
|
|
@Override
|
public long count(Company company) {
|
QueryWrapper<Company> wrapper = new QueryWrapper<>(company);
|
return companyMapper.selectCount(wrapper);
|
}
|
|
|
@Override
|
public List<CompanyDTO> findCompanyTreePage(Integer type) {
|
|
LambdaQueryWrapper<Company> wrapper = new LambdaQueryWrapper<>();
|
|
wrapper.eq(Company::getIsdeleted,Constants.ZERO)
|
.eq(Constants.equalsInteger(type,Constants.ONE),Company::getType,type);
|
List<Company> companies = companyMapper.selectList(wrapper);
|
return getCompanyTree( companies, null);
|
}
|
|
|
private List<CompanyDTO> getCompanyTree(List<Company> companies, Integer parentId){
|
if (CollectionUtils.isEmpty(companies)){
|
return null;
|
}
|
List<Company> collect = companies.stream()
|
.filter(s -> Constants.equalsInteger(s.getParentId(), parentId))
|
.collect(Collectors.toList());
|
if (CollectionUtils.isEmpty(companies)){
|
return null;
|
}
|
List<CompanyDTO> companyDTOList = new ArrayList<>();
|
for (int i = 0; i < collect.size(); i++) {
|
Company company = collect.get(i);
|
CompanyDTO companyDTO = new CompanyDTO();
|
BeanUtils.copyProperties(company,companyDTO);
|
companyDTO.setCompanyDTOList(getCompanyTree(companies, company.getId()));
|
companyDTOList.add(companyDTO);
|
}
|
return companyDTOList;
|
}
|
|
|
/**
|
* 劳务公司唯一性校验
|
* @param company
|
*/
|
private void checkUnique(Company company){
|
QueryWrapper<Company> wrapper = new QueryWrapper<>();
|
wrapper.lambda()
|
.eq(Company::getIsdeleted,Constants.ZERO)
|
.eq(Company::getType,Constants.ZERO)
|
.eq(Company::getName,company.getName());
|
List<Company> companies = companyMapper.selectList(wrapper);
|
if (CollectionUtils.isEmpty(companies)){
|
return;
|
}
|
//新增的情况存在记录
|
if (Objects.isNull(company.getId())){
|
throw new BusinessException(ResponseStatus.DATA_EXISTS.getCode(),"公司名称已存在");
|
}
|
//修改的情况存在记录 匹配不到 own
|
if (!companies.stream().map(s -> s.getId()).anyMatch(s -> s.equals(company.getId()))){
|
throw new BusinessException(ResponseStatus.DATA_EXISTS.getCode(),"公司名称已存在");
|
}
|
}
|
}
|