mirror of
https://codeup.aliyun.com/64f7d6b8ce01efaafef1e678/coal/coal.git
synced 2026-01-25 15:55:18 +08:00
添加员工历史记录
This commit is contained in:
@@ -14,6 +14,8 @@ import cn.lihongjie.coal.employee.dto.*;
|
||||
import cn.lihongjie.coal.employee.entity.EmployeeEntity;
|
||||
import cn.lihongjie.coal.employee.mapper.EmployeeMapper;
|
||||
import cn.lihongjie.coal.employee.repository.EmployeeRepository;
|
||||
import cn.lihongjie.coal.employeeHis.entity.EmployeeHisEntity;
|
||||
import cn.lihongjie.coal.employeeHis.service.EmployeeHisService;
|
||||
import cn.lihongjie.coal.exception.BizException;
|
||||
import cn.lihongjie.coal.file.service.FileService;
|
||||
import cn.lihongjie.coal.jobPost.dto.CreateJobPostDto;
|
||||
@@ -22,6 +24,8 @@ import cn.lihongjie.coal.jobPost.service.JobPostService;
|
||||
import cn.lihongjie.coal.organization.service.OrganizationService;
|
||||
import cn.lihongjie.coal.pojoProcessor.PojoProcessor;
|
||||
|
||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||
|
||||
import io.vavr.Function1;
|
||||
import io.vavr.Function2;
|
||||
|
||||
@@ -33,6 +37,7 @@ import lombok.SneakyThrows;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
|
||||
import org.apache.commons.collections4.CollectionUtils;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.core.convert.ConversionService;
|
||||
import org.springframework.data.domain.Page;
|
||||
@@ -66,8 +71,15 @@ public class EmployeeService extends BaseService<EmployeeEntity, EmployeeReposit
|
||||
return getById(entity.getId());
|
||||
}
|
||||
|
||||
@Autowired EmployeeHisService employeeHisService;
|
||||
@Autowired PojoProcessor pojoProcessor;
|
||||
@Autowired ObjectMapper objectMapper;
|
||||
|
||||
public EmployeeDto update(UpdateEmployeeDto request) {
|
||||
EmployeeEntity entity = this.repository.get(request.getId());
|
||||
|
||||
this.saveHis(entity);
|
||||
|
||||
this.mapper.updateEntity(entity, request);
|
||||
|
||||
this.repository.save(entity);
|
||||
@@ -75,14 +87,55 @@ public class EmployeeService extends BaseService<EmployeeEntity, EmployeeReposit
|
||||
return getById(entity.getId());
|
||||
}
|
||||
|
||||
private void saveHis(EmployeeEntity entity) {
|
||||
|
||||
EmployeeHisEntity his = getEmployeeHisEntity(entity);
|
||||
|
||||
employeeHisService.save(his);
|
||||
}
|
||||
|
||||
private @NotNull EmployeeHisEntity getEmployeeHisEntity(EmployeeEntity entity) {
|
||||
EmployeeHisEntity his = new EmployeeHisEntity();
|
||||
|
||||
his.setEmployeeId(entity.getId());
|
||||
his.setEmployeeName(entity.getName());
|
||||
his.setEmployeeCode(entity.getCode());
|
||||
his.setIdCard(entity.getIdCard());
|
||||
his.setPhone(entity.getPhone());
|
||||
his.setJsonStr(this.convertToHisJson(entity));
|
||||
return his;
|
||||
}
|
||||
|
||||
@SneakyThrows
|
||||
private String convertToHisJson(EmployeeEntity entity) {
|
||||
|
||||
EmployeeDto dto = this.toDto(entity);
|
||||
|
||||
pojoProcessor.process(dto, false);
|
||||
|
||||
return objectMapper.writeValueAsString(dto);
|
||||
}
|
||||
|
||||
public void delete(IdRequest request) {
|
||||
|
||||
if (this.repository.isLinked(request.getIds())) {
|
||||
throw new BizException("部分数据已被关联,无法删除");
|
||||
}
|
||||
|
||||
this.saveHis(request);
|
||||
this.repository.deleteAllById(request.getIds());
|
||||
}
|
||||
|
||||
private void saveHis(IdRequest request) {
|
||||
|
||||
List<EmployeeEntity> entities = this.repository.findAllById(request.getIds());
|
||||
|
||||
for (EmployeeEntity entity : entities) {
|
||||
|
||||
employeeHisService.save(getEmployeeHisEntity(entity));
|
||||
}
|
||||
}
|
||||
|
||||
@Autowired FileService fileService;
|
||||
|
||||
public EmployeeDto getById(String id) {
|
||||
@@ -182,7 +235,6 @@ public class EmployeeService extends BaseService<EmployeeEntity, EmployeeReposit
|
||||
return base64File;
|
||||
}
|
||||
|
||||
@Autowired PojoProcessor pojoProcessor;
|
||||
@Autowired OrganizationService organizationService;
|
||||
|
||||
public List<EmployeeDto> getDtoByIds(List<String> employeesIds) {
|
||||
|
||||
@@ -0,0 +1,54 @@
|
||||
package cn.lihongjie.coal.employeeHis.controller;
|
||||
|
||||
import cn.lihongjie.coal.annotation.OrgScope;
|
||||
import cn.lihongjie.coal.annotation.SysLog;
|
||||
import cn.lihongjie.coal.base.dto.CommonQuery;
|
||||
import cn.lihongjie.coal.base.dto.IdRequest;
|
||||
import cn.lihongjie.coal.employeeHis.dto.CreateEmployeeHisDto;
|
||||
import cn.lihongjie.coal.employeeHis.dto.EmployeeHisDto;
|
||||
import cn.lihongjie.coal.employeeHis.dto.UpdateEmployeeHisDto;
|
||||
import cn.lihongjie.coal.employeeHis.service.EmployeeHisService;
|
||||
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.data.domain.Page;
|
||||
import org.springframework.web.bind.annotation.PostMapping;
|
||||
import org.springframework.web.bind.annotation.RequestBody;
|
||||
import org.springframework.web.bind.annotation.RequestMapping;
|
||||
import org.springframework.web.bind.annotation.RestController;
|
||||
|
||||
@RestController
|
||||
@RequestMapping("/employeeHis")
|
||||
@SysLog(module = "人员历史记录")
|
||||
@Slf4j
|
||||
@OrgScope
|
||||
public class EmployeeHisController {
|
||||
@Autowired private EmployeeHisService service;
|
||||
|
||||
@PostMapping("/create")
|
||||
public EmployeeHisDto create(@RequestBody CreateEmployeeHisDto request) {
|
||||
return this.service.create(request);
|
||||
}
|
||||
|
||||
@PostMapping("/update")
|
||||
public EmployeeHisDto update(@RequestBody UpdateEmployeeHisDto request) {
|
||||
return this.service.update(request);
|
||||
}
|
||||
|
||||
@PostMapping("/delete")
|
||||
public Object delete(@RequestBody IdRequest request) {
|
||||
this.service.delete(request);
|
||||
return true;
|
||||
}
|
||||
|
||||
@PostMapping("/getById")
|
||||
public EmployeeHisDto getById(@RequestBody IdRequest request) {
|
||||
return this.service.getById(request.getId());
|
||||
}
|
||||
|
||||
@PostMapping("/list")
|
||||
public Page<EmployeeHisDto> list(@RequestBody CommonQuery request) {
|
||||
return this.service.list(request);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,25 @@
|
||||
package cn.lihongjie.coal.employeeHis.dto;
|
||||
|
||||
import cn.lihongjie.coal.base.dto.OrgCommonDto;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
public class CreateEmployeeHisDto extends OrgCommonDto {
|
||||
|
||||
private String employeeId;
|
||||
|
||||
private String employeeName;
|
||||
|
||||
private String employeeCode;
|
||||
|
||||
private String idCard;
|
||||
|
||||
private String phone;
|
||||
|
||||
|
||||
private String jsonStr;
|
||||
|
||||
|
||||
private Boolean isDeleted;
|
||||
}
|
||||
@@ -0,0 +1,25 @@
|
||||
package cn.lihongjie.coal.employeeHis.dto;
|
||||
|
||||
import cn.lihongjie.coal.base.dto.OrgCommonDto;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
public class EmployeeHisDto extends OrgCommonDto {
|
||||
|
||||
private String employeeId;
|
||||
|
||||
private String employeeName;
|
||||
|
||||
private String employeeCode;
|
||||
|
||||
private String idCard;
|
||||
|
||||
private String phone;
|
||||
|
||||
|
||||
private String jsonStr;
|
||||
|
||||
|
||||
private Boolean isDeleted;
|
||||
}
|
||||
@@ -0,0 +1,25 @@
|
||||
package cn.lihongjie.coal.employeeHis.dto;
|
||||
|
||||
import cn.lihongjie.coal.base.dto.OrgCommonDto;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
public class UpdateEmployeeHisDto extends OrgCommonDto {
|
||||
|
||||
private String employeeId;
|
||||
|
||||
private String employeeName;
|
||||
|
||||
private String employeeCode;
|
||||
|
||||
private String idCard;
|
||||
|
||||
private String phone;
|
||||
|
||||
|
||||
private String jsonStr;
|
||||
|
||||
|
||||
private Boolean isDeleted;
|
||||
}
|
||||
@@ -0,0 +1,30 @@
|
||||
package cn.lihongjie.coal.employeeHis.entity;
|
||||
|
||||
import cn.lihongjie.coal.base.entity.OrgCommonEntity;
|
||||
|
||||
import jakarta.persistence.Entity;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
@Entity
|
||||
public class EmployeeHisEntity extends OrgCommonEntity {
|
||||
|
||||
|
||||
private String employeeId;
|
||||
|
||||
private String employeeName;
|
||||
|
||||
private String employeeCode;
|
||||
|
||||
private String idCard;
|
||||
|
||||
private String phone;
|
||||
|
||||
|
||||
private String jsonStr;
|
||||
|
||||
|
||||
private Boolean isDeleted;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,20 @@
|
||||
package cn.lihongjie.coal.employeeHis.mapper;
|
||||
|
||||
import cn.lihongjie.coal.base.mapper.BaseMapper;
|
||||
import cn.lihongjie.coal.base.mapper.CommonEntityMapper;
|
||||
import cn.lihongjie.coal.base.mapper.CommonMapper;
|
||||
import cn.lihongjie.coal.employeeHis.dto.CreateEmployeeHisDto;
|
||||
import cn.lihongjie.coal.employeeHis.dto.EmployeeHisDto;
|
||||
import cn.lihongjie.coal.employeeHis.dto.UpdateEmployeeHisDto;
|
||||
import cn.lihongjie.coal.employeeHis.entity.EmployeeHisEntity;
|
||||
|
||||
import org.mapstruct.Mapper;
|
||||
import org.mapstruct.control.DeepClone;
|
||||
|
||||
@Mapper(
|
||||
componentModel = org.mapstruct.MappingConstants.ComponentModel.SPRING,
|
||||
uses = {CommonMapper.class, CommonEntityMapper.class},
|
||||
mappingControl = DeepClone.class)
|
||||
public interface EmployeeHisMapper
|
||||
extends BaseMapper<
|
||||
EmployeeHisEntity, EmployeeHisDto, CreateEmployeeHisDto, UpdateEmployeeHisDto> {}
|
||||
@@ -0,0 +1,15 @@
|
||||
package cn.lihongjie.coal.employeeHis.repository;
|
||||
|
||||
import cn.lihongjie.coal.base.dao.BaseRepository;
|
||||
import cn.lihongjie.coal.employeeHis.entity.EmployeeHisEntity;
|
||||
|
||||
import org.springframework.data.jpa.repository.Query;
|
||||
import org.springframework.stereotype.Repository;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Repository
|
||||
public interface EmployeeHisRepository extends BaseRepository<EmployeeHisEntity> {
|
||||
@Query("select false")
|
||||
boolean isLinked(List<String> ids);
|
||||
}
|
||||
@@ -0,0 +1,80 @@
|
||||
package cn.lihongjie.coal.employeeHis.service;
|
||||
|
||||
import cn.lihongjie.coal.base.dto.CommonQuery;
|
||||
import cn.lihongjie.coal.base.dto.IdRequest;
|
||||
import cn.lihongjie.coal.base.service.BaseService;
|
||||
import cn.lihongjie.coal.dbFunctions.DbFunctionService;
|
||||
import cn.lihongjie.coal.employeeHis.dto.CreateEmployeeHisDto;
|
||||
import cn.lihongjie.coal.employeeHis.dto.EmployeeHisDto;
|
||||
import cn.lihongjie.coal.employeeHis.dto.UpdateEmployeeHisDto;
|
||||
import cn.lihongjie.coal.employeeHis.entity.EmployeeHisEntity;
|
||||
import cn.lihongjie.coal.employeeHis.mapper.EmployeeHisMapper;
|
||||
import cn.lihongjie.coal.employeeHis.repository.EmployeeHisRepository;
|
||||
import cn.lihongjie.coal.exception.BizException;
|
||||
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.core.convert.ConversionService;
|
||||
import org.springframework.data.domain.Page;
|
||||
import org.springframework.data.domain.PageRequest;
|
||||
import org.springframework.data.domain.Sort;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
@Service
|
||||
@Slf4j
|
||||
@Transactional
|
||||
public class EmployeeHisService extends BaseService<EmployeeHisEntity, EmployeeHisRepository> {
|
||||
@Autowired private EmployeeHisRepository repository;
|
||||
|
||||
@Autowired private EmployeeHisMapper mapper;
|
||||
|
||||
@Autowired private ConversionService conversionService;
|
||||
|
||||
@Autowired private DbFunctionService dbFunctionService;
|
||||
|
||||
public EmployeeHisDto create(CreateEmployeeHisDto request) {
|
||||
EmployeeHisEntity entity = mapper.toEntity(request);
|
||||
|
||||
this.repository.save(entity);
|
||||
return getById(entity.getId());
|
||||
}
|
||||
|
||||
public EmployeeHisDto update(UpdateEmployeeHisDto request) {
|
||||
EmployeeHisEntity entity = this.repository.get(request.getId());
|
||||
this.mapper.updateEntity(entity, request);
|
||||
|
||||
this.repository.save(entity);
|
||||
|
||||
return getById(entity.getId());
|
||||
}
|
||||
|
||||
public void delete(IdRequest request) {
|
||||
boolean linked = this.repository.isLinked(request.getIds());
|
||||
|
||||
if (linked) {
|
||||
throw new BizException("数据已被关联,无法删除");
|
||||
}
|
||||
|
||||
this.repository.deleteAllById(request.getIds());
|
||||
}
|
||||
|
||||
public EmployeeHisDto getById(String id) {
|
||||
EmployeeHisEntity entity = repository.get(id);
|
||||
|
||||
return mapper.toDto(entity);
|
||||
}
|
||||
|
||||
public Page<EmployeeHisDto> list(CommonQuery query) {
|
||||
Page<EmployeeHisEntity> page =
|
||||
repository.findAll(
|
||||
query.specification(conversionService),
|
||||
PageRequest.of(
|
||||
query.getPageNo(),
|
||||
query.getPageSize(),
|
||||
Sort.by(query.getOrders())));
|
||||
|
||||
return page.map(this.mapper::toDto);
|
||||
}
|
||||
}
|
||||
17
src/main/resources/scripts/dict/enum/employeeHisDict.groovy
Normal file
17
src/main/resources/scripts/dict/enum/employeeHisDict.groovy
Normal file
@@ -0,0 +1,17 @@
|
||||
|
||||
package scripts.dict
|
||||
|
||||
import cn.lihongjie.coal.base.dto.CommonQuery
|
||||
import cn.lihongjie.coal.employeeHis.controller.EmployeeHisController
|
||||
import org.springframework.context.ApplicationContext
|
||||
|
||||
ApplicationContext ioc = ioc
|
||||
|
||||
def controller = ioc.getBean(EmployeeHisController.class)
|
||||
|
||||
|
||||
|
||||
|
||||
return controller.list(new CommonQuery())
|
||||
|
||||
|
||||
Reference in New Issue
Block a user