feat(wms): 新增员工入职离职功能
- 在 IWmsEmployeeChangeService 中添加 employeeEntry 和 employeeLeave 方法 - 扩展 WmsEmployeeChangeBo 类增加员工详细信息字段 - 在 WmsEmployeeChangeController 中添加入职和离职接口 - 实现 WmsEmployeeChangeServiceImpl 的入职离职业务逻辑 - 集成员工信息查询功能并在查询结果中关联员工详情 - 添加事务管理确保数据一致性操作
This commit is contained in:
@@ -96,4 +96,24 @@ public class WmsEmployeeChangeController extends BaseController {
|
|||||||
@PathVariable Long[] changeIds) {
|
@PathVariable Long[] changeIds) {
|
||||||
return toAjax(iWmsEmployeeChangeService.deleteWithValidByIds(Arrays.asList(changeIds), true));
|
return toAjax(iWmsEmployeeChangeService.deleteWithValidByIds(Arrays.asList(changeIds), true));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 员工入职
|
||||||
|
*/
|
||||||
|
@Log(title = "员工入职", businessType = BusinessType.INSERT)
|
||||||
|
@RepeatSubmit()
|
||||||
|
@PostMapping("/entry")
|
||||||
|
public R<Void> entry(@Validated(AddGroup.class) @RequestBody WmsEmployeeChangeBo bo) {
|
||||||
|
return toAjax(iWmsEmployeeChangeService.employeeEntry(bo));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 员工离职
|
||||||
|
*/
|
||||||
|
@Log(title = "员工离职", businessType = BusinessType.INSERT)
|
||||||
|
@RepeatSubmit()
|
||||||
|
@PostMapping("/leave")
|
||||||
|
public R<Void> leave(@Validated(AddGroup.class) @RequestBody WmsEmployeeChangeBo bo) {
|
||||||
|
return toAjax(iWmsEmployeeChangeService.employeeLeave(bo));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -59,5 +59,84 @@ public class WmsEmployeeChangeBo extends BaseEntity {
|
|||||||
*/
|
*/
|
||||||
private String remark;
|
private String remark;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 序号
|
||||||
|
*/
|
||||||
|
private Long serialNumber;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 部门
|
||||||
|
*/
|
||||||
|
private String dept;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 岗位工种
|
||||||
|
*/
|
||||||
|
private String jobType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 姓名
|
||||||
|
*/
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 身份证号
|
||||||
|
*/
|
||||||
|
private String idCard;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 年龄
|
||||||
|
*/
|
||||||
|
private Long age;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 性别(男/女)
|
||||||
|
*/
|
||||||
|
private String gender;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 学历
|
||||||
|
*/
|
||||||
|
private String education;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 家庭住址
|
||||||
|
*/
|
||||||
|
private String homeAddress;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 联系电话
|
||||||
|
*/
|
||||||
|
private String phone;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 入职时间
|
||||||
|
*/
|
||||||
|
private Date entryTime;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 紧急联系人
|
||||||
|
*/
|
||||||
|
private String emergencyContact;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 关系
|
||||||
|
*/
|
||||||
|
private String relationship;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 紧急联系人电话
|
||||||
|
*/
|
||||||
|
private String emergencyContactPhone;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 社保类型(三险/五险)
|
||||||
|
*/
|
||||||
|
private String socialInsuranceType;
|
||||||
|
|
||||||
|
// infoRemart
|
||||||
|
private String infoRemark;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,13 @@
|
|||||||
package com.klp.domain.vo;
|
package com.klp.domain.vo;
|
||||||
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||||
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
|
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
|
||||||
import com.alibaba.excel.annotation.ExcelProperty;
|
import com.alibaba.excel.annotation.ExcelProperty;
|
||||||
import com.klp.common.annotation.ExcelDictFormat;
|
import com.klp.common.annotation.ExcelDictFormat;
|
||||||
import com.klp.common.convert.ExcelDictConvert;
|
import com.klp.common.convert.ExcelDictConvert;
|
||||||
|
import com.klp.domain.WmsEmployeeInfo;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
|
||||||
|
|
||||||
@@ -70,6 +72,11 @@ public class WmsEmployeeChangeVo {
|
|||||||
*/
|
*/
|
||||||
@ExcelProperty(value = "备注")
|
@ExcelProperty(value = "备注")
|
||||||
private String remark;
|
private String remark;
|
||||||
|
/**
|
||||||
|
* 员工信息
|
||||||
|
*/
|
||||||
|
private WmsEmployeeInfo wmsEmployeeInfo;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -46,4 +46,14 @@ public interface IWmsEmployeeChangeService {
|
|||||||
* 校验并批量删除员工异动(入职/离职)信息
|
* 校验并批量删除员工异动(入职/离职)信息
|
||||||
*/
|
*/
|
||||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 员工入职
|
||||||
|
*/
|
||||||
|
Boolean employeeEntry(WmsEmployeeChangeBo bo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 员工离职
|
||||||
|
*/
|
||||||
|
Boolean employeeLeave(WmsEmployeeChangeBo bo);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,10 +9,13 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|||||||
import com.klp.common.utils.StringUtils;
|
import com.klp.common.utils.StringUtils;
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
import com.klp.domain.bo.WmsEmployeeChangeBo;
|
import com.klp.domain.bo.WmsEmployeeChangeBo;
|
||||||
import com.klp.domain.vo.WmsEmployeeChangeVo;
|
import com.klp.domain.vo.WmsEmployeeChangeVo;
|
||||||
import com.klp.domain.WmsEmployeeChange;
|
import com.klp.domain.WmsEmployeeChange;
|
||||||
|
import com.klp.domain.WmsEmployeeInfo;
|
||||||
import com.klp.mapper.WmsEmployeeChangeMapper;
|
import com.klp.mapper.WmsEmployeeChangeMapper;
|
||||||
|
import com.klp.mapper.WmsEmployeeInfoMapper;
|
||||||
import com.klp.service.IWmsEmployeeChangeService;
|
import com.klp.service.IWmsEmployeeChangeService;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -30,13 +33,19 @@ import java.util.Collection;
|
|||||||
public class WmsEmployeeChangeServiceImpl implements IWmsEmployeeChangeService {
|
public class WmsEmployeeChangeServiceImpl implements IWmsEmployeeChangeService {
|
||||||
|
|
||||||
private final WmsEmployeeChangeMapper baseMapper;
|
private final WmsEmployeeChangeMapper baseMapper;
|
||||||
|
private final WmsEmployeeInfoMapper wmsEmployeeInfoMapper;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询员工异动(入职/离职)
|
* 查询员工异动(入职/离职)
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public WmsEmployeeChangeVo queryById(Long changeId){
|
public WmsEmployeeChangeVo queryById(Long changeId){
|
||||||
return baseMapper.selectVoById(changeId);
|
WmsEmployeeChangeVo vo = baseMapper.selectVoById(changeId);
|
||||||
|
if (vo != null && vo.getInfoId() != null) {
|
||||||
|
WmsEmployeeInfo employee = wmsEmployeeInfoMapper.selectById(vo.getInfoId());
|
||||||
|
vo.setWmsEmployeeInfo(employee);
|
||||||
|
}
|
||||||
|
return vo;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -46,6 +55,10 @@ public class WmsEmployeeChangeServiceImpl implements IWmsEmployeeChangeService {
|
|||||||
public TableDataInfo<WmsEmployeeChangeVo> queryPageList(WmsEmployeeChangeBo bo, PageQuery pageQuery) {
|
public TableDataInfo<WmsEmployeeChangeVo> queryPageList(WmsEmployeeChangeBo bo, PageQuery pageQuery) {
|
||||||
LambdaQueryWrapper<WmsEmployeeChange> lqw = buildQueryWrapper(bo);
|
LambdaQueryWrapper<WmsEmployeeChange> lqw = buildQueryWrapper(bo);
|
||||||
Page<WmsEmployeeChangeVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
Page<WmsEmployeeChangeVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||||
|
for (WmsEmployeeChangeVo vo : result.getRecords()) {
|
||||||
|
WmsEmployeeInfo employee = wmsEmployeeInfoMapper.selectById(vo.getInfoId());
|
||||||
|
vo.setWmsEmployeeInfo(employee);
|
||||||
|
}
|
||||||
return TableDataInfo.build(result);
|
return TableDataInfo.build(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -55,7 +68,12 @@ public class WmsEmployeeChangeServiceImpl implements IWmsEmployeeChangeService {
|
|||||||
@Override
|
@Override
|
||||||
public List<WmsEmployeeChangeVo> queryList(WmsEmployeeChangeBo bo) {
|
public List<WmsEmployeeChangeVo> queryList(WmsEmployeeChangeBo bo) {
|
||||||
LambdaQueryWrapper<WmsEmployeeChange> lqw = buildQueryWrapper(bo);
|
LambdaQueryWrapper<WmsEmployeeChange> lqw = buildQueryWrapper(bo);
|
||||||
return baseMapper.selectVoList(lqw);
|
List<WmsEmployeeChangeVo> list = baseMapper.selectVoList(lqw);
|
||||||
|
for (WmsEmployeeChangeVo vo : list) {
|
||||||
|
WmsEmployeeInfo employee = wmsEmployeeInfoMapper.selectById(vo.getInfoId());
|
||||||
|
vo.setWmsEmployeeInfo(employee);
|
||||||
|
}
|
||||||
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
private LambdaQueryWrapper<WmsEmployeeChange> buildQueryWrapper(WmsEmployeeChangeBo bo) {
|
private LambdaQueryWrapper<WmsEmployeeChange> buildQueryWrapper(WmsEmployeeChangeBo bo) {
|
||||||
@@ -111,4 +129,80 @@ public class WmsEmployeeChangeServiceImpl implements IWmsEmployeeChangeService {
|
|||||||
}
|
}
|
||||||
return baseMapper.deleteBatchIds(ids) > 0;
|
return baseMapper.deleteBatchIds(ids) > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 员工入职
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public Boolean employeeEntry(WmsEmployeeChangeBo bo) {
|
||||||
|
WmsEmployeeInfo employee = new WmsEmployeeInfo();
|
||||||
|
employee.setSerialNumber(bo.getSerialNumber());
|
||||||
|
employee.setDept(bo.getDept());
|
||||||
|
employee.setJobType(bo.getJobType());
|
||||||
|
employee.setName(bo.getName());
|
||||||
|
employee.setIdCard(bo.getIdCard());
|
||||||
|
employee.setAge(bo.getAge());
|
||||||
|
employee.setGender(bo.getGender());
|
||||||
|
employee.setEducation(bo.getEducation());
|
||||||
|
employee.setHomeAddress(bo.getHomeAddress());
|
||||||
|
employee.setPhone(bo.getPhone());
|
||||||
|
employee.setEntryTime(bo.getEntryTime());
|
||||||
|
employee.setEmergencyContact(bo.getEmergencyContact());
|
||||||
|
employee.setRelationship(bo.getRelationship());
|
||||||
|
employee.setEmergencyContactPhone(bo.getEmergencyContactPhone());
|
||||||
|
employee.setSocialInsuranceType(bo.getSocialInsuranceType());
|
||||||
|
employee.setRemark(bo.getInfoRemark());
|
||||||
|
employee.setIsLeave(0);
|
||||||
|
boolean flag = wmsEmployeeInfoMapper.insert(employee) > 0;
|
||||||
|
if (!flag) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
Long infoId = employee.getInfoId();
|
||||||
|
|
||||||
|
WmsEmployeeChange change = new WmsEmployeeChange();
|
||||||
|
change.setInfoId(infoId);
|
||||||
|
change.setChangeType(0);
|
||||||
|
change.setChangeTime(bo.getChangeTime());
|
||||||
|
change.setChangeHandler(bo.getChangeHandler());
|
||||||
|
change.setAttachment(bo.getAttachment());
|
||||||
|
change.setCreateBy(bo.getCreateBy());
|
||||||
|
change.setRemark(bo.getRemark());
|
||||||
|
return baseMapper.insert(change) > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 员工离职
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
public Boolean employeeLeave(WmsEmployeeChangeBo bo) {
|
||||||
|
if (bo.getInfoId() == null) {
|
||||||
|
throw new RuntimeException("员工ID不能为空");
|
||||||
|
}
|
||||||
|
WmsEmployeeInfo employee = wmsEmployeeInfoMapper.selectById(bo.getInfoId());
|
||||||
|
if (employee == null) {
|
||||||
|
throw new RuntimeException("员工不存在");
|
||||||
|
}
|
||||||
|
if (employee.getIsLeave() != null && employee.getIsLeave() == 1) {
|
||||||
|
throw new RuntimeException("员工已离职");
|
||||||
|
}
|
||||||
|
|
||||||
|
employee.setIsLeave(1);
|
||||||
|
boolean flag = wmsEmployeeInfoMapper.updateById(employee) > 0;
|
||||||
|
if (!flag) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
WmsEmployeeChange change = new WmsEmployeeChange();
|
||||||
|
change.setInfoId(bo.getInfoId());
|
||||||
|
change.setChangeType(1);
|
||||||
|
change.setChangeTime(bo.getChangeTime());
|
||||||
|
change.setChangeReason(bo.getChangeReason());
|
||||||
|
change.setChangeHandler(bo.getChangeHandler());
|
||||||
|
change.setAttachment(bo.getAttachment());
|
||||||
|
change.setCreateBy(bo.getCreateBy());
|
||||||
|
change.setRemark(bo.getRemark());
|
||||||
|
return baseMapper.insert(change) > 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user