weaver-hrm-salary/src/com/engine/salary/service/impl/SalarySobItemServiceImpl.java

1068 lines
63 KiB
Java
Raw Normal View History

2022-03-21 20:09:10 +08:00
package com.engine.salary.service.impl;
2022-03-23 20:54:08 +08:00
import com.engine.common.util.ServiceUtil;
2022-03-21 20:09:10 +08:00
import com.engine.core.impl.Service;
2024-05-30 15:19:15 +08:00
import com.engine.hrmelog.entity.dto.LoggerContext;
2022-03-23 18:41:38 +08:00
import com.engine.salary.biz.SalarySobBiz;
2022-03-21 20:09:10 +08:00
import com.engine.salary.biz.SalarySobItemBiz;
2022-03-25 10:31:31 +08:00
import com.engine.salary.biz.SalarySobItemGroupBiz;
2023-02-09 15:33:35 +08:00
import com.engine.salary.biz.SalarySobItemHideBiz;
2024-01-30 09:58:13 +08:00
import com.engine.salary.config.SalaryElogConfig;
2022-03-25 10:31:31 +08:00
import com.engine.salary.constant.SalaryDefaultTenantConstant;
2025-04-22 15:33:28 +08:00
import com.engine.salary.entity.datacollection.AddUpDeduction;
import com.engine.salary.entity.datacollection.AddUpSituation;
import com.engine.salary.entity.datacollection.DataCollectionEmployee;
import com.engine.salary.entity.datacollection.dto.AttendQuoteDataDTO;
import com.engine.salary.entity.datacollection.dto.AttendQuoteFieldListDTO;
import com.engine.salary.entity.datacollection.po.OtherDeductionPO;
import com.engine.salary.entity.datacollection.po.VariableItemPO;
import com.engine.salary.entity.salaryacct.bo.CalculateFormulaVarBO;
import com.engine.salary.entity.salaryacct.bo.SalaryAcctCalculateBO;
2023-11-17 16:00:59 +08:00
import com.engine.salary.entity.salaryacct.bo.SalaryAcctCalculatePriorityBO;
2024-05-06 16:03:29 +08:00
import com.engine.salary.entity.salaryacct.bo.SalaryAcctConfig;
2025-04-22 15:33:28 +08:00
import com.engine.salary.entity.salaryacct.po.SalaryAcctEmployeePO;
import com.engine.salary.entity.salaryacct.po.SalaryAcctRecordPO;
2024-05-30 15:19:15 +08:00
import com.engine.salary.entity.salaryacct.po.SalaryAcctResultPO;
2025-04-22 15:33:28 +08:00
import com.engine.salary.entity.salaryarchive.dto.SalaryArchiveDataDTO;
2022-04-14 20:46:17 +08:00
import com.engine.salary.entity.salaryformula.ExpressFormula;
2024-08-13 18:15:04 +08:00
import com.engine.salary.entity.salaryformula.config.FormluaConfig;
import com.engine.salary.entity.salaryformula.po.FormulaPO;
import com.engine.salary.entity.salaryformula.po.FormulaVar;
2022-03-23 18:41:38 +08:00
import com.engine.salary.entity.salaryitem.po.SalaryItemPO;
import com.engine.salary.entity.salarysob.bo.SalarySobItemAggregateBO;
2023-10-17 10:24:30 +08:00
import com.engine.salary.entity.salarysob.dto.SalaryItemTopologyDTO;
2025-04-22 15:33:28 +08:00
import com.engine.salary.entity.salarysob.dto.SalarySobCycleDTO;
2022-03-23 18:41:38 +08:00
import com.engine.salary.entity.salarysob.dto.SalarySobItemAggregateDTO;
2023-07-24 17:11:19 +08:00
import com.engine.salary.entity.salarysob.dto.SalarySobItemFormDTO;
2023-10-16 15:00:54 +08:00
import com.engine.salary.entity.salarysob.param.SalaryItemTopologyQueryParam;
2022-03-23 18:41:38 +08:00
import com.engine.salary.entity.salarysob.param.SalarySobItemSaveParam;
2022-08-24 10:31:42 +08:00
import com.engine.salary.entity.salarysob.po.*;
2022-11-11 13:59:37 +08:00
import com.engine.salary.entity.taxagent.po.TaxAgentPO;
2024-01-30 09:58:13 +08:00
import com.engine.salary.enums.OperateTypeEnum;
2023-07-24 17:11:19 +08:00
import com.engine.salary.enums.SalaryValueTypeEnum;
2023-10-17 10:24:30 +08:00
import com.engine.salary.enums.salaryformula.SalaryFormulaReferenceEnum;
import com.engine.salary.enums.salaryformula.SalarySQLReferenceEnum;
2022-03-23 18:41:38 +08:00
import com.engine.salary.exception.SalaryRunTimeException;
2023-02-27 17:51:26 +08:00
import com.engine.salary.mapper.salarysob.SalarySobDefaultItemMapper;
2023-02-09 15:33:35 +08:00
import com.engine.salary.mapper.salarysob.SalarySobEmpFieldMapper;
import com.engine.salary.mapper.salarysob.SalarySobItemMapper;
2022-03-23 18:41:38 +08:00
import com.engine.salary.service.*;
import com.engine.salary.util.SalaryEntityUtil;
import com.engine.salary.util.SalaryI18nUtil;
2024-01-30 09:58:13 +08:00
import com.engine.salary.util.db.IdGenerator;
2023-02-09 15:33:35 +08:00
import com.engine.salary.util.db.MapperProxyFactory;
2022-04-18 14:45:12 +08:00
import com.engine.salary.util.valid.ValidUtil;
2023-10-17 10:24:30 +08:00
import lombok.Data;
2023-10-09 15:35:20 +08:00
import lombok.extern.slf4j.Slf4j;
2022-03-21 20:09:10 +08:00
import org.apache.commons.collections4.CollectionUtils;
2025-04-22 15:33:28 +08:00
import org.apache.commons.collections4.MapUtils;
2022-03-25 10:31:31 +08:00
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.math.NumberUtils;
2023-07-24 17:11:19 +08:00
import weaver.general.BaseBean;
2022-03-23 20:54:08 +08:00
import weaver.hrm.User;
2022-03-21 20:09:10 +08:00
2025-04-22 15:33:28 +08:00
import java.time.Month;
2022-03-23 18:41:38 +08:00
import java.util.*;
2023-01-12 14:09:04 +08:00
import java.util.function.Function;
2022-08-24 10:31:42 +08:00
import java.util.stream.Collectors;
2022-03-21 20:09:10 +08:00
/**
* 薪资账套的薪资项目副本
* <p>Copyright: Copyright (c) 2022</p>
* <p>Company: 泛微软件</p>
*
* @author qiantao
* @version 1.0
**/
2023-10-09 15:35:20 +08:00
@Slf4j
2022-03-21 20:09:10 +08:00
public class SalarySobItemServiceImpl extends Service implements SalarySobItemService {
private SalarySobItemBiz salarySobItemMapper = new SalarySobItemBiz();
2022-03-23 18:41:38 +08:00
private SalarySobBiz salarySobBiz = new SalarySobBiz();
2022-03-23 20:54:08 +08:00
2022-03-25 10:31:31 +08:00
private SalarySobItemGroupBiz salarySobItemGroupBiz = new SalarySobItemGroupBiz();
2023-02-09 15:33:35 +08:00
private SalarySobItemHideBiz salarySobItemHideBiz = new SalarySobItemHideBiz();
private SalarySobEmpFieldMapper getSalarySobEmpFieldMapper() {
return MapperProxyFactory.getProxy(SalarySobEmpFieldMapper.class);
}
private SalarySobItemMapper getSalarySobItemMapper() {
return MapperProxyFactory.getProxy(SalarySobItemMapper.class);
}
2022-03-25 10:31:31 +08:00
2022-03-23 20:54:08 +08:00
private SalarySobEmpFieldService getSalarySobEmpFieldService(User user) {
return (SalarySobEmpFieldService) ServiceUtil.getService(SalarySobEmpFieldServiceImpl.class, user);
}
2022-11-11 13:59:37 +08:00
private TaxAgentService getTaxAgentService(User user) {
return (TaxAgentService) ServiceUtil.getService(TaxAgentServiceImpl.class, user);
}
2022-03-23 20:54:08 +08:00
private SalarySobItemGroupService getSalarySobItemGroupService(User user) {
return (SalarySobItemGroupService) ServiceUtil.getService(SalarySobItemGroupServiceImpl.class, user);
}
2022-08-24 10:31:42 +08:00
private SalarySobItemHideService getSalarySobItemHideService(User user) {
return (SalarySobItemHideService) ServiceUtil.getService(SalarySobItemHideServiceImpl.class, user);
}
2022-04-18 14:45:12 +08:00
private SalaryFormulaService getSalaryFormulaService(User user) {
return (SalaryFormulaService) ServiceUtil.getService(SalaryFormulaServiceImpl.class, user);
}
2022-03-28 11:38:33 +08:00
private SalaryItemService getSalaryItemService(User user) {
return (SalaryItemService) ServiceUtil.getService(SalaryItemServiceImpl.class, user);
}
private SalarySobBackItemService getSalarySobBackItemService(User user) {
return (SalarySobBackItemService) ServiceUtil.getService(SalarySobBackItemServiceImpl.class, user);
}
2023-02-27 17:51:26 +08:00
private SalarySobDefaultItemMapper getSalarySobDefaultItemMapper() {
return MapperProxyFactory.getProxy(SalarySobDefaultItemMapper.class);
}
2023-10-17 14:24:52 +08:00
2024-05-06 16:03:29 +08:00
private SalaryAcctSobConfigService getSalaryAcctSobConfigService(User user) {
return ServiceUtil.getService(SalaryAcctSobConfigServiceImpl.class, user);
}
2023-10-17 14:24:52 +08:00
private SalaryAcctResultService getSalaryAcctResultService(User user) {
return ServiceUtil.getService(SalaryAcctResultServiceImpl.class, user);
}
2022-03-21 20:09:10 +08:00
// private LoggerTemplate salarySobLoggerTemplate;
2025-04-22 15:33:28 +08:00
private SalaryAcctEmployeeService getSalaryAcctEmployeeService(User user) {
return ServiceUtil.getService(SalaryAcctEmployeeServiceImpl.class, user);
}
private SalaryAcctRecordService getSalaryAcctRecordService(User user) {
return ServiceUtil.getService(SalaryAcctRecordServiceImpl.class, user);
}
private SalarySobService getSalarySobService(User user) {
return ServiceUtil.getService(SalarySobServiceImpl.class, user);
}
private SIAccountService getSIAccountService(User user) {
return ServiceUtil.getService(SIAccountServiceImpl.class, user);
}
private AttendQuoteFieldService getAttendQuoteFieldService(User user) {
return ServiceUtil.getService(AttendQuoteFieldServiceImpl.class, user);
}
private VariableItemService getVariableItemService(User user) {
return ServiceUtil.getService(VariableItemServiceImpl.class, user);
}
private SalaryEmployeeService getSalaryEmployeeService(User user) {
return ServiceUtil.getService(SalaryEmployeeServiceImpl.class, user);
}
private SalaryArchiveService getSalaryArchiveService(User user) {
return ServiceUtil.getService(SalaryArchiveServiceImpl.class, user);
}
private AddUpSituationService getAddUpSituationService(User user) {
return ServiceUtil.getService(AddUpSituationServiceImpl.class, user);
}
private AddUpDeductionService getAddUpDeductionService(User user) {
return ServiceUtil.getService(AddUpDeductionServiceImpl.class, user);
}
private OtherDeductionService getOtherDeductionService(User user) {
return ServiceUtil.getService(OtherDeductionServiceImpl.class, user);
}
private AttendQuoteDataService getAttendQuoteDataService(User user) {
return ServiceUtil.getService(AttendQuoteDataServiceImpl.class, user);
}
private VariableArchiveService getVariableArchiveService(User user) {
return ServiceUtil.getService(VariableArchiveServiceImpl.class, user);
}
2022-03-21 20:09:10 +08:00
@Override
public List<SalarySobItemPO> list() {
return salarySobItemMapper.listAll();
}
2022-03-23 18:41:38 +08:00
@Override
public List<SalarySobItemPO> listBySalarySobId(Long salarySobId) {
return salarySobItemMapper.listSome(SalarySobItemPO.builder().salarySobId(salarySobId).build());
}
2022-08-24 10:31:42 +08:00
@Override
2023-02-09 15:33:35 +08:00
public List<SalarySobItemPO> listBySalarySobIdAndGroupId(Long salarySobId, Collection<Long> salarySobItemGroupIds) {
return salarySobItemMapper.listBySalarySobIdAndGroupId(salarySobId, salarySobItemGroupIds);
2022-08-24 10:31:42 +08:00
}
2022-03-23 18:41:38 +08:00
@Override
public List<SalarySobItemPO> listBySalarySobIds(Collection<Long> salarySobIds) {
return salarySobItemMapper.listSome(SalarySobItemPO.builder().salarySobIds(salarySobIds).build());
}
@Override
public List<SalarySobItemPO> listBySalarySobIdAndSalaryItemIdNotIn(Long salarySobId, Collection<Long> salaryItemIds) {
2022-03-30 11:29:48 +08:00
return salarySobItemMapper.listSome(SalarySobItemPO.builder().salarySobId(salarySobId).notInSalaryItemIds(salaryItemIds).build());
2022-03-23 18:41:38 +08:00
}
2022-03-21 20:09:10 +08:00
@Override
public List<SalarySobItemPO> listBySalaryItemIds(Collection<Long> salaryItemIds) {
if (CollectionUtils.isEmpty(salaryItemIds)) {
return Collections.emptyList();
}
2022-03-23 18:41:38 +08:00
return salarySobItemMapper.listSome(SalarySobItemPO.builder().salaryItemIds(salaryItemIds).build());
}
@Override
public List<SalaryItemPO> listBySalarySobId4SalaryItem(Long salarySobId) {
// 查询薪资项目副本
List<SalarySobItemPO> salarySobItemPOS = listBySalarySobId(salarySobId);
if (CollectionUtils.isEmpty(salarySobItemPOS)) {
return Collections.emptyList();
}
// 查询薪资项目
Set<Long> salaryItemIds = SalaryEntityUtil.properties(salarySobItemPOS, SalarySobItemPO::getSalaryItemId);
2022-03-28 11:38:33 +08:00
return getSalaryItemService(user).listByIds(salaryItemIds);
2022-03-21 20:09:10 +08:00
}
2022-03-23 18:41:38 +08:00
@Override
public SalarySobItemAggregateDTO getAggregateBySalarySobId(Long salarySobId) {
// 查询薪资账套
SalarySobPO salarySobPO = salarySobBiz.getById(salarySobId);
if (Objects.isNull(salarySobPO)) {
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98379, "参数错误,薪资账套不存在或者已被删除"));
}
// 查询薪资账套的员工信息字段
2022-03-23 20:54:08 +08:00
List<SalarySobEmpFieldPO> salarySobEmpFieldPOS = getSalarySobEmpFieldService(user).listBySalarySobId(salarySobId);
2022-03-23 18:41:38 +08:00
// 查询薪资账套的薪资项目分类
2024-05-06 16:03:29 +08:00
List<SalarySobItemGroupPO> salarySobItemGroupPOS = getSalarySobItemGroupService(user).listBySalarySobId(salarySobId);
2022-03-23 18:41:38 +08:00
// 查询薪资账套的薪资项目副本
2024-05-06 16:03:29 +08:00
List<SalarySobItemPO> salarySobItemPOS = listBySalarySobId(salarySobId);
2023-04-07 15:14:07 +08:00
// 薪资项目副本去重
salarySobItemPOS = salarySobItemPOS.stream().filter(SalaryEntityUtil.distinctByKey(PO -> PO.getSalarySobId() + "-" + PO.getSalaryItemId())).collect(Collectors.toList());
// 回算薪资项目
List<SalarySobBackItemPO> salarySobBackItems = getSalarySobBackItemService(user).listBySalarySobId(salarySobId);
2022-03-23 18:41:38 +08:00
// 薪资账套的薪资项目副本所用的公式id
Set<Long> formulaIds = SalaryEntityUtil.properties(salarySobItemPOS, SalarySobItemPO::getFormulaId);
// 添加薪资回算项目的公式id
2023-02-09 15:33:35 +08:00
formulaIds.addAll(SalaryEntityUtil.properties(salarySobBackItems, SalarySobBackItemPO::getFormulaId));
2022-04-18 14:45:12 +08:00
// 查询公式详情
List<ExpressFormula> expressFormulas = getSalaryFormulaService(user).listExpressFormula(formulaIds);
// 查询薪资账套的薪资项目副本+回算的薪资项目所关联的薪资项目
2022-03-23 18:41:38 +08:00
Set<Long> salaryItemIds = SalaryEntityUtil.properties(salarySobItemPOS, SalarySobItemPO::getSalaryItemId);
Set<Long> backCalcItemIds = SalaryEntityUtil.properties(salarySobBackItems, SalarySobBackItemPO::getSalaryItemId);
salaryItemIds.addAll(backCalcItemIds);
2022-11-11 13:59:37 +08:00
Boolean needAuth = getTaxAgentService(user).isNeedAuth((long) user.getUID());
final Set<Long> ids = new HashSet<Long>();
if (needAuth) {
Set<Long> collect = getTaxAgentService(user).listAllTaxAgents((long) user.getUID())
.stream().map(TaxAgentPO::getId).collect(Collectors.toSet());
ids.addAll(collect);
}
List<SalaryItemPO> salaryItemPOS = getSalaryItemService(user).listByIds(salaryItemIds).stream()
.filter(po -> Boolean.FALSE.equals(needAuth) || getSalaryItemService(user).filterInRange(ids, po))
.collect(Collectors.toList());
2023-02-27 17:51:26 +08:00
//获取系统值
List<SalarySobDefaultItemPO> salarySobDefaultItemPOS = getSalarySobDefaultItemMapper().listAll();
2022-08-24 10:31:42 +08:00
// 转换成聚合dto
SalarySobItemAggregateBO salarySobItemAggregateBO = new SalarySobItemAggregateBO(salarySobPO, salarySobEmpFieldPOS,
2023-02-27 17:51:26 +08:00
salarySobItemGroupPOS, salarySobItemPOS, expressFormulas, salaryItemPOS, salarySobBackItems, salarySobDefaultItemPOS);
2022-08-24 10:31:42 +08:00
return salarySobItemAggregateBO.convert2AggregateDTO();
}
@Override
public SalarySobItemAggregateDTO getAggregateByRecordId(Long salaryAcctRecordId, boolean hideItem) {
SalaryAcctConfig salaryAcctConfig = getSalaryAcctSobConfigService(user).getSalaryAcctConfig(salaryAcctRecordId);
2022-08-24 10:31:42 +08:00
// 查询薪资账套
SalarySobPO salarySobPO = salaryAcctConfig.getSalarySob();
2022-08-24 10:31:42 +08:00
if (Objects.isNull(salarySobPO)) {
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98379, "参数错误,薪资账套不存在或者已被删除"));
}
// 查询薪资账套的员工信息字段
List<SalarySobEmpFieldPO> salarySobEmpFieldPOS = salaryAcctConfig.getSalarySobEmpFields();
2022-08-24 10:31:42 +08:00
// 查询薪资账套的薪资项目分类
List<SalarySobItemGroupPO> salarySobItemGroupPOS = salaryAcctConfig.getSalarySobItemGroups();
if (hideItem) {
salarySobItemGroupPOS = salarySobItemGroupPOS.stream().filter(po -> po.getItemHide() == null || po.getItemHide().equals(0L)).collect(Collectors.toList());
}
// 查询薪资账套的薪资项目副本(已经过滤关闭分类显示按钮的薪资项目)
List<SalarySobItemPO> salarySobItemPOS = salaryAcctConfig.getSalarySobItems();
if (hideItem) {
salarySobItemPOS = salarySobItemPOS.stream().filter(po -> po.getItemHide() == null || po.getItemHide().equals(0L)).collect(Collectors.toList());
}
// 回算薪资项目
List<SalarySobBackItemPO> salarySobBackItems = salaryAcctConfig.getSalarySobBackItems();
// 薪资账套的薪资项目副本所用的公式id
Set<Long> formulaIds = SalaryEntityUtil.properties(salarySobItemPOS, SalarySobItemPO::getFormulaId);
// 添加薪资回算项目的公式id
formulaIds.addAll(SalaryEntityUtil.properties(salarySobBackItems, SalarySobBackItemPO::getFormulaId));
// 查询公式详情
List<ExpressFormula> expressFormulas = getSalaryFormulaService(user).listExpressFormula(formulaIds);
// 查询薪资账套的薪资项目副本+回算的薪资项目所关联的薪资项目
Set<Long> salaryItemIds = SalaryEntityUtil.properties(salarySobItemPOS, SalarySobItemPO::getSalaryItemId);
Set<Long> backCalcItemIds = SalaryEntityUtil.properties(salarySobBackItems, SalarySobBackItemPO::getSalaryItemId);
salaryItemIds.addAll(backCalcItemIds);
2022-08-24 10:31:42 +08:00
Boolean needAuth = getTaxAgentService(user).isNeedAuth((long) user.getUID());
final Set<Long> ids = new HashSet<Long>();
if (needAuth) {
Set<Long> collect = getTaxAgentService(user).listAllTaxAgents((long) user.getUID()).stream().map(TaxAgentPO::getId).collect(Collectors.toSet());
ids.addAll(collect);
}
List<SalaryItemPO> salaryItemPOS = getSalaryItemService(user).listByIds(salaryItemIds).stream().filter(po -> Boolean.FALSE.equals(needAuth) || getSalaryItemService(user).filterInRange(ids, po)).collect(Collectors.toList());
2022-08-24 10:31:42 +08:00
//获取系统值
List<SalarySobDefaultItemPO> salarySobDefaultItemPOS = getSalarySobDefaultItemMapper().listAll();
2022-08-24 10:31:42 +08:00
// 转换成聚合dto
SalarySobItemAggregateBO salarySobItemAggregateBO = new SalarySobItemAggregateBO(salarySobPO, salarySobEmpFieldPOS, salarySobItemGroupPOS, salarySobItemPOS, expressFormulas, salaryItemPOS, salarySobBackItems, salarySobDefaultItemPOS);
return salarySobItemAggregateBO.convert2AggregateDTO();
}
2022-11-11 13:59:37 +08:00
2022-08-24 10:31:42 +08:00
@Override
2024-05-06 16:03:29 +08:00
public SalarySobItemAggregateDTO getAggregateWithItemHideBySalarySobId(Long salaryAcctRecordId, Long salarySobId, boolean isBackCalc) {
SalaryAcctConfig salaryAcctConfig = getSalaryAcctSobConfigService(user).getSalaryAcctConfig(salaryAcctRecordId);
2022-08-24 10:31:42 +08:00
// 查询薪资账套
2024-05-06 16:03:29 +08:00
SalarySobPO salarySobPO = salaryAcctConfig.getSalarySob();
2022-08-24 10:31:42 +08:00
if (Objects.isNull(salarySobPO)) {
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98379, "参数错误,薪资账套不存在或者已被删除"));
}
// 查询薪资账套的员工信息字段
2024-05-06 16:03:29 +08:00
List<SalarySobEmpFieldPO> salarySobEmpFieldPOS = salaryAcctConfig.getSalarySobEmpFields();
2022-08-24 10:31:42 +08:00
2024-05-06 16:03:29 +08:00
// 查询薪资账套的薪资项目分类
List<SalarySobItemGroupPO> salarySobItemGroupPOS = salaryAcctConfig.getSalarySobItemGroups();
salarySobItemGroupPOS = salarySobItemGroupPOS.stream().filter(po -> po.getItemHide() == null || po.getItemHide().equals(0L)).collect(Collectors.toList());
2022-08-24 10:31:42 +08:00
// 查询薪资账套的薪资项目副本(已经过滤关闭分类显示按钮的薪资项目)
2024-05-06 16:03:29 +08:00
List<SalarySobItemPO> salarySobItemPOS = salaryAcctConfig.getSalarySobItems();
salarySobItemPOS = salarySobItemPOS.stream().filter(po -> po.getItemHide() == null || po.getItemHide().equals(0L)).collect(Collectors.toList());
2022-08-24 10:31:42 +08:00
// 回算薪资项目
List<SalarySobBackItemPO> salarySobBackItems = Collections.emptyList();
2023-02-09 15:33:35 +08:00
if (isBackCalc) {
2024-05-06 16:03:29 +08:00
salarySobBackItems = salaryAcctConfig.getSalarySobBackItems();
}
2022-08-24 10:31:42 +08:00
// 薪资账套的薪资项目副本所用的公式id
Set<Long> formulaIds = SalaryEntityUtil.properties(salarySobItemPOS, SalarySobItemPO::getFormulaId);
formulaIds.addAll(salarySobBackItems.stream().map(SalarySobBackItemPO::getFormulaId).collect(Collectors.toList()));
2022-08-24 10:31:42 +08:00
// 查询公式详情
List<ExpressFormula> expressFormulas = getSalaryFormulaService(user).listExpressFormula(formulaIds);
// 查询薪资账套的薪资项目副本所关联的薪资项目
Set<Long> salaryItemIds = SalaryEntityUtil.properties(salarySobItemPOS, SalarySobItemPO::getSalaryItemId);
Set<Long> backCalcItemIds = SalaryEntityUtil.properties(salarySobBackItems, SalarySobBackItemPO::getSalaryItemId);
salaryItemIds.addAll(backCalcItemIds);
2022-08-24 10:31:42 +08:00
List<SalaryItemPO> salaryItemPOS = getSalaryItemService(user).listByIds(salaryItemIds);
2022-03-23 18:41:38 +08:00
// 转换成聚合dto
SalarySobItemAggregateBO salarySobItemAggregateBO = new SalarySobItemAggregateBO(salarySobPO, salarySobEmpFieldPOS,
2023-02-27 17:51:26 +08:00
salarySobItemGroupPOS, salarySobItemPOS, expressFormulas, salaryItemPOS, salarySobBackItems, Collections.emptyList());
2022-03-23 18:41:38 +08:00
return salarySobItemAggregateBO.convert2AggregateDTO();
}
@Override
public void save(SalarySobItemSaveParam saveParam) {
2022-03-25 10:31:31 +08:00
Long salarySobId = saveParam.getSalarySobId();
2022-03-25 18:05:07 +08:00
// 校验
2022-04-18 14:45:12 +08:00
validSaveParam(saveParam);
2022-03-25 18:05:07 +08:00
//保存
saveSobItem(saveParam);
2024-01-30 09:58:13 +08:00
SalarySobPO salarySob = salarySobBiz.getById(salarySobId);
// 记录日志
LoggerContext<SalarySobPO> loggerContext = new LoggerContext<>();
loggerContext.setUser(user);
loggerContext.setTargetId("" + salarySob.getId());
loggerContext.setTargetName(salarySob.getName());
2024-02-22 09:43:47 +08:00
loggerContext.setOperateType(OperateTypeEnum.ADD.getValue());
loggerContext.setOperateTypeName(SalaryI18nUtil.getI18nLabel(0, "编辑薪资账套薪资项目"));
loggerContext.setOperatedesc(SalaryI18nUtil.getI18nLabel(0, "编辑薪资账套薪资项目"));
2024-01-30 09:58:13 +08:00
SalaryElogConfig.salarySobLoggerTemplate.write(loggerContext);
2022-03-25 18:05:07 +08:00
}
/**
* 校验
*/
2022-04-18 14:45:12 +08:00
private void validSaveParam(SalarySobItemSaveParam saveParam) {
ValidUtil.doValidator(saveParam);
2022-06-21 11:38:55 +08:00
//账套存在
2022-04-18 14:45:12 +08:00
Long salarySobId = saveParam.getSalarySobId();
2022-03-25 10:31:31 +08:00
SalarySobPO salarySobPO = salarySobBiz.getById(salarySobId);
2022-03-23 18:41:38 +08:00
if (Objects.isNull(salarySobPO)) {
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98379, "参数错误,薪资账套不存在或者已被删除"));
}
2022-03-25 18:05:07 +08:00
2022-06-21 11:38:55 +08:00
//员工信息字段不可重复
List<SalarySobItemSaveParam.SalarySobEmpFieldParam> empFields = saveParam.getEmpFields();
2023-02-09 15:33:35 +08:00
if (CollectionUtils.isNotEmpty(empFields)) {
int count = (int) SalaryEntityUtil.properties(empFields, SalarySobItemSaveParam.SalarySobEmpFieldParam::getFieldId).stream().distinct().count();
if (count < empFields.size()) {
2022-06-21 11:38:55 +08:00
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98379, "分类名称重复!"));
}
2023-02-09 15:33:35 +08:00
} else {
2022-06-21 11:38:55 +08:00
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98379, "员工信息不能为空!"));
}
//分类名称唯一
2022-06-17 17:22:48 +08:00
List<SalarySobItemSaveParam.SalarySobItemGroupParam> itemGroups = saveParam.getItemGroups();
2023-02-09 15:33:35 +08:00
if (CollectionUtils.isNotEmpty(itemGroups)) {
int count = (int) SalaryEntityUtil.properties(itemGroups, SalarySobItemSaveParam.SalarySobItemGroupParam::getName).stream().distinct().count();
if (count < itemGroups.size()) {
2022-06-17 17:22:48 +08:00
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98379, "分类名称重复!"));
}
}
2022-03-25 18:05:07 +08:00
}
2022-08-24 10:31:42 +08:00
2022-03-25 18:05:07 +08:00
/**
* 保存项目信息
2022-04-27 18:48:41 +08:00
*
2022-03-25 18:05:07 +08:00
* @param saveParam
*/
private void saveSobItem(SalarySobItemSaveParam saveParam) {
2023-02-09 15:33:35 +08:00
//分组和薪资项
handleGroupAndItem(saveParam);
2024-03-07 10:21:06 +08:00
//处理人员信息字段
handleEmpField(saveParam);
2023-02-09 15:33:35 +08:00
}
private void handleGroupAndItem(SalarySobItemSaveParam saveParam) {
2022-03-25 18:05:07 +08:00
long employeeId = (long) user.getUID();
Date now = new Date();
Long salarySobId = saveParam.getSalarySobId();
2022-03-23 18:41:38 +08:00
2024-05-30 15:19:15 +08:00
SalarySobPO sob = salarySobBiz.getById(salarySobId);
String incomeCategory = sob.getIncomeCategory() == null ? "1" : sob.getIncomeCategory().toString();
2023-02-09 15:33:35 +08:00
List<SalarySobItemSaveParam.SalarySobItemGroupParam> itemGroups = saveParam.getItemGroups();
List<Long> newGroupIds = SalaryEntityUtil.properties(itemGroups, SalarySobItemSaveParam.SalarySobItemGroupParam::getId, Collectors.toList());
List<SalarySobItemGroupPO> salarySobItemGroupPOS = getSalarySobItemGroupService(user).listBySalarySobId(salarySobId);
List<Long> oldGroupIds = SalaryEntityUtil.properties(salarySobItemGroupPOS, SalarySobItemGroupPO::getId, Collectors.toList());
List<SalarySobItemSaveParam.SalarySobItemGroupParam> needAddGroup = itemGroups.stream().filter(f -> f.getId() == null).collect(Collectors.toList());
List<SalarySobItemSaveParam.SalarySobItemGroupParam> needUpdateGroup = itemGroups.stream().filter(f -> f.getId() != null && oldGroupIds.contains(f.getId())).collect(Collectors.toList());
List<Long> needDeleteGroupIds = oldGroupIds.stream().filter(f -> !newGroupIds.contains(f)).collect(Collectors.toList());
2022-03-25 10:31:31 +08:00
2023-07-24 17:11:19 +08:00
// 获取所有薪资项目
List<SalaryItemPO> allSalaryItemList = getSalaryItemService(user).listAll();
Map<Long, SalaryItemPO> salaryItemsMap = SalaryEntityUtil.convert2Map(allSalaryItemList, SalaryItemPO::getId);
2022-03-25 18:05:07 +08:00
//先保存项目分类获取分类id
Collection<SalarySobItemPO> salarySobItems = new ArrayList<>();
2023-02-09 15:33:35 +08:00
for (SalarySobItemSaveParam.SalarySobItemGroupParam itemGroupParam : needAddGroup) {
2022-05-10 17:26:58 +08:00
Long salarySobItemGroupId = IdGenerator.generate();
SalarySobItemGroupPO salarySobItemGroupPO = SalarySobItemGroupPO.builder().id(salarySobItemGroupId).salarySobId(salarySobId).name(itemGroupParam.getName()).sortedIndex(itemGroupParam.getSortedIndex()).itemHide(itemGroupParam.getItemHide()).description(StringUtils.EMPTY).creator(employeeId).createTime(now).updateTime(now).deleteType(NumberUtils.INTEGER_ZERO).tenantKey(SalaryDefaultTenantConstant.DEFAULT_TENANT_KEY).build();
2022-03-25 18:05:07 +08:00
//保存分类
2022-03-25 10:31:31 +08:00
salarySobItemGroupBiz.insert(salarySobItemGroupPO);
2022-08-24 10:31:42 +08:00
2022-03-25 10:31:31 +08:00
for (SalarySobItemSaveParam.SalarySobItemParam itemParam : itemGroupParam.getItems()) {
2023-07-24 17:11:19 +08:00
SalaryItemPO salaryItemPO = checkItemExists(itemParam.getSalaryItemId(), salaryItemsMap);
2022-03-25 10:31:31 +08:00
SalarySobItemPO salarySobItemPO = SalarySobItemPO.builder()
.salarySobId(salarySobId)
2024-05-30 15:19:15 +08:00
.incomeCategory(incomeCategory)
2022-03-25 10:31:31 +08:00
.salaryItemId(itemParam.getSalaryItemId())
2023-08-23 16:20:45 +08:00
.salaryItemCode(salaryItemPO.getCode())
2022-03-25 10:31:31 +08:00
.salarySobItemGroupId(salarySobItemGroupId)
.formulaId(Optional.ofNullable(itemParam.getFormulaId()).orElse(NumberUtils.LONG_ZERO))
.sortedIndex(itemParam.getSortedIndex())
.description(StringUtils.EMPTY)
.creator(employeeId)
.createTime(now)
.updateTime(now)
.deleteType(NumberUtils.INTEGER_ZERO)
.tenantKey(SalaryDefaultTenantConstant.DEFAULT_TENANT_KEY)
2022-05-18 14:34:06 +08:00
.canDelete(itemParam.getCanDelete() == null ? NumberUtils.INTEGER_ONE : (itemParam.getCanDelete() ? NumberUtils.INTEGER_ONE : NumberUtils.INTEGER_ZERO))
2023-07-24 17:11:19 +08:00
.roundingMode(itemParam.getRoundingMode() == null ? salaryItemPO.getRoundingMode() : itemParam.getRoundingMode())
.pattern(itemParam.getPattern() == null ? salaryItemPO.getPattern() : itemParam.getPattern())
.valueType(itemParam.getValueType() == null ? salaryItemPO.getValueType() : itemParam.getValueType())
2022-08-24 10:31:42 +08:00
.itemHide(itemParam.getItemHide())
.defaultValue(itemParam.getDefaultValue())
2022-08-24 10:31:42 +08:00
.build();
2024-05-06 16:03:29 +08:00
salarySobItems.add(salarySobItemPO);
2022-03-25 10:31:31 +08:00
}
}
2022-08-24 10:31:42 +08:00
2023-02-09 15:33:35 +08:00
//更新分组
for (SalarySobItemSaveParam.SalarySobItemGroupParam itemGroupParam : needUpdateGroup) {
Long groupId = itemGroupParam.getId();
SalarySobItemGroupPO salarySobItemGroupPO = SalarySobItemGroupPO.builder().id(groupId).name(itemGroupParam.getName()).sortedIndex(itemGroupParam.getSortedIndex()).itemHide(itemGroupParam.getItemHide()).build();
2023-02-09 15:33:35 +08:00
//更新分类
salarySobItemGroupBiz.update(salarySobItemGroupPO);
List<SalarySobItemSaveParam.SalarySobItemParam> items = itemGroupParam.getItems();
List<Long> itemIds = SalaryEntityUtil.properties(items, SalarySobItemSaveParam.SalarySobItemParam::getId, Collectors.toList());
List<SalarySobItemPO> oldItems = salarySobItemMapper.listBySalarySobIdAndGroupId(salarySobId, Collections.singleton(groupId));
List<Long> oldItemIds = SalaryEntityUtil.properties(oldItems, SalarySobItemPO::getId, Collectors.toList());
List<SalarySobItemSaveParam.SalarySobItemParam> needAddItems = items.stream().filter(f -> f.getId() == null).collect(Collectors.toList());
List<Long> needDeleteItemIds = oldItems.stream().filter(f -> !itemIds.contains(f.getId())).map(SalarySobItemPO::getId).collect(Collectors.toList());
List<SalarySobItemSaveParam.SalarySobItemParam> needUpdateItems = items.stream().filter(f -> f.getId() != null && oldItemIds.contains(f.getId())).collect(Collectors.toList());
//新增
for (SalarySobItemSaveParam.SalarySobItemParam itemParam : needAddItems) {
2023-07-24 17:11:19 +08:00
SalaryItemPO salaryItemPO = checkItemExists(itemParam.getSalaryItemId(), salaryItemsMap);
2023-02-09 15:33:35 +08:00
SalarySobItemPO salarySobItemPO = SalarySobItemPO.builder()
.salarySobId(salarySobId)
2024-05-30 15:19:15 +08:00
.incomeCategory(incomeCategory)
2023-02-09 15:33:35 +08:00
.salaryItemId(itemParam.getSalaryItemId())
2023-08-23 16:20:45 +08:00
.salaryItemCode(salaryItemPO.getCode())
2023-02-09 15:33:35 +08:00
.salarySobItemGroupId(groupId)
.formulaId(Optional.ofNullable(itemParam.getFormulaId()).orElse(NumberUtils.LONG_ZERO))
2023-02-27 17:51:26 +08:00
.canDelete(itemParam.getCanDelete() == null ? NumberUtils.INTEGER_ONE : (itemParam.getCanDelete() ? NumberUtils.INTEGER_ONE : NumberUtils.INTEGER_ZERO))
2023-02-09 15:33:35 +08:00
.sortedIndex(itemParam.getSortedIndex())
.description(StringUtils.EMPTY)
.creator(employeeId)
.createTime(now)
.updateTime(now)
2023-02-14 10:53:58 +08:00
.tenantKey(SalaryDefaultTenantConstant.DEFAULT_TENANT_KEY)
2023-02-09 15:33:35 +08:00
.deleteType(NumberUtils.INTEGER_ZERO)
2023-07-24 17:11:19 +08:00
.roundingMode(itemParam.getRoundingMode() == null ? salaryItemPO.getRoundingMode() : itemParam.getRoundingMode())
.pattern(itemParam.getPattern() == null ? salaryItemPO.getPattern() : itemParam.getPattern())
.valueType(itemParam.getValueType() == null ? salaryItemPO.getValueType() : itemParam.getValueType())
2023-02-09 15:33:35 +08:00
.itemHide(itemParam.getItemHide())
.defaultValue(itemParam.getDefaultValue())
2023-02-09 15:33:35 +08:00
.build();
2024-05-06 16:03:29 +08:00
salarySobItems.add(salarySobItemPO);
2023-02-09 15:33:35 +08:00
}
//更新
for (SalarySobItemSaveParam.SalarySobItemParam itemParam : needUpdateItems) {
2023-07-24 17:11:19 +08:00
SalaryItemPO salaryItemPO = checkItemExists(itemParam.getSalaryItemId(), salaryItemsMap);
2023-02-09 15:33:35 +08:00
SalarySobItemPO salarySobItemPO = SalarySobItemPO.builder()
.id(itemParam.getId())
2024-05-30 15:19:15 +08:00
.incomeCategory(incomeCategory)
2023-02-09 15:33:35 +08:00
.salaryItemId(itemParam.getSalaryItemId())
2023-08-23 16:20:45 +08:00
.salaryItemCode(salaryItemPO.getCode())
2023-02-09 15:33:35 +08:00
.salarySobItemGroupId(groupId)
.formulaId(Optional.ofNullable(itemParam.getFormulaId()).orElse(NumberUtils.LONG_ZERO))
.sortedIndex(itemParam.getSortedIndex())
2023-02-27 17:51:26 +08:00
.canDelete(itemParam.getCanDelete() == null ? NumberUtils.INTEGER_ONE : (itemParam.getCanDelete() ? NumberUtils.INTEGER_ONE : NumberUtils.INTEGER_ZERO))
2023-02-09 15:33:35 +08:00
.updateTime(now)
.deleteType(NumberUtils.INTEGER_ZERO)
2023-07-24 17:11:19 +08:00
.roundingMode(itemParam.getRoundingMode() == null ? salaryItemPO.getRoundingMode() : itemParam.getRoundingMode())
.pattern(itemParam.getPattern() == null ? salaryItemPO.getPattern() : itemParam.getPattern())
.valueType(itemParam.getValueType() == null ? salaryItemPO.getValueType() : itemParam.getValueType())
.itemHide(itemParam.getItemHide())
.defaultValue(itemParam.getDefaultValue())
2023-02-09 15:33:35 +08:00
.build();
getSalarySobItemMapper().updateIgnoreNull(salarySobItemPO);
2024-05-06 16:03:29 +08:00
2023-02-09 15:33:35 +08:00
}
//删除
salarySobItemMapper.deleteByIds(needDeleteItemIds);
}
//删除分组
salarySobItemGroupBiz.deleteByIds(needDeleteGroupIds);
salarySobItemMapper.deleteByGroupIds(needDeleteGroupIds);
2023-03-01 09:58:55 +08:00
//未分类
2023-02-09 15:33:35 +08:00
List<SalarySobItemSaveParam.SalarySobItemParam> items = saveParam.getItems();
List<Long> itemIds = SalaryEntityUtil.properties(items, SalarySobItemSaveParam.SalarySobItemParam::getId, Collectors.toList());
List<SalarySobItemPO> oldItems = salarySobItemMapper.listBySalarySobIdAndGroupId(salarySobId, Collections.singleton(0L));
List<Long> oldItemIds = SalaryEntityUtil.properties(oldItems, SalarySobItemPO::getId, Collectors.toList());
List<SalarySobItemSaveParam.SalarySobItemParam> needAddItems = items.stream().filter(f -> f.getId() == null).collect(Collectors.toList());
List<Long> needDeleteItemIds = oldItems.stream().filter(f -> !itemIds.contains(f.getId())).map(SalarySobItemPO::getId).collect(Collectors.toList());
List<SalarySobItemSaveParam.SalarySobItemParam> needUpdateItems = items.stream().filter(f -> f.getId() != null && oldItemIds.contains(f.getId())).collect(Collectors.toList());
for (SalarySobItemSaveParam.SalarySobItemParam itemParam : needAddItems) {
2023-07-24 17:11:19 +08:00
SalaryItemPO salaryItemPO = checkItemExists(itemParam.getSalaryItemId(), salaryItemsMap);
SalarySobItemPO salarySobItemPO = SalarySobItemPO.builder().salarySobId(salarySobId).incomeCategory(incomeCategory).salaryItemId(itemParam.getSalaryItemId()).salaryItemCode(salaryItemPO.getCode()).salarySobItemGroupId(NumberUtils.LONG_ZERO).formulaId(Optional.ofNullable(itemParam.getFormulaId()).orElse(NumberUtils.LONG_ZERO)).sortedIndex(itemParam.getSortedIndex()).description(StringUtils.EMPTY).creator(employeeId).createTime(now).updateTime(now).deleteType(NumberUtils.INTEGER_ZERO).tenantKey(SalaryDefaultTenantConstant.DEFAULT_TENANT_KEY).canDelete(itemParam.getCanDelete() == null ? NumberUtils.INTEGER_ONE : (itemParam.getCanDelete() ? NumberUtils.INTEGER_ONE : NumberUtils.INTEGER_ZERO)).roundingMode(itemParam.getRoundingMode() == null ? salaryItemPO.getRoundingMode() : itemParam.getRoundingMode()).pattern(itemParam.getPattern() == null ? salaryItemPO.getPattern() : itemParam.getPattern()).valueType(itemParam.getValueType() == null ? salaryItemPO.getValueType() : itemParam.getValueType()).itemHide(itemParam.getItemHide()).defaultValue(itemParam.getDefaultValue()).build();
2022-03-25 10:31:31 +08:00
salarySobItems.add(salarySobItemPO);
}
2022-03-24 19:42:03 +08:00
2023-02-09 15:33:35 +08:00
for (SalarySobItemSaveParam.SalarySobItemParam itemParam : needUpdateItems) {
2023-07-24 17:11:19 +08:00
SalaryItemPO salaryItemPO = checkItemExists(itemParam.getSalaryItemId(), salaryItemsMap);
SalarySobItemPO salarySobItemPO = SalarySobItemPO.builder().id(itemParam.getId()).incomeCategory(incomeCategory).formulaId(Optional.ofNullable(itemParam.getFormulaId()).orElse(NumberUtils.LONG_ZERO)).sortedIndex(itemParam.getSortedIndex()).updateTime(now).canDelete(itemParam.getCanDelete() == null ? NumberUtils.INTEGER_ONE : (itemParam.getCanDelete() ? NumberUtils.INTEGER_ONE : NumberUtils.INTEGER_ZERO)).roundingMode(itemParam.getRoundingMode() == null ? salaryItemPO.getRoundingMode() : itemParam.getRoundingMode()).pattern(itemParam.getPattern() == null ? salaryItemPO.getPattern() : itemParam.getPattern()).valueType(itemParam.getValueType() == null ? salaryItemPO.getValueType() : itemParam.getValueType()).itemHide(itemParam.getItemHide()).defaultValue(itemParam.getDefaultValue()).build();
2023-02-09 15:33:35 +08:00
getSalarySobItemMapper().updateIgnoreNull(salarySobItemPO);
}
if (CollectionUtils.isNotEmpty(needDeleteItemIds)) {
getSalarySobItemMapper().deleteByIds(needDeleteItemIds);
}
2022-03-23 18:41:38 +08:00
// 保存薪资账套的薪资项目副本
2022-03-25 18:05:07 +08:00
batchSave(salarySobItems);
2023-04-07 15:14:07 +08:00
2024-03-07 10:21:06 +08:00
// 删除原薪资项目是否显示
deleteItemShowBySalarySobIds(Collections.singleton(salarySobId));
2022-03-23 18:41:38 +08:00
}
2023-07-24 17:11:19 +08:00
private SalaryItemPO checkItemExists(Long salaryItemId, Map<Long, SalaryItemPO> salaryItemsMap) {
SalaryItemPO salaryItemPO = salaryItemsMap.get(salaryItemId);
2023-10-09 15:35:20 +08:00
if (salaryItemPO == null) {
log.error("薪资项目:{}不存在", salaryItemId);
2023-07-24 17:11:19 +08:00
throw new SalaryRunTimeException("保存失败!存在薪资项目不存在或已被删除");
}
return salaryItemPO;
}
2023-04-07 15:14:07 +08:00
2023-02-09 15:33:35 +08:00
private void handleEmpField(SalarySobItemSaveParam saveParam) {
long employeeId = (long) user.getUID();
Date now = new Date();
Long salarySobId = saveParam.getSalarySobId();
List<SalarySobItemSaveParam.SalarySobEmpFieldParam> empFields = saveParam.getEmpFields();
List<Long> newEmpIds = SalaryEntityUtil.properties(empFields, SalarySobItemSaveParam.SalarySobEmpFieldParam::getId, Collectors.toList());
List<SalarySobEmpFieldPO> salarySobEmpFieldPOS = getSalarySobEmpFieldService(user).listBySalarySobId(salarySobId);
List<Long> needDeleteEmpIds = salarySobEmpFieldPOS.stream().filter(f -> !newEmpIds.contains(f.getId())).map(SalarySobEmpFieldPO::getId).collect(Collectors.toList());
// 保存薪资账套的员工信息字段
Collection<SalarySobEmpFieldPO> needInsertSalarySobEmpFields = new ArrayList<>();
for (SalarySobItemSaveParam.SalarySobEmpFieldParam salarySobEmpFieldParam : empFields) {
if (salarySobEmpFieldParam.getId() == null) {
SalarySobEmpFieldPO salarySobEmpFieldPO = SalarySobEmpFieldPO.builder().salarySobId(saveParam.getSalarySobId()).fieldCode(salarySobEmpFieldParam.getFieldId()).sortedIndex(salarySobEmpFieldParam.getSortedIndex()).canDelete(salarySobEmpFieldParam.getCanDelete() ? NumberUtils.INTEGER_ONE : NumberUtils.INTEGER_ZERO).creator(employeeId).createTime(now).updateTime(now).deleteType(NumberUtils.INTEGER_ZERO).tenantKey(SalaryDefaultTenantConstant.DEFAULT_TENANT_KEY).build();
2023-02-09 15:33:35 +08:00
needInsertSalarySobEmpFields.add(salarySobEmpFieldPO);
} else {
SalarySobEmpFieldPO salarySobEmpFieldPO = SalarySobEmpFieldPO.builder().id(salarySobEmpFieldParam.getId()).sortedIndex(salarySobEmpFieldParam.getSortedIndex()).updateTime(now).build();
2023-02-09 15:33:35 +08:00
getSalarySobEmpFieldMapper().updateIgnoreNull(salarySobEmpFieldPO);
}
}
getSalarySobEmpFieldService(user).batchSave(needInsertSalarySobEmpFields);
//删除字段
getSalarySobEmpFieldService(user).deleteByIds(needDeleteEmpIds);
}
2022-03-23 18:41:38 +08:00
@Override
public void batchSave(Collection<SalarySobItemPO> salarySobItemPOS) {
2022-04-27 18:48:41 +08:00
if (CollectionUtils.isEmpty(salarySobItemPOS)) {
2022-04-14 20:46:17 +08:00
return;
}
2023-01-12 14:09:04 +08:00
//前端可能传重复数据,去重
List<SalarySobItemPO> list = new ArrayList<>(salarySobItemPOS.stream().collect(Collectors.toMap(SalarySobItemPO::getSalaryItemId, Function.identity(), (oldValue, newValue) -> oldValue)).values());
2023-01-12 14:09:04 +08:00
salarySobItemMapper.batchInsert(list);
2022-03-23 18:41:38 +08:00
}
@Override
public void deleteBySalarySobIds(Collection<Long> salarySobIds) {
salarySobItemMapper.deleteBySalarySobIds(salarySobIds);
}
2022-08-24 10:31:42 +08:00
@Override
public void deleteItemShowBySalarySobIds(Collection<Long> salarySobIds) {
salarySobItemMapper.deleteItemShowBySalarySobId(salarySobIds);
}
2023-07-24 17:11:19 +08:00
2023-08-31 09:24:41 +08:00
@Override
public void update(SalarySobItemPO po) {
salarySobItemMapper.update(po);
}
2024-08-13 18:15:04 +08:00
@Override
public List<SalarySobItemPO> getConfig(Long salarySobId) {
List<SalarySobItemPO> salarySobItemPOS = salarySobItemMapper.listSome(SalarySobItemPO.builder().salarySobId(salarySobId).salarySobItemGroupId(0L).build());
if (CollectionUtils.isNotEmpty(salarySobItemPOS)) {
FormluaConfig config = getSalaryFormulaService(user).getConfig();
List<FormulaPO> formulaPOS = config.getFormulas();
Map<Long, FormulaPO> formulaMap = SalaryEntityUtil.convert2Map(formulaPOS, FormulaPO::getId);
List<FormulaVar> formulaVars = config.getFormulaVars();
Map<Long, List<FormulaVar>> varListMap = SalaryEntityUtil.group2Map(formulaVars, FormulaVar::getFormulaId);
List<SalaryItemPO> salaryItems = getSalaryItemService(user).listAll();
Map<Long, SalaryItemPO> itemIdMap = SalaryEntityUtil.convert2Map(salaryItems, SalaryItemPO::getId);
salarySobItemPOS.forEach(salarySobItemPO -> {
if (SalaryEntityUtil.isNotNullOrEmpty(salarySobItemPO.getFormulaId())) {
FormulaPO formulaPO = formulaMap.get(salarySobItemPO.getFormulaId());
if (SalaryEntityUtil.isNotNullOrEmpty(formulaPO)) {
List<FormulaVar> formulaVarList = varListMap.getOrDefault(formulaPO.getId(), new ArrayList<>());
formulaPO.setFormulaVars(formulaVarList);
}
salarySobItemPO.setFormula(formulaPO);
}
2025-04-22 15:33:28 +08:00
if (SalaryEntityUtil.isNotNullOrEmpty(salarySobItemPO.getSalaryItemId())) {
2024-08-13 18:15:04 +08:00
SalaryItemPO salaryItemPO = itemIdMap.get(salarySobItemPO.getSalaryItemId());
salarySobItemPO.setSalaryItem(salaryItemPO);
}
});
}
return salarySobItemPOS;
}
2023-07-24 17:11:19 +08:00
@Override
public SalarySobItemFormDTO getSalaryItemForm(SalarySobItemPO param) {
SalarySobItemFormDTO salarySobItemFormDTO = new SalarySobItemFormDTO();
salarySobItemFormDTO.setCanEdit(1);
// 默认可以编辑
2023-10-09 10:43:43 +08:00
if (param.getSalarySobId() != null && param.getSalaryItemId() != null) {
2023-07-24 17:11:19 +08:00
// 查询薪资账套
SalarySobPO salarySobPO = salarySobBiz.getById(param.getSalarySobId());
if (Objects.isNull(salarySobPO)) {
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98379, "参数错误,薪资账套不存在或者已被删除"));
}
// 查询薪资项目
List<SalarySobItemPO> salarySobItemPOS = getSalarySobItemMapper().listSome(SalarySobItemPO.builder().salarySobId(param.getSalarySobId()).salaryItemId(param.getSalaryItemId()).build());
2023-10-09 10:43:43 +08:00
if (CollectionUtils.isEmpty(salarySobItemPOS)) {
2023-07-24 17:11:19 +08:00
throw new SalaryRunTimeException("账套中薪资项目不存在");
}
SalarySobItemPO salarySobItemPO = salarySobItemPOS.get(0);
SalaryItemPO salaryItemPO = getSalaryItemService(user).getById(salarySobItemPO.getSalaryItemId());
2023-10-09 10:43:43 +08:00
if (salaryItemPO == null) {
2023-07-24 17:11:19 +08:00
throw new SalaryRunTimeException("薪资项目不存在或已被删除");
}
//获取系统值
List<SalarySobDefaultItemPO> salarySobDefaultItemPOS = getSalarySobDefaultItemMapper().listAll();
salarySobDefaultItemPOS = salarySobDefaultItemPOS.stream().filter(po -> po.getSysSalaryItemId() != 0).collect(Collectors.toList());
Map<Long, Integer> longIntegerMap = SalaryEntityUtil.convert2Map(salarySobDefaultItemPOS, SalarySobDefaultItemPO::getSysSalaryItemId, SalarySobDefaultItemPO::getCanDelete);
2023-10-09 10:43:43 +08:00
if (salaryItemPO.getSysSalaryItemId() != null) {
2023-07-24 17:11:19 +08:00
salarySobItemPO.setCanDelete(longIntegerMap.getOrDefault(salaryItemPO.getSysSalaryItemId(), 1));
}
// 获取薪资项目公式
List<ExpressFormula> expressFormulas = getSalaryFormulaService(user).listExpressFormula(Collections.singleton(salarySobItemPO.getFormulaId()));
// 强制开启账套的公式配置
BaseBean baseBean = new BaseBean();
final Boolean openFormulaForcedEditing = "true".equals(baseBean.getPropValue("hrmSalary", "openFormulaForcedEditing"));
String formulaContent = CollectionUtils.isEmpty(expressFormulas) ? "" : expressFormulas.get(0).getFormula();
2023-10-09 10:43:43 +08:00
Integer valueType = salarySobItemPO.getValueType() == null ? salaryItemPO.getValueType() : salarySobItemPO.getValueType();
2024-05-31 11:39:08 +08:00
salarySobItemFormDTO
.setId(salarySobItemPO.getId())
.setName(salaryItemPO.getName())
2025-04-22 15:33:28 +08:00
.setItemHide(salarySobItemPO.getItemHide() == null ? 0 : Integer.parseInt(salarySobItemPO.getItemHide().toString()))
2024-05-31 11:39:08 +08:00
.setDataType(salaryItemPO.getDataType())
.setRoundingMode(salarySobItemPO.getRoundingMode() == null ? salaryItemPO.getRoundingMode() : salarySobItemPO.getRoundingMode())
.setPattern(salarySobItemPO.getPattern() == null ? salaryItemPO.getPattern() : salarySobItemPO.getPattern())
.setValueType(valueType).setFormulaId(salarySobItemPO.getFormulaId())
.setFormulaContent(CollectionUtils.isNotEmpty(expressFormulas) ? formulaContent : "")
.setOriginFormulaContent(valueType.equals(SalaryValueTypeEnum.FORMULA.getValue()) ? formulaContent : "")
.setOriginSqlContent(valueType.equals(SalaryValueTypeEnum.SQL.getValue()) ? formulaContent : "")
.setUseInEmployeeSalary(salaryItemPO.getUseInEmployeeSalary())
.setDescription(salarySobItemPO.getDescription())
2024-05-20 15:04:14 +08:00
.setCanEdit((openFormulaForcedEditing || salaryItemPO.getCanEdit().equals(1)) ? 1 : 0)
.setDefaultValue(salarySobItemPO.getDefaultValue());
2023-07-24 17:11:19 +08:00
}
return salarySobItemFormDTO;
}
2023-10-17 14:24:52 +08:00
/**
* 拓扑图
*
* @param param
* @return
*/
2023-10-16 15:00:54 +08:00
@Override
2023-10-17 10:24:30 +08:00
public SalaryItemTopologyDTO topology(SalaryItemTopologyQueryParam param) {
2023-10-16 15:00:54 +08:00
2023-10-17 10:24:30 +08:00
// 查询薪资账套
SalarySobPO salarySobPO = salarySobBiz.getById(param.getSalarySobId());
if (Objects.isNull(salarySobPO)) {
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98379, "参数错误,薪资账套不存在或者已被删除"));
2023-10-16 15:00:54 +08:00
}
2023-10-17 10:24:30 +08:00
// 查询薪资项目
List<SalarySobItemPO> salarySobItemPOS = getSalarySobItemMapper().listSome(SalarySobItemPO.builder().salarySobId(param.getSalarySobId()).salaryItemId(param.getSalaryItemId()).build());
if (CollectionUtils.isEmpty(salarySobItemPOS)) {
throw new SalaryRunTimeException("账套中薪资项目不存在");
}
SalarySobItemPO salarySobItemPO = salarySobItemPOS.get(0);
//所有薪资项目
TopologyData topologyData = init(param);
SalaryItemPO salaryItemPO = topologyData.getSalaryItemPO();
// 获取薪资项目公式
ExpressFormula expressFormula = getSalaryFormulaService(user).getExpressFormula(salarySobItemPO.getFormulaId());
SalaryItemTopologyDTO salaryItemTopologyDTO = new SalaryItemTopologyDTO();
2023-10-17 14:24:52 +08:00
salaryItemTopologyDTO.setSalaryItemId(salaryItemPO.getId());
2023-10-17 10:24:30 +08:00
salaryItemTopologyDTO.setSalaryItemName(salaryItemPO.getName());
salaryItemTopologyDTO.setFormula(expressFormula);
2025-04-22 15:33:28 +08:00
salaryItemTopologyDTO.setResult(topologyData.getResultItemMap().getOrDefault(SalaryFormulaReferenceEnum.SALARY_ITEM.getValue() + "_" + salaryItemPO.getCode(), ""));
2023-10-17 10:24:30 +08:00
topology(salaryItemTopologyDTO, topologyData);
return salaryItemTopologyDTO;
}
2023-11-17 16:00:59 +08:00
@Override
public void checkLoop(Long salarySobId) {
// 查询薪资项目副本
List<SalarySobItemPO> salarySobItemPOS = listBySalarySobId(salarySobId);
// 查询薪资项目
2024-05-30 15:19:15 +08:00
List<Long> salaryItemIds = SalaryEntityUtil.properties(salarySobItemPOS, SalarySobItemPO::getSalaryItemId, Collectors.toList());
2023-11-17 16:00:59 +08:00
List<SalaryItemPO> salaryItems = getSalaryItemService(user).listByIds(salaryItemIds);
// 查询公式详情
2024-05-30 15:19:15 +08:00
List<Long> formulaIds = SalaryEntityUtil.properties(salaryItems, SalaryItemPO::getFormulaId, Collectors.toList());
2023-11-17 16:00:59 +08:00
List<ExpressFormula> expressFormulas = getSalaryFormulaService(user).listExpressFormula(formulaIds);
2024-05-30 15:19:15 +08:00
SalaryAcctCalculatePriorityBO.calculatePriority(salarySobItemPOS, salaryItems, expressFormulas, new ArrayList<>(), new HashSet<>());
2023-11-17 16:00:59 +08:00
}
2023-10-17 14:24:52 +08:00
/**
* 递归拓扑
*
* @param salaryItemTopologyDTO
* @param topologyData
*/
2023-10-17 10:24:30 +08:00
private void topology(SalaryItemTopologyDTO salaryItemTopologyDTO, TopologyData topologyData) {
Long salaryItemId = topologyData.getSalaryItemId();
Map<Long, SalaryItemPO> salaryItemIdMap = topologyData.getSalaryItemIdMap();
Map<String, SalaryItemPO> salaryItemCodeMap = topologyData.getSalaryItemCodeMap();
Map<String, SalarySobItemPO> salarySobItemCodeMap = topologyData.getSalarySobItemCodeMap();
Map<Long, ExpressFormula> expressFormulaIdMap = topologyData.getExpressFormulaIdMap();
ExpressFormula formula = salaryItemTopologyDTO.getFormula();
if (formula != null) {
List<FormulaVar> parameters = formula.getParameters();
if (CollectionUtils.isNotEmpty(parameters)) {
List<SalaryItemTopologyDTO> salaryItemTopologyDTOChildren = new ArrayList<>();
for (int i = 0; i < parameters.size(); i++) {
FormulaVar formulaVar = parameters.get(i);
String source = formulaVar.getSource();
2025-04-22 15:33:28 +08:00
String fieldId = formulaVar.getFieldId();
String code = fieldId.replace(source + "_", "");
2023-10-17 10:24:30 +08:00
String name = formulaVar.getName();
2023-10-17 14:24:52 +08:00
String fieldName = formulaVar.getFieldName();
2023-10-17 10:24:30 +08:00
//是否是薪资项目
boolean isSalaryItemVar;
SalaryFormulaReferenceEnum salaryFormulaReferenceEnum = SalaryFormulaReferenceEnum.parseByValue(source);
if (salaryFormulaReferenceEnum == null) {
SalarySQLReferenceEnum referenceEnum = SalarySQLReferenceEnum.parseByValue(source);
if (referenceEnum == null) {
isSalaryItemVar = false;
} else {
isSalaryItemVar = referenceEnum == SalarySQLReferenceEnum.SALARY_ITEM;
}
} else {
isSalaryItemVar = salaryFormulaReferenceEnum == SalaryFormulaReferenceEnum.SALARY_ITEM;
}
ExpressFormula expressFormula;
2025-04-22 15:33:28 +08:00
if (salarySobItemCodeMap.containsKey(code)) {
2023-10-17 10:24:30 +08:00
// 如果薪资账套下重新定义了薪资项目的公式,则使用薪资账套下的公式,否则使用薪资项目本身的公式
2025-04-22 15:33:28 +08:00
expressFormula = expressFormulaIdMap.get(salarySobItemCodeMap.get(code).getFormulaId());
} else if (salaryItemCodeMap.containsKey(code)) {
expressFormula = expressFormulaIdMap.get(salaryItemCodeMap.get(code).getFormulaId());
2023-10-17 10:24:30 +08:00
} else {
2023-10-17 14:24:52 +08:00
expressFormula = null;
2023-10-17 10:24:30 +08:00
}
2025-04-22 15:33:28 +08:00
SalaryItemPO salaryItemChild = isSalaryItemVar ? salaryItemCodeMap.get(code) : new SalaryItemPO();
2023-10-17 10:24:30 +08:00
SalaryItemTopologyDTO salaryItemTopologyChild = new SalaryItemTopologyDTO();
2023-10-17 14:24:52 +08:00
salaryItemTopologyChild.setSalaryItemId(isSalaryItemVar ? salaryItemChild.getId() : null);
salaryItemTopologyChild.setSalaryItemName(isSalaryItemVar ? salaryItemChild.getName() : fieldName);
2023-10-17 10:24:30 +08:00
salaryItemTopologyChild.setFormula(expressFormula);
2025-04-22 15:33:28 +08:00
salaryItemTopologyChild.setResult(topologyData.getResultItemMap().getOrDefault(fieldId, ""));
2023-10-17 10:24:30 +08:00
salaryItemTopologyDTOChildren.add(salaryItemTopologyChild);
if (isSalaryItemVar) {
2025-04-22 15:33:28 +08:00
SalaryItemPO salaryItemChildChild = salaryItemCodeMap.get(code);
2023-10-17 10:24:30 +08:00
SalaryValueTypeEnum salaryValueTypeEnum = SalaryValueTypeEnum.parseByValue(salaryItemChildChild.getValueType());
if (salaryValueTypeEnum != SalaryValueTypeEnum.INPUT) {
topologyData.setSalaryItemId(salaryItemChildChild.getId());
topology(salaryItemTopologyChild, topologyData);
}
}
}
salaryItemTopologyDTO.setChildren(salaryItemTopologyDTOChildren);
}
}
}
private TopologyData init(SalaryItemTopologyQueryParam param) {
TopologyData topologyData = new TopologyData();
2023-10-17 14:24:52 +08:00
//薪资项目
2023-10-17 10:24:30 +08:00
topologyData.setSalaryItemId(param.getSalaryItemId());
List<SalaryItemPO> salaryItems = getSalaryItemService(user).listAll();
Map<Long, SalaryItemPO> salaryItemIdMap = SalaryEntityUtil.convert2Map(salaryItems, SalaryItemPO::getId);
topologyData.setSalaryItemIdMap(salaryItemIdMap);
Map<String, SalaryItemPO> salaryItemCodeMap = SalaryEntityUtil.convert2Map(salaryItems, SalaryItemPO::getCode);
topologyData.setSalaryItemCodeMap(salaryItemCodeMap);
SalaryItemPO salaryItemPO = salaryItemIdMap.get(topologyData.salaryItemId);
topologyData.setSalaryItemPO(salaryItemPO);
//账套项目
List<SalarySobItemPO> salarySobItems = listBySalarySobId(param.getSalarySobId());
Map<String, SalarySobItemPO> salarySobItemCodeMap = SalaryEntityUtil.convert2Map(salarySobItems, SalarySobItemPO::getSalaryItemCode);
topologyData.setSalarySobItemCodeMap(salarySobItemCodeMap);
//公式
List<ExpressFormula> expressFormulas = getSalaryFormulaService(user).listAllExpressFormula();
Map<Long, ExpressFormula> expressFormulaIdMap = SalaryEntityUtil.convert2Map(expressFormulas, ExpressFormula::getId);
topologyData.setExpressFormulaIdMap(expressFormulaIdMap);
2023-10-17 14:24:52 +08:00
//薪资结果
Long acctEmpId = param.getAcctEmpId();
if (acctEmpId != null) {
2025-04-22 15:33:28 +08:00
SalaryAcctEmployeePO acctEmployeePO = getSalaryAcctEmployeeService(user).getById(acctEmpId);
List<SalaryAcctEmployeePO> acctEmployeePOS = new ArrayList<>();
acctEmployeePOS.add(acctEmployeePO);
Long salaryAcctRecordId = acctEmployeePO.getSalaryAcctRecordId();
// 1、查询薪资核算记录
SalaryAcctRecordPO salaryAcctRecordPO = getSalaryAcctRecordService(user).getById(salaryAcctRecordId);
if (Objects.isNull(salaryAcctRecordPO)) {
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98747, "薪资核算记录不存在或已被删除"));
}
//查询对应账套
SalarySobPO salarySobPO = getSalarySobService(user).getById(salaryAcctRecordPO.getSalarySobId());
if (Objects.isNull(salarySobPO)) {
throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98747, "薪资账套不存在或已被删除"));
}
// 不是查询薪资账套下实时的薪资项目,而是查询发起薪资核算时存储的薪资项目快照
SalaryAcctConfig salaryAcctSobConfig = getSalaryAcctSobConfigService(user).getSalaryAcctConfig(salaryAcctRecordId);
// 2、查询薪资核算记录的薪资周期、考勤周期等
SalarySobCycleDTO salarySobCycleDTO = getSalaryAcctRecordService(user).getSalarySobCycleById(salaryAcctRecordId);
// 3、查询薪资核算记录所用薪资账套的薪资项目副本
List<SalarySobItemPO> salarySobItemPOS = salaryAcctSobConfig.getSalarySobItems();
// 回算薪资项目
List<SalarySobBackItemPO> salarySobBackItems = Collections.emptyList();
if (Objects.equals(salaryAcctRecordPO.getBackCalcStatus(), 1)) {
salarySobBackItems = salaryAcctSobConfig.getSalarySobBackItems();
}
// 4、查询当前租户的所有薪资项目
List<SalaryItemPO> salaryItemPOS = getSalaryItemService(user).listAll();
// 6、查询社保福利的所有字段
Map<String, String> welfareColumns = getSIAccountService(user).welfareColumns();
// 7、查询考勤引用的所有字段
List<AttendQuoteFieldListDTO> attendQuoteFieldListDTOS = getAttendQuoteFieldService(user).listAll();
List<VariableItemPO> variableItemPOS = getVariableItemService(user).listAll();
// 8、查询公式详情
Set<Long> formulaIds = SalaryEntityUtil.properties(salarySobItemPOS, SalarySobItemPO::getFormulaId);
formulaIds.addAll(SalaryEntityUtil.properties(salaryItemPOS, SalaryItemPO::getFormulaId));
formulaIds.addAll(SalaryEntityUtil.properties(salarySobBackItems, SalarySobBackItemPO::getFormulaId));
List<ExpressFormula> formulas = getSalaryFormulaService(user).listExpressFormula(formulaIds);
// 本次运算的回算薪资项目所涉及的变量
// Set<String> issuedFieldIds = getIssuedFieldIds(salarySobBackItems);
// 10、根据id查询其他合并计税的薪资核算记录
List<SalaryAcctRecordPO> otherSalaryAcctRecordPOS = getSalaryAcctRecordService(user).listById4OtherConsolidatedTax(salaryAcctRecordPO.getId());
// 12.3、生成本次运算的key
String calculateKey = UUID.randomUUID().toString();
// 12.5、多线程运算,运算结果存放在临时表中
SalaryAcctCalculateBO salaryAcctCalculateBO = new SalaryAcctCalculateBO()
.setSalaryAcctRecordPO(salaryAcctRecordPO)
.setSalarySobPO(salarySobPO)
.setSalarySobCycleDTO(salarySobCycleDTO)
.setOtherSalaryAcctRecordPOS(otherSalaryAcctRecordPOS)
.setSalarySobItemPOS(salarySobItemPOS)
.setSalaryItemIdWithPriorityList(new ArrayList<>())
.setExpressFormulas(formulas)
.setSalaryItemPOS(salaryItemPOS)
.setSalarySobAdjustRulePOS(new ArrayList<>())
.setWelfareColumns(MapUtils.emptyIfNull(welfareColumns))
.setAttendQuoteFieldListDTOS(attendQuoteFieldListDTOS)
.setSalaryAcctEmployeePOS(acctEmployeePOS)
.setIssuedFieldIds(new HashSet<>())
.setResults(null)
.setCalculateKey(calculateKey)
.setVariableItems(variableItemPOS)
.setTaxDeclarationFunction(null)
.setTaxIds(null);
List<Long> employeeIds = Collections.singletonList(acctEmployeePO.getEmployeeId());
List<DataCollectionEmployee> simpleEmployees = getSalaryEmployeeService(user).getEmployeeByIdsAll(employeeIds);
Long taxAgentId = salaryAcctCalculateBO.getSalarySobPO().getTaxAgentId();
List<SalaryArchiveDataDTO> salaryArchiveData = getSalaryArchiveService(user).getSalaryArchiveData(salarySobCycleDTO.getSalaryCycle(), employeeIds, taxAgentId);
List<AddUpSituation> addUpSituationPOS;
if (salarySobCycleDTO.getTaxCycle().getMonth() == Month.JANUARY) {
// 3.1、如果当前税款所属期是本年度第一个税款所属期,就不需要查询往期累计情况
addUpSituationPOS = Collections.emptyList();
} else {
addUpSituationPOS = getAddUpSituationService(user).getAddUpSituationList(salarySobCycleDTO.getTaxCycle().plusMonths(-1), employeeIds);
}
List<AddUpDeduction> addUpDeductionPOS = getAddUpDeductionService(user).getAddUpDeductionList(salarySobCycleDTO.getTaxCycle(), employeeIds, taxAgentId);
List<OtherDeductionPO> otherDeductionPOS = getOtherDeductionService(user).getOtherDeductionList(salarySobCycleDTO.getTaxCycle(), employeeIds, taxAgentId);
List<Map<String, Object>> welfareData = new ArrayList<>();
welfareData.addAll(getSIAccountService(user).welfareData(salarySobCycleDTO.getSocialSecurityCycle().toString(), employeeIds, taxAgentId));
List<AttendQuoteDataDTO> attendQuoteDataDTOS = getAttendQuoteDataService(user).getAttendQuoteData(salarySobCycleDTO.getSalaryMonth(), salarySobCycleDTO.getSalarySobId(), employeeIds);
List<Long> salaryAcctEmployeeIds = SalaryEntityUtil.properties(salaryAcctCalculateBO.getSalaryAcctEmployeePOS(), SalaryAcctEmployeePO::getId, Collectors.toList());
List<SalaryAcctResultPO> salaryAcctResultPOS = getSalaryAcctResultService(user).listBySalaryAcctEmployeeIds(salaryAcctEmployeeIds);
Map<String, String> empItemValueMap = SalaryEntityUtil.convert2Map(salaryAcctResultPOS, p -> p.getSalaryAcctEmpId() + "_" + p.getSalaryItemId(), SalaryAcctResultPO::getResultValue);
List<Map<String, Object>> variableArchiveList = getVariableArchiveService(user).listBySalaryMonthAndEmployeeIds(salarySobCycleDTO.getSalaryMonth(), employeeIds, taxAgentId);
Map<String, List<SalaryAcctResultPO>> collect = salaryAcctResultPOS.stream().collect(Collectors.groupingBy(k -> k.getEmployeeId() + "-" + k.getTaxAgentId() + "-" + k.getSalaryItemId()));
Map<String, String> salaryAcctResultPOMap = new HashMap<>();
for (Map.Entry<String, List<SalaryAcctResultPO>> et : collect.entrySet()) {
salaryAcctResultPOMap.put(et.getKey(), et.getValue().get(0).getOriginResultValue());
}
Set<Long> otherSalaryAcctRecordIds = SalaryEntityUtil.properties(salaryAcctCalculateBO.getOtherSalaryAcctRecordPOS(), SalaryAcctRecordPO::getId);
List<SalaryAcctResultPO> otherSalaryAcctResultPOS = getSalaryAcctResultService(user).listBySalaryAcctRecordIdsAndEmployeeIds(otherSalaryAcctRecordIds, employeeIds);
Map<String, List<SalaryAcctResultPO>> otherSalaryAcctResultPOMap = SalaryEntityUtil.group2Map(otherSalaryAcctResultPOS, e -> e.getEmployeeId() + "_" + e.getTaxAgentId());
List<SalaryAcctEmployeePO> otherSalaryAcctEmployeePOS = getSalaryAcctEmployeeService(user).listBySalaryAcctRecordIdsAndEmployeeIds(otherSalaryAcctRecordIds, employeeIds);
Map<String, List<SalaryAcctEmployeePO>> otherSalaryAcctEmployeePOMap = SalaryEntityUtil.group2Map(otherSalaryAcctEmployeePOS, salaryAcctEmployeePO -> salaryAcctEmployeePO.getEmployeeId() + "_" + salaryAcctEmployeePO.getTaxAgentId());
// List<SalaryAcctResultPO> lastMonthResultPOS = getSalaryAcctResultService(user).listBySobSalaryMonth(SalaryDateUtil.toDate(salarySobCycleDTO.getSalaryMonth().minusMonths(1), 1), salaryAcctCalculateBO.getSalarySobPO().getId(), employeeIds);
CalculateFormulaVarBO calculateFormulaVarBO = new CalculateFormulaVarBO(simpleEmployees, salaryArchiveData, addUpSituationPOS, addUpDeductionPOS, otherDeductionPOS, welfareData, attendQuoteDataDTOS, salaryAcctResultPOS, variableArchiveList);
Map<String, List<CalculateFormulaVarBO.FormulaVarValue>> formulaVarMap = calculateFormulaVarBO.convert2FormulaVar(salaryAcctCalculateBO);
Map<String, String> resultMap = new HashMap<>();
formulaVarMap.entrySet().forEach(e -> {
e.getValue().forEach(f -> {
resultMap.put(f.getFieldId(), f.getFieldValue());
});
});
topologyData.setResultItemMap(resultMap);
2023-10-17 14:24:52 +08:00
} else {
topologyData.setResultItemMap(new HashMap<>());
}
2023-10-17 10:24:30 +08:00
return topologyData;
}
@Data
class TopologyData {
2023-10-17 14:24:52 +08:00
/**
* 薪资项目id
*/
2023-10-17 10:24:30 +08:00
Long salaryItemId;
2023-10-17 14:24:52 +08:00
/**
* 薪资项目
*/
2023-10-17 10:24:30 +08:00
Map<Long, SalaryItemPO> salaryItemIdMap;
Map<String, SalaryItemPO> salaryItemCodeMap;
2023-10-17 14:24:52 +08:00
/**
* 账套项目
*/
2023-10-17 10:24:30 +08:00
SalaryItemPO salaryItemPO;
Map<String, SalarySobItemPO> salarySobItemCodeMap;
2023-10-17 14:24:52 +08:00
/**
* 公式
*/
2023-10-17 10:24:30 +08:00
Map<Long, ExpressFormula> expressFormulaIdMap;
2023-10-17 14:24:52 +08:00
/**
* 核算结果
*/
2025-04-22 15:33:28 +08:00
Map<String, String> resultItemMap;
2023-10-16 15:00:54 +08:00
}
2023-10-16 10:45:19 +08:00
2022-03-21 20:09:10 +08:00
}