package com.engine.salary.wrapper; import com.engine.common.util.ServiceUtil; import com.engine.core.impl.Service; import com.engine.salary.component.WeaFormOption; import com.engine.salary.entity.salaryformula.ExpressFormula; import com.engine.salary.entity.salaryformula.po.FormulaVar; import com.engine.salary.entity.salaryitem.bo.SalaryItemBO; import com.engine.salary.entity.salaryitem.bo.SysSalaryItemBO; import com.engine.salary.entity.salaryitem.dto.SalaryItemFormDTO; import com.engine.salary.entity.salaryitem.dto.SalaryItemListDTO; import com.engine.salary.entity.salaryitem.param.SalaryItemSaveParam; import com.engine.salary.entity.salaryitem.param.SalaryItemSearchParam; import com.engine.salary.entity.salaryitem.po.SalaryItemPO; import com.engine.salary.entity.salaryitem.po.SysSalaryItemPO; import com.engine.salary.entity.salarysob.po.SalarySobBackItemPO; import com.engine.salary.entity.salarysob.po.SalarySobItemPO; import com.engine.salary.enums.*; import com.engine.salary.enums.salaryitem.SalaryDataTypeEnum; import com.engine.salary.exception.SalaryRunTimeException; import com.engine.salary.service.*; import com.engine.salary.service.impl.*; import com.engine.salary.util.SalaryEntityUtil; import com.engine.salary.util.SalaryI18nUtil; import com.engine.salary.util.page.PageInfo; import com.engine.salary.util.valid.RuntimeTypeEnum; import com.engine.salary.util.valid.ValidUtil; import lombok.Builder; import org.apache.commons.collections4.CollectionUtils; import org.apache.commons.lang.math.NumberUtils; import org.apache.commons.lang3.StringUtils; import weaver.hrm.User; import java.util.*; import java.util.stream.Collectors; /** * 薪资项目 *

Copyright: Copyright (c) 2022

*

Company: 泛微软件

* * @author qiantao * @version 1.0 **/ public class SalaryItemWrapper extends Service { private SalaryItemService getSalaryItemService(User user) { return ServiceUtil.getService(SalaryItemServiceImpl.class, user); } private SysSalaryItemService getSysSalaryItemService(User user) { return ServiceUtil.getService(SysSalaryItemServiceImpl.class, user); } private SalaryFormulaService getSalaryFormulaService(User user) { return ServiceUtil.getService(SalaryFormulaServiceImpl.class, user); } private SalarySobItemService getSalarySobItemService(User user) { return ServiceUtil.getService(SalarySobItemServiceImpl.class, user); } private SalarySobBackItemService getSalarySobBackItemService(User user) { return ServiceUtil.getService(SalarySobBackItemServiceImpl.class, user); } /** * 薪资项目列表 * * @param searchParam 查询参数 * @return */ public PageInfo listPage(SalaryItemSearchParam searchParam) { //清除未被引用的公式 List sysItems = getSysSalaryItemService(user).listAll(); List sysItemFormulaIds = SalaryEntityUtil.properties(sysItems, SysSalaryItemPO::getFormulaId, Collectors.toList()); List items = getSalaryItemService(user).listAll(); List itemFormulaIds = SalaryEntityUtil.properties(items, SalaryItemPO::getFormulaId, Collectors.toList()); List sobItems = getSalarySobItemService(user).list(); List sobItemFormulaIds = SalaryEntityUtil.properties(sobItems, SalarySobItemPO::getFormulaId, Collectors.toList()); List backItems = getSalarySobBackItemService(user).listAll(); List backItemFormulaIds = SalaryEntityUtil.properties(backItems, SalarySobBackItemPO::getFormulaId, Collectors.toList()); List effectiveFormulaIds = new ArrayList<>(); effectiveFormulaIds.addAll(sysItemFormulaIds); effectiveFormulaIds.addAll(itemFormulaIds); effectiveFormulaIds.addAll(sobItemFormulaIds); effectiveFormulaIds.addAll(backItemFormulaIds); //删除无用公式 // getSalaryFormulaService(user).deleteNotIn(effectiveFormulaIds); //账套里的项目,项目里的项目 List sobItemIds = SalaryEntityUtil.properties(sobItems, SalarySobItemPO::getSalaryItemId, Collectors.toList()); List backItemIds = SalaryEntityUtil.properties(backItems, SalarySobBackItemPO::getSalaryItemId, Collectors.toList()); List usingItemIds = new ArrayList<>(); usingItemIds.addAll(sobItemIds); usingItemIds.addAll(backItemIds); List formulaVars = getSalaryFormulaService(user).listVarByFormulaIds(effectiveFormulaIds); List itemCode = formulaVars.stream().map(FormulaVar::getFieldId).map(v -> v.replaceAll("salaryItem_", "")).collect(Collectors.toList()); //!!! 从2023-01-23起,薪资项目这里不再查询薪资档案引用的项目 !!! //薪资档案引用的项目转移到字段管理功能项 searchParam.setUseInEmployeeSalary(SalaryOnOffEnum.OFF.getValue()); // 1、查询薪资项目 PageInfo page = getSalaryItemService(user).listPageByParam(searchParam); List salaryItemList = page.getList(); //最终返回的分页对象 PageInfo salaryItemListDTOPage = new PageInfo<>(SalaryItemListDTO.class); salaryItemListDTOPage.setPageSize(page.getPageSize()); salaryItemListDTOPage.setPageNum(page.getPageNum()); salaryItemListDTOPage.setTotal(page.getTotal()); // 被薪资账套引用的薪资项目 List salarySobItems = new ArrayList<>(); if (CollectionUtils.isNotEmpty(salaryItemList)) { //2、填充公式内容 Set formulaIds = SalaryEntityUtil.properties(salaryItemList, SalaryItemPO::getFormulaId); List expressFormulas = getSalaryFormulaService(user).listExpressFormula(formulaIds); // 查询系统薪资项目 Set sysSalaryItemIds = SalaryEntityUtil.properties(salaryItemList, SalaryItemPO::getSysSalaryItemId); List sysSalaryItemPOS = getSysSalaryItemService(user).listByIds(sysSalaryItemIds); // 转换成薪资项目列表dto List salaryItemListDTOS = SalaryItemBO.convert2ListDTO(salaryItemList, expressFormulas, sysSalaryItemPOS); //系统项目不删除 salaryItemListDTOS.forEach(dto -> { if (StringUtils.isNotBlank(dto.getSystemName()) || usingItemIds.contains(dto.getId()) || itemCode.contains(dto.getCode())) { dto.setCanDelete(false); } }); salaryItemListDTOPage.setList(salaryItemListDTOS); } return salaryItemListDTOPage; } /** * 可以删除的薪资项目列表 * * @param searchParam 查询人员 * @return */ public PageInfo listPage4CanDelete(SalaryItemSearchParam searchParam) { // 查询所有薪资账套中的薪资项目副本 List salarySobItemPOS = getSalarySobItemService(user).list(); // 被引用的薪资项目id Set salaryItemIds = SalaryEntityUtil.properties(salarySobItemPOS, SalarySobItemPO::getSalaryItemId); // 排除被引用的薪资项目(被引用的薪资项目不可以删除) searchParam.setExcludeIds(salaryItemIds); // 转换成前端所需的数据格式 return listPage(searchParam); } /** * 根据主键id获取薪资项目详情 * * @param ids 薪资项目的主键id * @return */ public List listByIds(Collection ids) { List salaryItemPOS = getSalaryItemService(user).listByIds(ids); if (CollectionUtils.isEmpty(salaryItemPOS)) { return Collections.emptyList(); } // 查询公式详情 Set formulaIds = SalaryEntityUtil.properties(salaryItemPOS, SalaryItemPO::getFormulaId); List expressFormulas = getSalaryFormulaService(user).listExpressFormula(formulaIds); // 查询系统薪资项目 Set sysSalaryItemIds = SalaryEntityUtil.properties(salaryItemPOS, SalaryItemPO::getSysSalaryItemId); List sysSalaryItemPOS = getSysSalaryItemService(user).listByIds(sysSalaryItemIds); // 转换成薪资项目列表dto return SalaryItemBO.convert2ListDTO(salaryItemPOS, expressFormulas, sysSalaryItemPOS); } /** * 薪资项目详情 * * @param id 主键id * @return */ public SalaryItemFormDTO getForm(Long id) { SalaryItemFormDTO salaryItemFormDTO = new SalaryItemFormDTO(); // 默认可以编辑 salaryItemFormDTO.setCanEdit(NumberUtils.INTEGER_ONE); if (!Objects.isNull(id)) { // 查询薪资项目 SalaryItemPO salaryItemPO = getSalaryItemService(user).getById(id); // 系统薪资项目 SysSalaryItemPO sysSalaryItemPO = getSysSalaryItemService(user).getById(id); if (Objects.isNull(salaryItemPO) && Objects.isNull(sysSalaryItemPO)) { throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98299, "参数错误,薪资项目不存在或已被删除")); } ExpressFormula expressFormula; // // 转换成薪资项目详情dto if (Objects.isNull(salaryItemPO)) { salaryItemFormDTO = SysSalaryItemBO.convert2FormDTO(sysSalaryItemPO); expressFormula = getSalaryFormulaService(user).getExpressFormula(sysSalaryItemPO.getFormulaId()); } else { salaryItemFormDTO = SalaryItemBO.convert2FormDTO(salaryItemPO); expressFormula = getSalaryFormulaService(user).getExpressFormula(salaryItemPO.getFormulaId()); } salaryItemFormDTO.setFormulaContent(Optional.ofNullable(expressFormula).map(ExpressFormula::getFormula).orElse("")); } return salaryItemFormDTO; } /** * 获取薪资项目可选的类型(与属性有联动) * * @return */ public Map> listSalaryItemTypeOption() { return SalaryEntityUtil.group2ListMap(Arrays.asList(SalaryItemTypeEnum.values()), e -> e.getCategory().name(), e -> new WeaFormOption(e.name(), SalaryI18nUtil.getI18nLabel(e.getLabelId(), e.getDefaultLabel()))); } /** * 保存薪资项目 * * @param saveParam 保存参数 */ public void save(SalaryItemSaveParam saveParam) { ValidUtil.doValidator(saveParam); validParam(saveParam); getSalaryItemService(user).save(saveParam); } private void validParam(SalaryItemSaveParam saveParam) { if (SalarySystemTypeEnum.parseByValue(saveParam.getSystemType()) == null) { throw new SalaryRunTimeException("系统内置的薪资项目异常"); } if (SalaryRoundingModeEnum.parseByValue(saveParam.getRoundingMode()) == null) { throw new SalaryRunTimeException("舍入规则异常"); } if (SalaryValueTypeEnum.parseByValue(saveParam.getValueType()) == null) { throw new SalaryRunTimeException("取值方式异常"); } if (SalaryDataTypeEnum.parseByValue(saveParam.getDataType()) == null) { throw new SalaryRunTimeException("字段类型异常"); } } /** * 编辑薪资项目 * * @param saveParam 更新参数 */ public void update(SalaryItemSaveParam saveParam) { ValidUtil.doValidator(saveParam, RuntimeTypeEnum.UPDATE); validParam(saveParam); getSalaryItemService(user).update(saveParam); } /** * 删除薪资项目 * * @param ids 主键id */ public void delete(Collection ids) { //清除未被引用的公式 List effectiveFormulaIds = getEffectiveFormulaIds(); //删除无用公式 // getSalaryFormulaService(user).deleteNotIn(effectiveFormulaIds); //账套里的项目,项目里的项目 List sobItemIds = SalaryEntityUtil.properties(sobItems, SalarySobItemPO::getSalaryItemId, Collectors.toList()); List backItemIds = SalaryEntityUtil.properties(backItems, SalarySobBackItemPO::getSalaryItemId, Collectors.toList()); List usingItemIds = new ArrayList<>(); usingItemIds.addAll(sobItemIds); usingItemIds.addAll(backItemIds); List formulaVars = getSalaryFormulaService(user).listVarByFormulaIds(effectiveFormulaIds); List itemCode = formulaVars.stream().map(FormulaVar::getFieldId).map(v -> v.replaceAll("salaryItem_", "")).collect(Collectors.toList()); // 查询薪资项目 List salaryItemPOS = getSalaryItemService(user).listByIds(ids); if (CollectionUtils.isEmpty(salaryItemPOS)) { throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98299, "参数错误,薪资项目不存在或已被删除")); } if (CollectionUtils.containsAny(usingItemIds, ids)) { throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98322, "薪资账套正在使用该薪资项目,不允许删除")); } List codes = SalaryEntityUtil.properties(salaryItemPOS, SalaryItemPO::getCode, Collectors.toList()); if (CollectionUtils.containsAny(itemCode, codes)) { throw new SalaryRunTimeException(SalaryI18nUtil.getI18nLabel(98322, "公式正在使用该薪资项目,不允许删除")); } getSalaryItemService(user).deleteByIds(ids); } private usingItemAndFormulaIds getUsingFormulaIds() { //系统项目 List sysItems = getSysSalaryItemService(user).listAll(); List sysItemFormulaIds = SalaryEntityUtil.properties(sysItems, SysSalaryItemPO::getFormulaId, Collectors.toList()); //薪资项目 List items = getSalaryItemService(user).listAll(); List itemFormulaIds = SalaryEntityUtil.properties(items, SalaryItemPO::getFormulaId, Collectors.toList()); //账套项目 List sobItems = getSalarySobItemService(user).list(); List sobItemFormulaIds = SalaryEntityUtil.properties(sobItems, SalarySobItemPO::getFormulaId, Collectors.toList()); //回算项目 List backItems = getSalarySobBackItemService(user).listAll(); List backItemFormulaIds = SalaryEntityUtil.properties(backItems, SalarySobBackItemPO::getFormulaId, Collectors.toList()); List usingFormulaIds = new ArrayList<>(); usingFormulaIds.addAll(sysItemFormulaIds); usingFormulaIds.addAll(itemFormulaIds); usingFormulaIds.addAll(sobItemFormulaIds); usingFormulaIds.addAll(backItemFormulaIds); return usingFormulaIds; } @Builder class UsingItemAndFormulaIds { private List usingFormulaIds; private List usingItemIds; } }