2022-12-06 09:41:26 +08:00
|
|
|
|
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;
|
2024-11-19 13:35:25 +08:00
|
|
|
|
import org.apache.commons.lang3.StringUtils;
|
2022-12-06 09:41:26 +08:00
|
|
|
|
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.List;
|
|
|
|
|
|
import java.util.Map;
|
|
|
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
|
|
|
|
@Slf4j
|
2022-12-06 10:26:36 +08:00
|
|
|
|
public class CheckBatEditSalaryExcelAction implements Action {
|
2022-12-06 09:41:26 +08:00
|
|
|
|
|
|
|
|
|
|
private SalaryArchiveExcelService getSalaryArchiveExcelService(User user) {
|
|
|
|
|
|
return ServiceUtil.getService(SalaryArchiveExcelServiceImpl.class, user);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-06 09:52:55 +08:00
|
|
|
|
private String batSalaryExcelField;
|
|
|
|
|
|
|
|
|
|
|
|
public String getBatSalaryExcelField() {
|
|
|
|
|
|
return batSalaryExcelField;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void setBatSalaryExcelField(String batSalaryExcelField) {
|
|
|
|
|
|
this.batSalaryExcelField = batSalaryExcelField;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-16 10:32:45 +08:00
|
|
|
|
private String operatorField;
|
|
|
|
|
|
|
|
|
|
|
|
public String getOperatorField() {
|
|
|
|
|
|
return operatorField;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void setOperatorField(String operatorField) {
|
|
|
|
|
|
this.operatorField = operatorField;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2024-11-19 13:35:25 +08:00
|
|
|
|
// 是否执行action的字段, 0代表不执行,其余代表执行
|
|
|
|
|
|
private String enableField;
|
|
|
|
|
|
|
|
|
|
|
|
public String getEnableField() {
|
|
|
|
|
|
return enableField;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void setEnableField(String enableField) {
|
|
|
|
|
|
this.enableField = enableField;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-06 09:41:26 +08:00
|
|
|
|
@Override
|
|
|
|
|
|
public String execute(RequestInfo requestInfo) {
|
|
|
|
|
|
try {
|
|
|
|
|
|
Property[] properties = requestInfo.getMainTableInfo().getProperty();
|
|
|
|
|
|
Map<String, String> fieldMap = Arrays.stream(properties).collect(Collectors.toMap(Property::getName,
|
|
|
|
|
|
property -> Util.null2String(property.getValue())));
|
|
|
|
|
|
|
2024-11-19 13:35:25 +08:00
|
|
|
|
String enable = fieldMap.get(enableField);
|
|
|
|
|
|
if (StringUtils.isNotBlank(enable) && enable.equals("0")) {
|
|
|
|
|
|
// 不执行action
|
|
|
|
|
|
return SUCCESS;
|
|
|
|
|
|
}
|
2022-12-06 09:52:55 +08:00
|
|
|
|
String docId = fieldMap.get(batSalaryExcelField);
|
2022-12-06 09:41:26 +08:00
|
|
|
|
|
|
|
|
|
|
RecordSet rs = new RecordSet();
|
|
|
|
|
|
String queryImageId = "select imagefileid from docimagefile where docid = ?";
|
2022-12-06 09:52:55 +08:00
|
|
|
|
rs.executeQuery(queryImageId, docId);
|
2022-12-06 09:41:26 +08:00
|
|
|
|
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(true)
|
|
|
|
|
|
.isProcess(true)
|
|
|
|
|
|
.build();
|
|
|
|
|
|
|
2022-12-16 10:32:45 +08:00
|
|
|
|
//操作人
|
|
|
|
|
|
String uid = fieldMap.getOrDefault(operatorField, "1");
|
|
|
|
|
|
Map<String, Object> map = getSalaryArchiveExcelService(new User(Integer.parseInt(uid))).batchImportEbatch(param);
|
2022-12-06 09:41:26 +08:00
|
|
|
|
int errorCount = (int) map.get("errorCount");
|
|
|
|
|
|
if (errorCount > 0) {
|
2022-12-16 10:32:45 +08:00
|
|
|
|
log.error("批量调薪检查存在异常 requestId:{} map:{}", requestInfo.getRequestid(), map);
|
2022-12-06 09:41:26 +08:00
|
|
|
|
List<Map<String, String>> excelComments = (List<Map<String, String>>) map.get("errorNotice");
|
|
|
|
|
|
StringBuilder message = new StringBuilder("excel中");
|
|
|
|
|
|
for (Map<String, String> comments : excelComments) {
|
|
|
|
|
|
message.append(comments.get("message")).append("\n");
|
|
|
|
|
|
}
|
|
|
|
|
|
requestInfo.getRequestManager().setMessage(message.toString());
|
|
|
|
|
|
return FAILURE_AND_CONTINUE;
|
|
|
|
|
|
}
|
|
|
|
|
|
} catch (Exception e) {
|
2022-12-07 09:17:31 +08:00
|
|
|
|
log.error("批量调薪检查异常", e);
|
2022-12-06 09:41:26 +08:00
|
|
|
|
requestInfo.getRequestManager().setMessage(e.getMessage());
|
|
|
|
|
|
return FAILURE_AND_CONTINUE;
|
|
|
|
|
|
}
|
|
|
|
|
|
return SUCCESS;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|