部门筛选转部门筛选反馈(单一、批量)Action

This commit is contained in:
dxfeng 2023-09-20 11:47:27 +08:00
parent d93a4b6c8b
commit c14c7ecfdc
4 changed files with 189 additions and 47 deletions

View File

@ -26,7 +26,7 @@ public class RecruitButtonWrapper extends Service {
* @param classPath 类全路径
* @return
*/
public RecruitButtonService getRecruitButtonService(User user, String classPath) {
private RecruitButtonService getRecruitButtonService(User user, String classPath) {
return ServiceUtil.getService(RecruitButtonFactory.getClass(classPath), user);
}

View File

@ -0,0 +1,156 @@
package weaver.formmode.recruit.departmentscreening;
import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang3.StringUtils;
import weaver.common.DateUtil;
import weaver.conn.RecordSet;
import weaver.formmode.customjavacode.AbstractModeExpandJavaCodeNew;
import weaver.formmode.setup.ModeRightInfo;
import weaver.general.BaseBean;
import weaver.general.Util;
import weaver.soa.workflow.request.*;
import java.util.*;
/**
* <p>聚才林招聘</p>
* 批量发起部门筛选转部门筛选反馈数据
*
* @author:dxfeng
* @createTime: 2023/09/18
* @version: 1.0
*/
public class BatchAddDeptScreeningModeExpand extends AbstractModeExpandJavaCodeNew {
/**
* JCL_部门筛选反馈(uf_jcl_bmsxfk)
*/
private static final String MODE_TABLE_NAME = "uf_jcl_bmsxfk";
@Override
public Map<String, String> doModeExpand(Map<String, Object> param) {
Map<String, String> result = new HashMap<>();
try {
RequestInfo requestInfo = (RequestInfo) param.get("RequestInfo");
if (requestInfo != null) {
int formModeId = -1;
RecordSet rs = new RecordSet();
rs.executeQuery("select id from modeinfo where formid =( select id from workflow_bill where tablename = ? )", MODE_TABLE_NAME);
if (rs.next()) {
formModeId = rs.getInt("id");
}
MainTableInfo mainTableInfo = requestInfo.getMainTableInfo();
Property[] properties = mainTableInfo.getProperty();
Map<String, Object> mainDataMap = new HashMap<>();
for (Property property : properties) {
mainDataMap.put(property.getName(), property.getValue());
}
// 部门筛选ID
mainDataMap.put("bmsxid", requestInfo.getRequestid());
// 结果
mainDataMap.put("jg", "2");
// 填充建模数据基本信息
mainDataMap.put("formmodeid", formModeId);
mainDataMap.put("modedatacreater", requestInfo.getCreatorid());
String dateTime = DateUtil.getFullDate();
String[] split = dateTime.split(" ");
mainDataMap.put("modedatacreatedate", split[0]);
mainDataMap.put("modedatacreatetime", split[1]);
mainDataMap.put("modedatamodifier", requestInfo.getCreatorid());
mainDataMap.put("modedatamodifydatetime", dateTime);
mainDataMap.put("modedatacreatertype", "0");
List<Map<String, Object>> detailMapList = new ArrayList<>();
DetailTableInfo detailTableInfo = requestInfo.getDetailTableInfo();
DetailTable detailTable = detailTableInfo.getDetailTable(0);
Row[] rows = detailTable.getRow();
for (Row row : rows) {
Map<String, Object> detailDataMap = new HashMap<>(mainDataMap);
Cell[] cells = row.getCell();
for (Cell cell : cells) {
detailDataMap.put(cell.getName(), cell.getValue());
}
detailMapList.add(detailDataMap);
}
for (Map<String, Object> detailDataMap : detailMapList) {
List<List<Object>> paramList = new ArrayList<>();
buildParamList(detailDataMap, paramList);
if (CollectionUtils.isNotEmpty(paramList)) {
String insertSql = "insert into " + MODE_TABLE_NAME + " (modeuuid, modedatacreatertype, formmodeid, modedatacreater, modedatacreatedate, modedatacreatetime, modedatamodifier, modedatamodifydatetime, bmsxid, ypz, ypzw, tdsj, jg, pcid, fkr) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)";
for (List<Object> objects : paramList) {
String uuid = UUID.randomUUID().toString();
objects.add(0, uuid);
rs.executeUpdate(insertSql, objects);
refreshRight(rs, uuid, formModeId);
}
}
}
}
} catch (Exception e) {
new BaseBean().writeLog(e);
result.put("errmsg", "自定义出错信息");
result.put("flag", "false");
}
return result;
}
/**
* 构建批量插入数据集合
*
* @param map 表单参数
* @param paramList 待插入数据集合
*/
private void buildParamList(Map<String, Object> map, List<List<Object>> paramList) {
List<Object> param = new ArrayList<>();
// 填充建模表相关字段
param.add(map.get("modedatacreatertype"));
param.add(map.get("formmodeid"));
param.add(map.get("modedatacreater"));
param.add(map.get("modedatacreatedate"));
param.add(map.get("modedatacreatetime"));
param.add(map.get("modedatamodifier"));
param.add(map.get("modedatamodifydatetime"));
//部门筛选ID
param.add(map.get("bmsxid"));
// 应聘者
param.add(map.get("ypz"));
// 应聘职位
param.add(map.get("ypzw"));
// 投递时间
param.add(map.get("tdsj"));
// 状态
param.add(map.get("jg"));
// 批次ID
param.add(map.get("pcid"));
// 反馈人
String fkr = Util.null2String(map.get("fkr"));
if (StringUtils.isNotBlank(fkr)) {
String[] fkrArray = fkr.split(",");
for (String fkrId : fkrArray) {
ArrayList<Object> objects = new ArrayList<>(param);
objects.add(fkrId);
paramList.add(objects);
}
}
}
/**
* 权限重构
*
* @param rs RecordSet
* @param uuid UUID
* @param formModeId 建模ID
*/
private void refreshRight(RecordSet rs, String uuid, int formModeId) {
rs.executeQuery("select id from " + MODE_TABLE_NAME + " where modeuuid='" + uuid + "'");
if (rs.next()) {
//建模数据的id
int bid = Util.getIntValue(rs.getString("id"));
ModeRightInfo modeRightInfo = new ModeRightInfo();
modeRightInfo.setNewRight(true);
//新建的时候添加共享
modeRightInfo.editModeDataShare(1, formModeId, bid);
}
}
}

View File

@ -16,13 +16,13 @@ import java.util.*;
/**
* <p>聚才林招聘</p>
* 发起部门筛选转部门筛选反馈数据
* 单一发起部门筛选转部门筛选反馈数据
*
* @author:dxfeng
* @createTime: 2023/09/18
* @version: 1.0
*/
public class AddDeptScreeningModeExpand extends AbstractModeExpandJavaCodeNew {
public class SingleAddDeptScreeningModeExpand extends AbstractModeExpandJavaCodeNew {
/**
* JCL_部门筛选反馈(uf_jcl_bmsxfk)
*/
@ -67,7 +67,7 @@ public class AddDeptScreeningModeExpand extends AbstractModeExpandJavaCodeNew {
List<List<Object>> paramList = new ArrayList<>();
buildParamList(dataMap, paramList);
if (CollectionUtils.isNotEmpty(paramList)) {
String insertSql = "insert into " + MODE_TABLE_NAME + " (modeuuid, modedatacreatertype, formmodeid, modedatacreater, modedatacreatedate, modedatacreatetime, modedatamodifier, modedatamodifydatetime, bmsxid, ypz, ypzw, tdsj, jg, fkr) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)";
String insertSql = "insert into " + MODE_TABLE_NAME + " (modeuuid, modedatacreatertype, formmodeid, modedatacreater, modedatacreatedate, modedatacreatetime, modedatamodifier, modedatamodifydatetime, bmsxid, ypz, ypzw, tdsj, jg, pcid, fkr) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)";
for (List<Object> objects : paramList) {
String uuid = UUID.randomUUID().toString();
objects.add(0, uuid);
@ -91,41 +91,36 @@ public class AddDeptScreeningModeExpand extends AbstractModeExpandJavaCodeNew {
* @param paramList 待插入数据集合
*/
private void buildParamList(Map<String, Object> map, List<List<Object>> paramList) {
String ypz = Util.null2String(map.get("ypz"));
String[] ypzIds = ypz.split(",");
for (String ypzId : ypzIds) {
if (StringUtils.isBlank(ypzId)) {
continue;
}
List<Object> param = new ArrayList<>();
// 填充建模表相关字段
param.add(map.get("modedatacreatertype"));
param.add(map.get("formmodeid"));
param.add(map.get("modedatacreater"));
param.add(map.get("modedatacreatedate"));
param.add(map.get("modedatacreatetime"));
param.add(map.get("modedatamodifier"));
param.add(map.get("modedatamodifydatetime"));
List<Object> param = new ArrayList<>();
// 填充建模表相关字段
param.add(map.get("modedatacreatertype"));
param.add(map.get("formmodeid"));
param.add(map.get("modedatacreater"));
param.add(map.get("modedatacreatedate"));
param.add(map.get("modedatacreatetime"));
param.add(map.get("modedatamodifier"));
param.add(map.get("modedatamodifydatetime"));
//部门筛选ID
param.add(map.get("bmsxid"));
// 应聘者
param.add(ypzId);
// 应聘职位
param.add(map.get("ypzw"));
// 投递时间
param.add(map.get("tdsj"));
// 状态
param.add(map.get("jg"));
// 反馈人
String fkr = Util.null2String(map.get("fkr"));
if (StringUtils.isNotBlank(fkr)) {
String[] fkrArray = fkr.split(",");
for (String fkrId : fkrArray) {
ArrayList<Object> objects = new ArrayList<>(param);
objects.add(fkrId);
paramList.add(objects);
}
//部门筛选ID
param.add(map.get("bmsxid"));
// 应聘者
param.add(map.get("ypz"));
// 应聘职位
param.add(map.get("ypzw"));
// 投递时间
param.add(map.get("tdsj"));
// 状态
param.add(map.get("jg"));
// 批次ID
param.add(map.get("pcid"));
// 反馈人
String fkr = Util.null2String(map.get("fkr"));
if (StringUtils.isNotBlank(fkr)) {
String[] fkrArray = fkr.split(",");
for (String fkrId : fkrArray) {
ArrayList<Object> objects = new ArrayList<>(param);
objects.add(fkrId);
paramList.add(objects);
}
}
}

View File

@ -10,7 +10,6 @@ import weaver.general.Util;
import weaver.soa.workflow.request.MainTableInfo;
import weaver.soa.workflow.request.Property;
import weaver.soa.workflow.request.RequestInfo;
import weaver.workflow.workflow.WorkflowBillComInfo;
import java.util.*;
@ -37,13 +36,6 @@ public class RelatedStageModeExpand extends AbstractModeExpandJavaCodeNew {
if (requestInfo != null) {
billId = requestInfo.getRequestid();
// 获取表单名称
String formId = Util.null2String(param.get("formid"));
String tableName = new WorkflowBillComInfo().getTablename(formId);
//String sql = "update " + tableName + " set xqzt = ? ,jssj = ?,wcsj = ? where id = ?";
//RecordSet rs = new RecordSet();
//// 更新状态为招聘完成置空结束日期完成日期取当前日期
//rs.executeUpdate(sql, RecruitStatusEnum.RECRUITMENT_COMPLETED.getValue(), null, DateUtil.getCurrentDate(), billId);
new BaseBean().writeLog("完成需求操作billId=[" + billId + "]操作完成");
MainTableInfo mainTableInfo = requestInfo.getMainTableInfo();
Property[] properties = mainTableInfo.getProperty();
Map<String, String> mainDataMap = new HashMap<>();
@ -58,7 +50,6 @@ public class RelatedStageModeExpand extends AbstractModeExpandJavaCodeNew {
String jsjd = mainDataMap.get("jsjd");
// 查询所有的操作阶段信息
relatedStageData(requestInfo.getCreatorid(), billId, ksjd, gcjd, jsjd);
}
} catch (Exception e) {
new BaseBean().writeLog(e);