package com.engine.salary.action; import com.engine.common.util.ServiceUtil; import com.engine.salary.entity.salaryarchive.param.SalaryArchiveImportHandleParam; import com.engine.salary.enums.salaryarchive.SalaryArchiveImportTypeEnum; import com.engine.salary.enums.salaryarchive.SalaryArchiveListTypeEnum; import com.engine.salary.service.SalaryArchiveExcelService; import com.engine.salary.service.impl.SalaryArchiveExcelServiceImpl; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import weaver.conn.RecordSet; import weaver.general.Util; import weaver.hrm.User; import weaver.interfaces.workflow.action.Action; import weaver.soa.workflow.request.Property; import weaver.soa.workflow.request.RequestInfo; import java.util.Arrays; import java.util.Map; import java.util.stream.Collectors; @Slf4j public class BatEditSalaryExcelAction implements Action { private SalaryArchiveExcelService getSalaryArchiveExcelService(User user) { return ServiceUtil.getService(SalaryArchiveExcelServiceImpl.class, user); } private String batSalaryExcelField; public String getBatSalaryExcelField() { return batSalaryExcelField; } public void setBatSalaryExcelField(String batSalaryExcelField) { this.batSalaryExcelField = batSalaryExcelField; } private String operatorField; public String getOperatorField() { return operatorField; } public void setOperatorField(String operatorField) { this.operatorField = operatorField; } // 是否执行action的字段, 0代表不执行,其余代表执行 private String enableField; public String getEnableField() { return enableField; } public void setEnableField(String enableField) { this.enableField = enableField; } @Override public String execute(RequestInfo requestInfo) { try { Property[] properties = requestInfo.getMainTableInfo().getProperty(); Map fieldMap = Arrays.stream(properties).collect(Collectors.toMap(Property::getName, property -> Util.null2String(property.getValue()))); String enable = fieldMap.get(enableField); if (StringUtils.isNotBlank(enable) && enable.equals("0")) { // 不执行action return SUCCESS; } String docId = fieldMap.get(batSalaryExcelField); RecordSet rs = new RecordSet(); String queryImageId = "select imagefileid from docimagefile where docid = ?"; rs.executeQuery(queryImageId, docId); String imagefileid = null; if (rs.next()) { imagefileid = rs.getString("imagefileid"); } SalaryArchiveImportHandleParam param = SalaryArchiveImportHandleParam.builder().imageId(imagefileid) .listType(SalaryArchiveListTypeEnum.FIXED.getValue()) .importType(SalaryArchiveImportTypeEnum.SALARYITEMADJUST.getValue()) .onlyCheck(false) .isProcess(true) .build(); //操作人 String uid = fieldMap.getOrDefault(operatorField, "1"); Map map = getSalaryArchiveExcelService(new User(Integer.parseInt(uid))).batchImportEbatch(param); int errorCount = (int) map.get("errorCount"); if (errorCount > 0) { log.error("批量调薪存在异常 requestId:{} map:{}",requestInfo.getRequestid(), map); // List> excelComments = (List>) map.get("errorNotice"); // StringBuilder message = new StringBuilder(); // for (Map comments : excelComments) { // message.append(comments.get("message")).append("/n"); // } // requestInfo.getRequestManager().setMessage(message.toString()); // return FAILURE_AND_CONTINUE; } } catch (Exception e) { log.error("批量调薪异常", e); requestInfo.getRequestManager().setMessage(e.getMessage()); return FAILURE_AND_CONTINUE; } return SUCCESS; } }