package cc.mrbird.febs.server.hr.service.impl; import cc.mrbird.febs.common.core.constant.ModuleCode; import cc.mrbird.febs.common.core.entity.QueryRequest; import cc.mrbird.febs.common.core.entity.constant.FebsConstant; import cc.mrbird.febs.common.core.entity.constant.StringConstant; import cc.mrbird.febs.common.core.utils.FebsUtil; import cc.mrbird.febs.common.core.utils.SequenceUtil; import cc.mrbird.febs.common.core.utils.SortUtil; import cc.mrbird.febs.server.hr.entity.EmpDimissionLog; import cc.mrbird.febs.server.hr.feign.IRemoteDeptService; import cc.mrbird.febs.server.hr.mapper.EmpDimissionLogMapper; import cc.mrbird.febs.server.hr.service.IEmpDimissionLogService; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import lombok.RequiredArgsConstructor; import org.apache.commons.lang3.StringUtils; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Propagation; import org.springframework.transaction.annotation.Transactional; import java.util.*; /** * name:EmpDimissionlog * package:cc.mrbird.febs.server.hr.controller * description:员工离职记录服务接口实现 * * @author luoyibo * @date 2021-02-18 16:04:42 * @since JDK1.8 */ @Service @RequiredArgsConstructor @Transactional(propagation = Propagation.SUPPORTS, readOnly = true) class EmpDimissionLogServiceImpl extends ServiceImpl implements IEmpDimissionLogService { private final EmpDimissionLogMapper empDimissionlogMapper; private final IRemoteDeptService remoteDeptService; private final String operatorId = Optional.ofNullable(FebsUtil.getCurrentUser()) .map(u -> u.getUserId().toString()) .orElse("1"); @Override public IPage> findEmpDimissionLogs(QueryRequest request, EmpDimissionLog empDimissionlog) { QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.eq("a.delFlag", 0); if (StringUtils.isNotBlank(empDimissionlog.getEntryDateStr())) { queryWrapper.between("a.entryDate", empDimissionlog.getEntryDateStr().split(",")[0], empDimissionlog.getEntryDateStr().split(",")[1]); } if (StringUtils.isNotBlank(empDimissionlog.getDimissionDateStr())) { queryWrapper.between("a.dimissionDate", empDimissionlog.getDimissionDateStr().split(",")[0], empDimissionlog.getDimissionDateStr().split(",")[1]); } if (StringUtils.isNotBlank(empDimissionlog.getDimissionType())) { queryWrapper.eq("a.dimissionType", empDimissionlog.getDimissionType()); } if (null!=empDimissionlog.getEmpId()&&!empDimissionlog.getEmpId().equals(0L)) { queryWrapper.eq("a.empId", empDimissionlog.getEmpId()); } if (StringUtils.isNotBlank(empDimissionlog.getEmpStatus())) { queryWrapper.in("b.EmpStatus", empDimissionlog.getEmpStatus().split(",")); } if (StringUtils.isNotBlank(empDimissionlog.getDeptName())) { queryWrapper.like("c.allDeptName", empDimissionlog.getDeptName()); } if (StringUtils.isNotBlank(empDimissionlog.getEmpName())) { queryWrapper.like("b.empName", empDimissionlog.getEmpName()); } if (StringUtils.isNotBlank(empDimissionlog.getEmpNumb())) { queryWrapper.like("b.empNumb", empDimissionlog.getEmpNumb()); } Page> page = new Page<>(request.getPageNum(), request.getPageSize()); SortUtil.handlePageSort(request, page, "createTime", FebsConstant.ORDER_DESC, true); queryWrapper.in("c.dept_Id", remoteDeptService.userRightDepts().split(StringConstant.COMMA)); return this.baseMapper.selectPageVo(page,queryWrapper); } @Override public List findEmpDimissionLogs(EmpDimissionLog empDimissionlog) { LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>(); queryWrapper.eq(EmpDimissionLog::getDelFlag, 0); return this.baseMapper.selectList(queryWrapper); } @Override @Transactional(rollbackFor = Exception.class) public void createEmpDimissionLog(EmpDimissionLog empDimissionlog) { empDimissionlog.setCloseId(SequenceUtil.generateId(0L, ModuleCode.HR_EMPLOYEE)); empDimissionlog.setCreator(operatorId); empDimissionlog.setModifier(operatorId); this.save(empDimissionlog); } @Override @Transactional(rollbackFor = Exception.class) public void updateEmpDimissionLog(EmpDimissionLog empDimissionlog) { EmpDimissionLog dbData = this.getById(empDimissionlog.getCloseId()); empDimissionlog.setCreateTime(dbData.getCreateTime()); empDimissionlog.setCreator(dbData.getCreator()); empDimissionlog.setDelFlag(dbData.getDelFlag()); empDimissionlog.setModifyTime(new Date()); empDimissionlog.setModifier(operatorId); this.saveOrUpdate(empDimissionlog); } @Override @Transactional(rollbackFor = Exception.class) public void deleteEmpDimissionLog(EmpDimissionLog empDimissionlog) { LambdaQueryWrapper wrapper = new LambdaQueryWrapper<>(); // TODO 设置删除条件 this.remove(wrapper); } /** * 根据Id批量逻辑删除记录 *

* date 2021-01-28 10:48 * * @param ids 待删除Id * @return void * @author: luoyibo */ @Override @Transactional(rollbackFor = Exception.class) public void logicDelEmpDimissionLog(String ids) { String[] str = ids.split(","); List list = new ArrayList<>(Arrays.asList(str)); empDimissionlogMapper.logicDeleteByIds(list, operatorId); } }