package doumeemes.service.business.impl; import com.github.yulichang.wrapper.MPJLambdaWrapper; import doumeemes.core.constants.ResponseStatus; import doumeemes.core.exception.BusinessException; import doumeemes.core.model.LoginUserInfo; import doumeemes.core.model.PageData; import doumeemes.core.model.PageWrap; import doumeemes.core.utils.Constants; import doumeemes.core.utils.Utils; import doumeemes.dao.business.UnqualifiedRecordMapper; import doumeemes.dao.business.model.*; import doumeemes.dao.ext.dto.QueryUnQualifiedRecordDTO; import doumeemes.dao.system.dto.QuerySystemLoginLogDTO; import doumeemes.dao.ext.join.UnQualifiedRecordJoinMapper; import doumeemes.dao.system.model.SystemLoginLog; import doumeemes.dao.system.model.SystemUser; import doumeemes.service.business.UnqualifiedRecordService; 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 org.apache.commons.lang3.StringUtils; import org.apache.shiro.SecurityUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import java.util.List; import java.util.Objects; /** * 工单类-报工不良记录类型表Service实现 * @author 江蹄蹄 * @since 2023/08/16 14:15 */ @Service public class UnqualifiedRecordServiceImpl implements UnqualifiedRecordService { @Autowired private UnqualifiedRecordMapper unqualifiedRecordMapper; @Autowired private UnQualifiedRecordJoinMapper unQualifiedRecordJoinMapper; @Override public Integer create(UnqualifiedRecord unqualifiedRecord) { unqualifiedRecordMapper.insert(unqualifiedRecord); return unqualifiedRecord.getId(); } @Override public void deleteById(Integer id) { unqualifiedRecordMapper.deleteById(id); } @Override public void delete(UnqualifiedRecord unqualifiedRecord) { UpdateWrapper deleteWrapper = new UpdateWrapper<>(unqualifiedRecord); unqualifiedRecordMapper.delete(deleteWrapper); } @Override public void deleteByIdInBatch(List ids) { if (CollectionUtils.isEmpty(ids)) { return; } unqualifiedRecordMapper.deleteBatchIds(ids); } @Override public void updateById(UnqualifiedRecord unqualifiedRecord) { unqualifiedRecordMapper.updateById(unqualifiedRecord); } @Override public void updateByIdInBatch(List unqualifiedRecords) { if (CollectionUtils.isEmpty(unqualifiedRecords)) { return; } for (UnqualifiedRecord unqualifiedRecord: unqualifiedRecords) { this.updateById(unqualifiedRecord); } } @Override public UnqualifiedRecord findById(Integer id) { return unqualifiedRecordMapper.selectById(id); } @Override public UnqualifiedRecord findOne(UnqualifiedRecord unqualifiedRecord) { QueryWrapper wrapper = new QueryWrapper<>(unqualifiedRecord); return unqualifiedRecordMapper.selectOne(wrapper); } @Override public List findList(UnqualifiedRecord unqualifiedRecord) { QueryWrapper wrapper = new QueryWrapper<>(unqualifiedRecord); return unqualifiedRecordMapper.selectList(wrapper); } @Override public PageData findPage(PageWrap pageWrap) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); QueryWrapper queryWrapper = new QueryWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); queryWrapper.lambda() .eq(pageWrap.getModel().getId() != null, UnqualifiedRecord::getId, pageWrap.getModel().getId()) .eq(pageWrap.getModel().getDeleted() != null, UnqualifiedRecord::getDeleted, pageWrap.getModel().getDeleted()) .eq(pageWrap.getModel().getCreateUser() != null, UnqualifiedRecord::getCreateUser, pageWrap.getModel().getCreateUser()) .ge(pageWrap.getModel().getCreateTime() != null, UnqualifiedRecord::getCreateTime, Utils.Date.getStart(pageWrap.getModel().getCreateTime())) .le(pageWrap.getModel().getCreateTime() != null, UnqualifiedRecord::getCreateTime, Utils.Date.getEnd(pageWrap.getModel().getCreateTime())) .eq(pageWrap.getModel().getUpdateUser() != null, UnqualifiedRecord::getUpdateUser, pageWrap.getModel().getUpdateUser()) .ge(pageWrap.getModel().getUpdateTime() != null, UnqualifiedRecord::getUpdateTime, Utils.Date.getStart(pageWrap.getModel().getUpdateTime())) .le(pageWrap.getModel().getUpdateTime() != null, UnqualifiedRecord::getUpdateTime, Utils.Date.getEnd(pageWrap.getModel().getUpdateTime())) .eq(pageWrap.getModel().getRemark() != null, UnqualifiedRecord::getRemark, pageWrap.getModel().getRemark()) .eq(pageWrap.getModel().getRootDepartId() != null, UnqualifiedRecord::getRootDepartId, pageWrap.getModel().getRootDepartId()) .eq(pageWrap.getModel().getDepartId() != null, UnqualifiedRecord::getDepartId, pageWrap.getModel().getDepartId()) .eq(pageWrap.getModel().getWorkorderId() != null, UnqualifiedRecord::getWorkorderId, pageWrap.getModel().getWorkorderId()) .eq(pageWrap.getModel().getRecordId() != null, UnqualifiedRecord::getRecordId, pageWrap.getModel().getRecordId()) .eq(pageWrap.getModel().getCategoryId() != null, UnqualifiedRecord::getCategoryId, pageWrap.getModel().getCategoryId()) .eq(pageWrap.getModel().getUnqualifiedNum() != null, UnqualifiedRecord::getUnqualifiedNum, pageWrap.getModel().getUnqualifiedNum()) ; for(PageWrap.SortData sortData: pageWrap.getSorts()) { if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { queryWrapper.orderByDesc(sortData.getProperty()); } else { queryWrapper.orderByAsc(sortData.getProperty()); } } return PageData.from(unqualifiedRecordMapper.selectPage(page, queryWrapper)); } @Override public long count(UnqualifiedRecord unqualifiedRecord) { QueryWrapper wrapper = new QueryWrapper<>(unqualifiedRecord); return unqualifiedRecordMapper.selectCount(wrapper); } @Override public PageData findJoinPage(PageWrap pageWrap) { LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); if(!Constants.equalsInteger(user.getType(),Constants.USERTYPE.COM)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "对不起,您无权限进行该操作!"); } IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); MPJLambdaWrapper mpjLambdaWrapper = new MPJLambdaWrapper<>(); mpjLambdaWrapper.selectAll(UnqualifiedRecord.class); mpjLambdaWrapper.selectAs(Workorder::getCode, UnqualifiedRecord::getWorkOrderCode); mpjLambdaWrapper.selectAs(Material::getName, UnqualifiedRecord::getMaterialName); mpjLambdaWrapper.selectAs(Material::getCode, UnqualifiedRecord::getMaterialCode); mpjLambdaWrapper.selectAs(Procedures::getName, UnqualifiedRecord::getProceduresName); mpjLambdaWrapper.selectAs(Category::getName, UnqualifiedRecord::getCategoryName); mpjLambdaWrapper.selectAs(SystemUser::getRealname, UnqualifiedRecord::getCreateUserName); mpjLambdaWrapper.leftJoin(Workorder.class,Workorder::getId,UnqualifiedRecord::getWorkorderId); mpjLambdaWrapper.leftJoin(MaterialDistribute.class,MaterialDistribute::getId,Workorder::getMaterialId); mpjLambdaWrapper.leftJoin(Material.class,Material::getId,MaterialDistribute::getMaterialId); mpjLambdaWrapper.leftJoin(Procedures.class,Procedures::getId,Workorder::getProcedureId); mpjLambdaWrapper.leftJoin(Category.class,Category::getId,UnqualifiedRecord::getCategoryId); mpjLambdaWrapper.leftJoin(SystemUser.class,SystemUser::getId,UnqualifiedRecord::getCreateUser); //只能查看当前根组织的数据 mpjLambdaWrapper.eq(Workorder::getRootDepartId,user.getRootDepartment().getId()); //如果当前选择的公司级组织非根组织信息,只能查看当前选择公司级组织数据 mpjLambdaWrapper.eq(Workorder::getDepartId,user.getCurComDepartment().getId()); mpjLambdaWrapper.eq(UnqualifiedRecord::getDeleted,Constants.ZERO); // 不良分类分类 if ( pageWrap.getModel().getCategoryId() !=null) { mpjLambdaWrapper.eq(UnqualifiedRecord::getCategoryId, pageWrap.getModel().getCategoryId()); } // 工单编码 if (StringUtils.isNotBlank(pageWrap.getModel().getCode())) { mpjLambdaWrapper.like(Workorder::getCode, pageWrap.getModel().getCode()); } return PageData.from(unQualifiedRecordJoinMapper.selectJoinPage(page, UnqualifiedRecord.class,mpjLambdaWrapper)); } @Override public List findJoinList(Integer recordId) { LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); if(!Constants.equalsInteger(user.getType(),Constants.USERTYPE.COM)){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "对不起,您无权限进行该操作!"); } MPJLambdaWrapper mpjLambdaWrapper = new MPJLambdaWrapper<>(); mpjLambdaWrapper.selectAll(UnqualifiedRecord.class); mpjLambdaWrapper.selectAs(Workorder::getCode, UnqualifiedRecord::getWorkOrderCode); mpjLambdaWrapper.selectAs(Material::getName, UnqualifiedRecord::getMaterialName); mpjLambdaWrapper.selectAs(Material::getCode, UnqualifiedRecord::getMaterialCode); mpjLambdaWrapper.selectAs(Procedures::getName, UnqualifiedRecord::getProceduresName); mpjLambdaWrapper.selectAs(Category::getName, UnqualifiedRecord::getCategoryName); mpjLambdaWrapper.selectAs(SystemUser::getRealname, UnqualifiedRecord::getCreateUserName); mpjLambdaWrapper.leftJoin(Workorder.class,Workorder::getId,UnqualifiedRecord::getWorkorderId); mpjLambdaWrapper.leftJoin(MaterialDistribute.class,MaterialDistribute::getId,Workorder::getMaterialId); mpjLambdaWrapper.leftJoin(Material.class,Material::getId,MaterialDistribute::getMaterialId); mpjLambdaWrapper.leftJoin(Procedures.class,Procedures::getId,Workorder::getProcedureId); mpjLambdaWrapper.leftJoin(Category.class,Category::getId,UnqualifiedRecord::getCategoryId); mpjLambdaWrapper.leftJoin(SystemUser.class,SystemUser::getId,UnqualifiedRecord::getCreateUser); //只能查看当前根组织的数据 mpjLambdaWrapper.eq(Workorder::getRootDepartId,user.getRootDepartment().getId()); //如果当前选择的公司级组织非根组织信息,只能查看当前选择公司级组织数据 mpjLambdaWrapper.eq(Workorder::getDepartId,user.getCurComDepartment().getId()); mpjLambdaWrapper.eq(UnqualifiedRecord::getDeleted,Constants.ZERO); mpjLambdaWrapper.eq(UnqualifiedRecord::getRecordId, recordId); List unqualifiedRecordList = unQualifiedRecordJoinMapper.selectJoinList(UnqualifiedRecord.class,mpjLambdaWrapper); return unqualifiedRecordList; } }