mirror of
https://codeup.aliyun.com/64f7d6b8ce01efaafef1e678/coal/coal.git
synced 2026-01-25 07:46:40 +08:00
员工工资表
This commit is contained in:
@@ -0,0 +1,66 @@
|
||||
package cn.lihongjie.coal.empSalary.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.empSalary.dto.CreateEmpSalaryDto;
|
||||
import cn.lihongjie.coal.empSalary.dto.EmpSalaryDto;
|
||||
import cn.lihongjie.coal.empSalary.dto.UpdateEmpSalaryDto;
|
||||
import cn.lihongjie.coal.empSalary.service.EmpSalaryService;
|
||||
|
||||
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("/empSalary")
|
||||
@SysLog(module = "员工工资记录")
|
||||
@Slf4j
|
||||
@OrgScope
|
||||
public class EmpSalaryController {
|
||||
@Autowired private EmpSalaryService service;
|
||||
|
||||
@PostMapping("/create")
|
||||
public EmpSalaryDto create(@RequestBody CreateEmpSalaryDto request) {
|
||||
return this.service.create(request);
|
||||
}
|
||||
|
||||
@PostMapping("/update")
|
||||
public EmpSalaryDto update(@RequestBody UpdateEmpSalaryDto request) {
|
||||
return this.service.update(request);
|
||||
}
|
||||
|
||||
@PostMapping("/delete")
|
||||
public Object delete(@RequestBody IdRequest request) {
|
||||
this.service.delete(request);
|
||||
return true;
|
||||
}
|
||||
|
||||
@PostMapping("/getById")
|
||||
public EmpSalaryDto getById(@RequestBody IdRequest request) {
|
||||
return this.service.getById(request.getId());
|
||||
}
|
||||
|
||||
@PostMapping("/list")
|
||||
public Page<EmpSalaryDto> list(@RequestBody CommonQuery request) {
|
||||
return this.service.list(request);
|
||||
}
|
||||
|
||||
@PostMapping("/archive")
|
||||
public Object archive(@RequestBody IdRequest request) {
|
||||
this.service.archive(request);
|
||||
return true;
|
||||
}
|
||||
|
||||
@PostMapping("/unarchive")
|
||||
public Object unarchive(@RequestBody IdRequest request) {
|
||||
this.service.unarchive(request);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,74 @@
|
||||
package cn.lihongjie.coal.empSalary.dto;
|
||||
|
||||
import cn.lihongjie.coal.base.dto.OrgCommonDto;
|
||||
|
||||
import jakarta.persistence.ManyToOne;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
@Data
|
||||
public class CreateEmpSalaryDto extends OrgCommonDto {
|
||||
|
||||
|
||||
@ManyToOne
|
||||
private String batch;
|
||||
|
||||
@ManyToOne
|
||||
private String employee;
|
||||
|
||||
|
||||
private BigDecimal item0;
|
||||
private BigDecimal item1;
|
||||
private BigDecimal item2;
|
||||
private BigDecimal item3;
|
||||
private BigDecimal item4;
|
||||
private BigDecimal item5;
|
||||
private BigDecimal item6;
|
||||
private BigDecimal item7;
|
||||
private BigDecimal item8;
|
||||
private BigDecimal item9;
|
||||
private BigDecimal item10;
|
||||
private BigDecimal item11;
|
||||
private BigDecimal item12;
|
||||
private BigDecimal item13;
|
||||
private BigDecimal item14;
|
||||
private BigDecimal item15;
|
||||
private BigDecimal item16;
|
||||
private BigDecimal item17;
|
||||
private BigDecimal item18;
|
||||
private BigDecimal item19;
|
||||
private BigDecimal item20;
|
||||
private BigDecimal item21;
|
||||
private BigDecimal item22;
|
||||
private BigDecimal item23;
|
||||
private BigDecimal item24;
|
||||
private BigDecimal item25;
|
||||
private BigDecimal item26;
|
||||
private BigDecimal item27;
|
||||
private BigDecimal item28;
|
||||
private BigDecimal item29;
|
||||
private BigDecimal item30;
|
||||
private BigDecimal item31;
|
||||
private BigDecimal item32;
|
||||
private BigDecimal item33;
|
||||
private BigDecimal item34;
|
||||
private BigDecimal item35;
|
||||
private BigDecimal item36;
|
||||
private BigDecimal item37;
|
||||
private BigDecimal item38;
|
||||
private BigDecimal item39;
|
||||
private BigDecimal item40;
|
||||
private BigDecimal item41;
|
||||
private BigDecimal item42;
|
||||
private BigDecimal item43;
|
||||
private BigDecimal item44;
|
||||
private BigDecimal item45;
|
||||
private BigDecimal item46;
|
||||
private BigDecimal item47;
|
||||
private BigDecimal item48;
|
||||
private BigDecimal item49;
|
||||
private BigDecimal item50;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,82 @@
|
||||
package cn.lihongjie.coal.empSalary.dto;
|
||||
|
||||
import cn.lihongjie.coal.base.dto.OrgCommonDto;
|
||||
import cn.lihongjie.coal.empSalaryBatch.dto.EmpSalaryBatchDto;
|
||||
import cn.lihongjie.coal.employee.dto.EmployeeDto;
|
||||
|
||||
import jakarta.persistence.ManyToOne;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import org.hibernate.annotations.Comment;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
@Data
|
||||
public class EmpSalaryDto extends OrgCommonDto {
|
||||
private String archiveStatus;
|
||||
|
||||
private String archiveStatusName;
|
||||
|
||||
@ManyToOne
|
||||
private EmpSalaryBatchDto batch;
|
||||
|
||||
@ManyToOne
|
||||
private EmployeeDto employee;
|
||||
|
||||
|
||||
@Comment("员工快照")
|
||||
private String employeeSnapshot;
|
||||
|
||||
private BigDecimal item0;
|
||||
private BigDecimal item1;
|
||||
private BigDecimal item2;
|
||||
private BigDecimal item3;
|
||||
private BigDecimal item4;
|
||||
private BigDecimal item5;
|
||||
private BigDecimal item6;
|
||||
private BigDecimal item7;
|
||||
private BigDecimal item8;
|
||||
private BigDecimal item9;
|
||||
private BigDecimal item10;
|
||||
private BigDecimal item11;
|
||||
private BigDecimal item12;
|
||||
private BigDecimal item13;
|
||||
private BigDecimal item14;
|
||||
private BigDecimal item15;
|
||||
private BigDecimal item16;
|
||||
private BigDecimal item17;
|
||||
private BigDecimal item18;
|
||||
private BigDecimal item19;
|
||||
private BigDecimal item20;
|
||||
private BigDecimal item21;
|
||||
private BigDecimal item22;
|
||||
private BigDecimal item23;
|
||||
private BigDecimal item24;
|
||||
private BigDecimal item25;
|
||||
private BigDecimal item26;
|
||||
private BigDecimal item27;
|
||||
private BigDecimal item28;
|
||||
private BigDecimal item29;
|
||||
private BigDecimal item30;
|
||||
private BigDecimal item31;
|
||||
private BigDecimal item32;
|
||||
private BigDecimal item33;
|
||||
private BigDecimal item34;
|
||||
private BigDecimal item35;
|
||||
private BigDecimal item36;
|
||||
private BigDecimal item37;
|
||||
private BigDecimal item38;
|
||||
private BigDecimal item39;
|
||||
private BigDecimal item40;
|
||||
private BigDecimal item41;
|
||||
private BigDecimal item42;
|
||||
private BigDecimal item43;
|
||||
private BigDecimal item44;
|
||||
private BigDecimal item45;
|
||||
private BigDecimal item46;
|
||||
private BigDecimal item47;
|
||||
private BigDecimal item48;
|
||||
private BigDecimal item49;
|
||||
private BigDecimal item50;
|
||||
}
|
||||
@@ -0,0 +1,74 @@
|
||||
package cn.lihongjie.coal.empSalary.dto;
|
||||
|
||||
import cn.lihongjie.coal.base.dto.OrgCommonDto;
|
||||
|
||||
import jakarta.persistence.ManyToOne;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
@Data
|
||||
public class UpdateEmpSalaryDto extends OrgCommonDto {
|
||||
|
||||
|
||||
@ManyToOne
|
||||
private String batch;
|
||||
|
||||
@ManyToOne
|
||||
private String employee;
|
||||
|
||||
|
||||
private BigDecimal item0;
|
||||
private BigDecimal item1;
|
||||
private BigDecimal item2;
|
||||
private BigDecimal item3;
|
||||
private BigDecimal item4;
|
||||
private BigDecimal item5;
|
||||
private BigDecimal item6;
|
||||
private BigDecimal item7;
|
||||
private BigDecimal item8;
|
||||
private BigDecimal item9;
|
||||
private BigDecimal item10;
|
||||
private BigDecimal item11;
|
||||
private BigDecimal item12;
|
||||
private BigDecimal item13;
|
||||
private BigDecimal item14;
|
||||
private BigDecimal item15;
|
||||
private BigDecimal item16;
|
||||
private BigDecimal item17;
|
||||
private BigDecimal item18;
|
||||
private BigDecimal item19;
|
||||
private BigDecimal item20;
|
||||
private BigDecimal item21;
|
||||
private BigDecimal item22;
|
||||
private BigDecimal item23;
|
||||
private BigDecimal item24;
|
||||
private BigDecimal item25;
|
||||
private BigDecimal item26;
|
||||
private BigDecimal item27;
|
||||
private BigDecimal item28;
|
||||
private BigDecimal item29;
|
||||
private BigDecimal item30;
|
||||
private BigDecimal item31;
|
||||
private BigDecimal item32;
|
||||
private BigDecimal item33;
|
||||
private BigDecimal item34;
|
||||
private BigDecimal item35;
|
||||
private BigDecimal item36;
|
||||
private BigDecimal item37;
|
||||
private BigDecimal item38;
|
||||
private BigDecimal item39;
|
||||
private BigDecimal item40;
|
||||
private BigDecimal item41;
|
||||
private BigDecimal item42;
|
||||
private BigDecimal item43;
|
||||
private BigDecimal item44;
|
||||
private BigDecimal item45;
|
||||
private BigDecimal item46;
|
||||
private BigDecimal item47;
|
||||
private BigDecimal item48;
|
||||
private BigDecimal item49;
|
||||
private BigDecimal item50;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,97 @@
|
||||
package cn.lihongjie.coal.empSalary.entity;
|
||||
|
||||
import cn.lihongjie.coal.base.entity.OrgCommonEntity;
|
||||
import cn.lihongjie.coal.empSalaryBatch.entity.EmpSalaryBatchEntity;
|
||||
import cn.lihongjie.coal.employee.entity.EmployeeEntity;
|
||||
|
||||
import jakarta.persistence.Entity;
|
||||
import jakarta.persistence.ManyToOne;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import org.hibernate.annotations.ColumnDefault;
|
||||
import org.hibernate.annotations.Comment;
|
||||
import org.hibernate.annotations.Formula;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
@Data
|
||||
@Entity
|
||||
public class EmpSalaryEntity extends OrgCommonEntity {
|
||||
|
||||
@ManyToOne
|
||||
private EmpSalaryBatchEntity batch;
|
||||
|
||||
@ManyToOne
|
||||
private EmployeeEntity employee;
|
||||
|
||||
|
||||
@Comment("员工快照")
|
||||
private String employeeSnapshot;
|
||||
|
||||
private BigDecimal item0;
|
||||
private BigDecimal item1;
|
||||
private BigDecimal item2;
|
||||
private BigDecimal item3;
|
||||
private BigDecimal item4;
|
||||
private BigDecimal item5;
|
||||
private BigDecimal item6;
|
||||
private BigDecimal item7;
|
||||
private BigDecimal item8;
|
||||
private BigDecimal item9;
|
||||
private BigDecimal item10;
|
||||
private BigDecimal item11;
|
||||
private BigDecimal item12;
|
||||
private BigDecimal item13;
|
||||
private BigDecimal item14;
|
||||
private BigDecimal item15;
|
||||
private BigDecimal item16;
|
||||
private BigDecimal item17;
|
||||
private BigDecimal item18;
|
||||
private BigDecimal item19;
|
||||
private BigDecimal item20;
|
||||
private BigDecimal item21;
|
||||
private BigDecimal item22;
|
||||
private BigDecimal item23;
|
||||
private BigDecimal item24;
|
||||
private BigDecimal item25;
|
||||
private BigDecimal item26;
|
||||
private BigDecimal item27;
|
||||
private BigDecimal item28;
|
||||
private BigDecimal item29;
|
||||
private BigDecimal item30;
|
||||
private BigDecimal item31;
|
||||
private BigDecimal item32;
|
||||
private BigDecimal item33;
|
||||
private BigDecimal item34;
|
||||
private BigDecimal item35;
|
||||
private BigDecimal item36;
|
||||
private BigDecimal item37;
|
||||
private BigDecimal item38;
|
||||
private BigDecimal item39;
|
||||
private BigDecimal item40;
|
||||
private BigDecimal item41;
|
||||
private BigDecimal item42;
|
||||
private BigDecimal item43;
|
||||
private BigDecimal item44;
|
||||
private BigDecimal item45;
|
||||
private BigDecimal item46;
|
||||
private BigDecimal item47;
|
||||
private BigDecimal item48;
|
||||
private BigDecimal item49;
|
||||
private BigDecimal item50;
|
||||
|
||||
|
||||
@Comment("归档状态")
|
||||
@ColumnDefault("'0'")
|
||||
private String archiveStatus;
|
||||
|
||||
@Formula(
|
||||
"(select i.name\n"
|
||||
+ "from t_dictionary d,\n"
|
||||
+ " t_dictionary_item i\n"
|
||||
+ "where d.id = i.dictionary_id\n"
|
||||
+ " and d.code = 'archiveStatus'\n"
|
||||
+ " and i.code = archive_status)")
|
||||
private String archiveStatusName;
|
||||
}
|
||||
@@ -0,0 +1,19 @@
|
||||
package cn.lihongjie.coal.empSalary.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.empSalary.dto.CreateEmpSalaryDto;
|
||||
import cn.lihongjie.coal.empSalary.dto.EmpSalaryDto;
|
||||
import cn.lihongjie.coal.empSalary.dto.UpdateEmpSalaryDto;
|
||||
import cn.lihongjie.coal.empSalary.entity.EmpSalaryEntity;
|
||||
|
||||
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 EmpSalaryMapper
|
||||
extends BaseMapper<EmpSalaryEntity, EmpSalaryDto, CreateEmpSalaryDto, UpdateEmpSalaryDto> {}
|
||||
@@ -0,0 +1,9 @@
|
||||
package cn.lihongjie.coal.empSalary.repository;
|
||||
|
||||
import cn.lihongjie.coal.base.dao.BaseRepository;
|
||||
import cn.lihongjie.coal.empSalary.entity.EmpSalaryEntity;
|
||||
|
||||
import org.springframework.stereotype.Repository;
|
||||
|
||||
@Repository
|
||||
public interface EmpSalaryRepository extends BaseRepository<EmpSalaryEntity> {}
|
||||
@@ -0,0 +1,117 @@
|
||||
package cn.lihongjie.coal.empSalary.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.common.ArchiveUtils;
|
||||
import cn.lihongjie.coal.empSalary.dto.CreateEmpSalaryDto;
|
||||
import cn.lihongjie.coal.empSalary.dto.EmpSalaryDto;
|
||||
import cn.lihongjie.coal.empSalary.dto.UpdateEmpSalaryDto;
|
||||
import cn.lihongjie.coal.empSalary.entity.EmpSalaryEntity;
|
||||
import cn.lihongjie.coal.empSalary.mapper.EmpSalaryMapper;
|
||||
import cn.lihongjie.coal.empSalary.repository.EmpSalaryRepository;
|
||||
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 EmpSalaryService extends BaseService<EmpSalaryEntity, EmpSalaryRepository> {
|
||||
@Autowired private EmpSalaryRepository repository;
|
||||
|
||||
@Autowired private EmpSalaryMapper mapper;
|
||||
|
||||
@Autowired private ConversionService conversionService;
|
||||
|
||||
public EmpSalaryDto create(CreateEmpSalaryDto request) {
|
||||
EmpSalaryEntity entity = mapper.toEntity(request);
|
||||
|
||||
this.repository.save(entity);
|
||||
return getById(entity.getId());
|
||||
}
|
||||
|
||||
public EmpSalaryDto update(UpdateEmpSalaryDto request) {
|
||||
EmpSalaryEntity entity = this.repository.get(request.getId());
|
||||
ArchiveUtils.checkArchiveStatus(
|
||||
entity,
|
||||
EmpSalaryEntity::getArchiveStatus,
|
||||
x -> "0",
|
||||
(e, actual, expected) -> {
|
||||
throw new BizException("数据 " + "已归档,无法编辑");
|
||||
});
|
||||
this.mapper.updateEntity(entity, request);
|
||||
|
||||
this.repository.save(entity);
|
||||
|
||||
return getById(entity.getId());
|
||||
}
|
||||
|
||||
public void delete(IdRequest request) {
|
||||
ArchiveUtils.checkArchiveStatus(
|
||||
this.repository::findAllById,
|
||||
request.getIds(),
|
||||
EmpSalaryEntity::getArchiveStatus,
|
||||
x -> "0",
|
||||
(e, actual, expected) -> {
|
||||
throw new BizException("数据 " + "已归档,无法删除");
|
||||
});
|
||||
this.repository.deleteAllById(request.getIds());
|
||||
}
|
||||
|
||||
public EmpSalaryDto getById(String id) {
|
||||
EmpSalaryEntity entity = repository.get(id);
|
||||
|
||||
return mapper.toDto(entity);
|
||||
}
|
||||
|
||||
public Page<EmpSalaryDto> list(CommonQuery query) {
|
||||
Page<EmpSalaryEntity> page =
|
||||
repository.findAll(
|
||||
query.specification(conversionService),
|
||||
PageRequest.of(
|
||||
query.getPageNo(),
|
||||
query.getPageSize(),
|
||||
Sort.by(query.getOrders())));
|
||||
|
||||
return page.map(this.mapper::toDto);
|
||||
}
|
||||
|
||||
public void archive(IdRequest dto) {
|
||||
this.repository.findAllById(dto.getIds()).stream()
|
||||
.peek(
|
||||
x ->
|
||||
ArchiveUtils.checkArchiveStatus(
|
||||
x,
|
||||
EmpSalaryEntity::getArchiveStatus,
|
||||
y -> "0",
|
||||
(e, actual, expected) -> {
|
||||
throw new BizException("数据 " + "已归档,无法再次归档");
|
||||
}))
|
||||
.peek(x -> x.setArchiveStatus("1"))
|
||||
.forEach(this.repository::save);
|
||||
}
|
||||
|
||||
public void unarchive(IdRequest dto) {
|
||||
this.repository.findAllById(dto.getIds()).stream()
|
||||
.peek(
|
||||
x ->
|
||||
ArchiveUtils.checkArchiveStatus(
|
||||
x,
|
||||
EmpSalaryEntity::getArchiveStatus,
|
||||
y -> "1",
|
||||
(e, actual, expected) -> {
|
||||
throw new BizException("数据" + "未归档,无法取消归档");
|
||||
}))
|
||||
.peek(x -> x.setArchiveStatus("0"))
|
||||
.forEach(this.repository::save);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,66 @@
|
||||
package cn.lihongjie.coal.empSalaryBatch.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.empSalaryBatch.dto.CreateEmpSalaryBatchDto;
|
||||
import cn.lihongjie.coal.empSalaryBatch.dto.EmpSalaryBatchDto;
|
||||
import cn.lihongjie.coal.empSalaryBatch.dto.UpdateEmpSalaryBatchDto;
|
||||
import cn.lihongjie.coal.empSalaryBatch.service.EmpSalaryBatchService;
|
||||
|
||||
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("/empSalaryBatch")
|
||||
@SysLog(module = "员工工资批次")
|
||||
@Slf4j
|
||||
@OrgScope
|
||||
public class EmpSalaryBatchController {
|
||||
@Autowired private EmpSalaryBatchService service;
|
||||
|
||||
@PostMapping("/create")
|
||||
public EmpSalaryBatchDto create(@RequestBody CreateEmpSalaryBatchDto request) {
|
||||
return this.service.create(request);
|
||||
}
|
||||
|
||||
@PostMapping("/update")
|
||||
public EmpSalaryBatchDto update(@RequestBody UpdateEmpSalaryBatchDto request) {
|
||||
return this.service.update(request);
|
||||
}
|
||||
|
||||
@PostMapping("/delete")
|
||||
public Object delete(@RequestBody IdRequest request) {
|
||||
this.service.delete(request);
|
||||
return true;
|
||||
}
|
||||
|
||||
@PostMapping("/getById")
|
||||
public EmpSalaryBatchDto getById(@RequestBody IdRequest request) {
|
||||
return this.service.getById(request.getId());
|
||||
}
|
||||
|
||||
@PostMapping("/list")
|
||||
public Page<EmpSalaryBatchDto> list(@RequestBody CommonQuery request) {
|
||||
return this.service.list(request);
|
||||
}
|
||||
|
||||
@PostMapping("/archive")
|
||||
public Object archive(@RequestBody IdRequest request) {
|
||||
this.service.archive(request);
|
||||
return true;
|
||||
}
|
||||
|
||||
@PostMapping("/unarchive")
|
||||
public Object unarchive(@RequestBody IdRequest request) {
|
||||
this.service.unarchive(request);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,8 @@
|
||||
package cn.lihongjie.coal.empSalaryBatch.dto;
|
||||
|
||||
import cn.lihongjie.coal.base.dto.OrgCommonDto;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
public class CreateEmpSalaryBatchDto extends OrgCommonDto {}
|
||||
@@ -0,0 +1,12 @@
|
||||
package cn.lihongjie.coal.empSalaryBatch.dto;
|
||||
|
||||
import cn.lihongjie.coal.base.dto.OrgCommonDto;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
public class EmpSalaryBatchDto extends OrgCommonDto {
|
||||
private String archiveStatus;
|
||||
|
||||
private String archiveStatusName;
|
||||
}
|
||||
@@ -0,0 +1,8 @@
|
||||
package cn.lihongjie.coal.empSalaryBatch.dto;
|
||||
|
||||
import cn.lihongjie.coal.base.dto.OrgCommonDto;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
public class UpdateEmpSalaryBatchDto extends OrgCommonDto {}
|
||||
@@ -0,0 +1,37 @@
|
||||
package cn.lihongjie.coal.empSalaryBatch.entity;
|
||||
|
||||
import cn.lihongjie.coal.base.entity.OrgCommonEntity;
|
||||
|
||||
import jakarta.persistence.Entity;
|
||||
|
||||
import lombok.Data;
|
||||
|
||||
import org.hibernate.annotations.ColumnDefault;
|
||||
import org.hibernate.annotations.Comment;
|
||||
import org.hibernate.annotations.Formula;
|
||||
|
||||
import java.time.LocalDate;
|
||||
|
||||
@Data
|
||||
@Entity
|
||||
public class EmpSalaryBatchEntity extends OrgCommonEntity {
|
||||
|
||||
@Comment("批次年月")
|
||||
private LocalDate batchYearMonth;
|
||||
|
||||
@Comment("批次号")
|
||||
private String batchNo;
|
||||
|
||||
@Comment("归档状态")
|
||||
@ColumnDefault("'0'")
|
||||
private String archiveStatus;
|
||||
|
||||
@Formula(
|
||||
"(select i.name\n"
|
||||
+ "from t_dictionary d,\n"
|
||||
+ " t_dictionary_item i\n"
|
||||
+ "where d.id = i.dictionary_id\n"
|
||||
+ " and d.code = 'archiveStatus'\n"
|
||||
+ " and i.code = archive_status)")
|
||||
private String archiveStatusName;
|
||||
}
|
||||
@@ -0,0 +1,23 @@
|
||||
package cn.lihongjie.coal.empSalaryBatch.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.empSalaryBatch.dto.CreateEmpSalaryBatchDto;
|
||||
import cn.lihongjie.coal.empSalaryBatch.dto.EmpSalaryBatchDto;
|
||||
import cn.lihongjie.coal.empSalaryBatch.dto.UpdateEmpSalaryBatchDto;
|
||||
import cn.lihongjie.coal.empSalaryBatch.entity.EmpSalaryBatchEntity;
|
||||
|
||||
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 EmpSalaryBatchMapper
|
||||
extends BaseMapper<
|
||||
EmpSalaryBatchEntity,
|
||||
EmpSalaryBatchDto,
|
||||
CreateEmpSalaryBatchDto,
|
||||
UpdateEmpSalaryBatchDto> {}
|
||||
@@ -0,0 +1,9 @@
|
||||
package cn.lihongjie.coal.empSalaryBatch.repository;
|
||||
|
||||
import cn.lihongjie.coal.base.dao.BaseRepository;
|
||||
import cn.lihongjie.coal.empSalaryBatch.entity.EmpSalaryBatchEntity;
|
||||
|
||||
import org.springframework.stereotype.Repository;
|
||||
|
||||
@Repository
|
||||
public interface EmpSalaryBatchRepository extends BaseRepository<EmpSalaryBatchEntity> {}
|
||||
@@ -0,0 +1,118 @@
|
||||
package cn.lihongjie.coal.empSalaryBatch.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.common.ArchiveUtils;
|
||||
import cn.lihongjie.coal.empSalaryBatch.dto.CreateEmpSalaryBatchDto;
|
||||
import cn.lihongjie.coal.empSalaryBatch.dto.EmpSalaryBatchDto;
|
||||
import cn.lihongjie.coal.empSalaryBatch.dto.UpdateEmpSalaryBatchDto;
|
||||
import cn.lihongjie.coal.empSalaryBatch.entity.EmpSalaryBatchEntity;
|
||||
import cn.lihongjie.coal.empSalaryBatch.mapper.EmpSalaryBatchMapper;
|
||||
import cn.lihongjie.coal.empSalaryBatch.repository.EmpSalaryBatchRepository;
|
||||
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 EmpSalaryBatchService
|
||||
extends BaseService<EmpSalaryBatchEntity, EmpSalaryBatchRepository> {
|
||||
@Autowired private EmpSalaryBatchRepository repository;
|
||||
|
||||
@Autowired private EmpSalaryBatchMapper mapper;
|
||||
|
||||
@Autowired private ConversionService conversionService;
|
||||
|
||||
public EmpSalaryBatchDto create(CreateEmpSalaryBatchDto request) {
|
||||
EmpSalaryBatchEntity entity = mapper.toEntity(request);
|
||||
|
||||
this.repository.save(entity);
|
||||
return getById(entity.getId());
|
||||
}
|
||||
|
||||
public EmpSalaryBatchDto update(UpdateEmpSalaryBatchDto request) {
|
||||
EmpSalaryBatchEntity entity = this.repository.get(request.getId());
|
||||
ArchiveUtils.checkArchiveStatus(
|
||||
entity,
|
||||
EmpSalaryBatchEntity::getArchiveStatus,
|
||||
x -> "0",
|
||||
(e, actual, expected) -> {
|
||||
throw new BizException("数据 " + "已归档,无法编辑");
|
||||
});
|
||||
this.mapper.updateEntity(entity, request);
|
||||
|
||||
this.repository.save(entity);
|
||||
|
||||
return getById(entity.getId());
|
||||
}
|
||||
|
||||
public void delete(IdRequest request) {
|
||||
ArchiveUtils.checkArchiveStatus(
|
||||
this.repository::findAllById,
|
||||
request.getIds(),
|
||||
EmpSalaryBatchEntity::getArchiveStatus,
|
||||
x -> "0",
|
||||
(e, actual, expected) -> {
|
||||
throw new BizException("数据 " + "已归档,无法删除");
|
||||
});
|
||||
this.repository.deleteAllById(request.getIds());
|
||||
}
|
||||
|
||||
public EmpSalaryBatchDto getById(String id) {
|
||||
EmpSalaryBatchEntity entity = repository.get(id);
|
||||
|
||||
return mapper.toDto(entity);
|
||||
}
|
||||
|
||||
public Page<EmpSalaryBatchDto> list(CommonQuery query) {
|
||||
Page<EmpSalaryBatchEntity> page =
|
||||
repository.findAll(
|
||||
query.specification(conversionService),
|
||||
PageRequest.of(
|
||||
query.getPageNo(),
|
||||
query.getPageSize(),
|
||||
Sort.by(query.getOrders())));
|
||||
|
||||
return page.map(this.mapper::toDto);
|
||||
}
|
||||
|
||||
public void archive(IdRequest dto) {
|
||||
this.repository.findAllById(dto.getIds()).stream()
|
||||
.peek(
|
||||
x ->
|
||||
ArchiveUtils.checkArchiveStatus(
|
||||
x,
|
||||
EmpSalaryBatchEntity::getArchiveStatus,
|
||||
y -> "0",
|
||||
(e, actual, expected) -> {
|
||||
throw new BizException("数据 " + "已归档,无法再次归档");
|
||||
}))
|
||||
.peek(x -> x.setArchiveStatus("1"))
|
||||
.forEach(this.repository::save);
|
||||
}
|
||||
|
||||
public void unarchive(IdRequest dto) {
|
||||
this.repository.findAllById(dto.getIds()).stream()
|
||||
.peek(
|
||||
x ->
|
||||
ArchiveUtils.checkArchiveStatus(
|
||||
x,
|
||||
EmpSalaryBatchEntity::getArchiveStatus,
|
||||
y -> "1",
|
||||
(e, actual, expected) -> {
|
||||
throw new BizException("数据" + "未归档,无法取消归档");
|
||||
}))
|
||||
.peek(x -> x.setArchiveStatus("0"))
|
||||
.forEach(this.repository::save);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,17 @@
|
||||
|
||||
package scripts.dict
|
||||
|
||||
import cn.lihongjie.coal.base.dto.CommonQuery
|
||||
import cn.lihongjie.coal.empSalaryBatch.controller.EmpSalaryBatchController
|
||||
import org.springframework.context.ApplicationContext
|
||||
|
||||
ApplicationContext ioc = ioc
|
||||
|
||||
def controller = ioc.getBean(EmpSalaryBatchController.class)
|
||||
|
||||
|
||||
|
||||
|
||||
return controller.list(new CommonQuery())
|
||||
|
||||
|
||||
17
src/main/resources/scripts/dict/enum/empSalaryDict.groovy
Normal file
17
src/main/resources/scripts/dict/enum/empSalaryDict.groovy
Normal file
@@ -0,0 +1,17 @@
|
||||
|
||||
package scripts.dict
|
||||
|
||||
import cn.lihongjie.coal.base.dto.CommonQuery
|
||||
import cn.lihongjie.coal.empSalary.controller.EmpSalaryController
|
||||
import org.springframework.context.ApplicationContext
|
||||
|
||||
ApplicationContext ioc = ioc
|
||||
|
||||
def controller = ioc.getBean(EmpSalaryController.class)
|
||||
|
||||
|
||||
|
||||
|
||||
return controller.list(new CommonQuery())
|
||||
|
||||
|
||||
Reference in New Issue
Block a user