Compare commits
2 Commits
28464f4c8d
...
09ea2f1bdb
Author | SHA1 | Date |
---|---|---|
youHong.ai | 09ea2f1bdb | |
youHong.ai | 5216cfecd1 |
12
pom.xml
12
pom.xml
|
@ -64,7 +64,18 @@
|
||||||
<artifactId>junit</artifactId>
|
<artifactId>junit</artifactId>
|
||||||
<version>4.12</version>
|
<version>4.12</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<!-- -->
|
||||||
|
<!-- <dependency>-->
|
||||||
|
<!-- <groupId>eu.agno3.jcifs</groupId>-->
|
||||||
|
<!-- <artifactId>jcifs-ng</artifactId>-->
|
||||||
|
<!-- <version>2.1.9</version>-->
|
||||||
|
<!-- </dependency>-->
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.hierynomus</groupId>
|
||||||
|
<artifactId>smbj</artifactId>
|
||||||
|
<version>0.10.0</version>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<!-- easy excel -->
|
<!-- easy excel -->
|
||||||
<dependency>
|
<dependency>
|
||||||
|
@ -87,7 +98,6 @@
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<repositories>
|
<repositories>
|
||||||
|
|
|
@ -17,5 +17,5 @@ public class DocImageInfo {
|
||||||
private Integer id;
|
private Integer id;
|
||||||
private Integer detailId;
|
private Integer detailId;
|
||||||
private Integer fileSize;
|
private Integer fileSize;
|
||||||
|
private Integer docFileType;
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,7 @@ package aiyh.utils.httpUtil;
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.alibaba.fastjson.JSONArray;
|
import com.alibaba.fastjson.JSONArray;
|
||||||
|
import com.alibaba.fastjson.JSONException;
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
import com.fasterxml.jackson.core.type.TypeReference;
|
import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
|
@ -133,7 +134,11 @@ public class ResponeVo implements HttpResponse {
|
||||||
ObjectMapper mapper = new ObjectMapper();
|
ObjectMapper mapper = new ObjectMapper();
|
||||||
this.entityMap = mapper.readValue(this.getEntityString(), Map.class);
|
this.entityMap = mapper.readValue(this.getEntityString(), Map.class);
|
||||||
} catch (JsonProcessingException ignored) {
|
} catch (JsonProcessingException ignored) {
|
||||||
|
try {
|
||||||
this.resultList = (List<Map>) JSONArray.parseArray(this.getEntityString(), Map.class);
|
this.resultList = (List<Map>) JSONArray.parseArray(this.getEntityString(), Map.class);
|
||||||
|
} catch (JSONException e) {
|
||||||
|
Util.getLogger().error("Unable to convert the response result to array!" + Util.getErrString(e));
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Util.getLogger().error("Unable to convert the response result to map or array!" + Util.getErrString(e));
|
Util.getLogger().error("Unable to convert the response result to map or array!" + Util.getErrString(e));
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,13 +4,15 @@ import aiyh.utils.Util;
|
||||||
import aiyh.utils.httpUtil.*;
|
import aiyh.utils.httpUtil.*;
|
||||||
import aiyh.utils.httpUtil.httpAsync.HttpAsyncThread;
|
import aiyh.utils.httpUtil.httpAsync.HttpAsyncThread;
|
||||||
import aiyh.utils.httpUtil.httpAsync.HttpAsyncThreadCallBack;
|
import aiyh.utils.httpUtil.httpAsync.HttpAsyncThreadCallBack;
|
||||||
import aiyh.utils.zwl.common.ToolUtil;
|
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.alibaba.fastjson.JSONObject;
|
import com.alibaba.fastjson.JSONObject;
|
||||||
import com.alibaba.fastjson.serializer.SerializerFeature;
|
import com.alibaba.fastjson.serializer.SerializerFeature;
|
||||||
import com.alibaba.fastjson.support.spring.PropertyPreFilters;
|
import com.alibaba.fastjson.support.spring.PropertyPreFilters;
|
||||||
import com.google.common.base.Strings;
|
import com.google.common.base.Strings;
|
||||||
import com.google.common.util.concurrent.ThreadFactoryBuilder;
|
import com.google.common.util.concurrent.ThreadFactoryBuilder;
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import lombok.ToString;
|
||||||
import org.apache.http.HttpEntity;
|
import org.apache.http.HttpEntity;
|
||||||
import org.apache.http.NameValuePair;
|
import org.apache.http.NameValuePair;
|
||||||
import org.apache.http.client.CredentialsProvider;
|
import org.apache.http.client.CredentialsProvider;
|
||||||
|
@ -41,32 +43,26 @@ import java.util.function.Function;
|
||||||
* @author EBU7-dev1-ayh
|
* @author EBU7-dev1-ayh
|
||||||
* @date 2021/8/31 0031 17:16 http请求工具 与HttpStaticUtils使用相同,说明请查看HttpStaticUtils
|
* @date 2021/8/31 0031 17:16 http请求工具 与HttpStaticUtils使用相同,说明请查看HttpStaticUtils
|
||||||
*/
|
*/
|
||||||
|
@ToString
|
||||||
|
|
||||||
public class HttpUtils {
|
public class HttpUtils {
|
||||||
public static final String JSON_PARAM_KEY = "JSON_PARAM_KEY";
|
public static final String JSON_PARAM_KEY = "JSON_PARAM_KEY";
|
||||||
public static final ThreadLocal<HttpUtilParamInfo> HTTP_UTIL_PARAM_INFO_THREAD_LOCAL = new ThreadLocal<>();
|
public static final ThreadLocal<HttpUtilParamInfo> HTTP_UTIL_PARAM_INFO_THREAD_LOCAL = new ThreadLocal<>();
|
||||||
private static final Logger log = Util.getLogger("http_util");
|
private static final Logger log = Util.getLogger("http_util");
|
||||||
private final ToolUtil toolUtil = new ToolUtil();
|
@Getter
|
||||||
private final GlobalCache globalCache = new GlobalCache();
|
private final GlobalCache globalCache = new GlobalCache();
|
||||||
// 线程池
|
// 线程池
|
||||||
private final ThreadPoolExecutor executorService;
|
private final ThreadPoolExecutor executorService;
|
||||||
private final PropertyPreFilters filters = new PropertyPreFilters();
|
private final PropertyPreFilters filters = new PropertyPreFilters();
|
||||||
private final PropertyPreFilters.MySimplePropertyPreFilter excludefilter = filters.addFilter();
|
private final PropertyPreFilters.MySimplePropertyPreFilter excludefilter = filters.addFilter();
|
||||||
// 默认编码
|
// 默认编码
|
||||||
|
@Setter
|
||||||
private String DEFAULT_ENCODING = "UTF-8";
|
private String DEFAULT_ENCODING = "UTF-8";
|
||||||
|
@Setter
|
||||||
private String sslKeyPath = "";
|
private String sslKeyPath = "";
|
||||||
|
@Setter
|
||||||
private String password = "";
|
private String password = "";
|
||||||
|
|
||||||
public void setSslKeyPath(String sslKeyPath) {
|
|
||||||
this.sslKeyPath = sslKeyPath;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public void setPassword(String password) {
|
|
||||||
this.password = password;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* basic 认证
|
* basic 认证
|
||||||
|
@ -148,17 +144,6 @@ public class HttpUtils {
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setCredentialsProvider(CredentialsProvider credentialsProvider) {
|
|
||||||
this.credentialsProvider = credentialsProvider;
|
|
||||||
}
|
|
||||||
|
|
||||||
public GlobalCache getGlobalCache() {
|
|
||||||
return globalCache;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setDEFAULT_ENCODING() {
|
|
||||||
this.DEFAULT_ENCODING = DEFAULT_ENCODING;
|
|
||||||
}
|
|
||||||
|
|
||||||
public HttpPost getHttpPost(String url) {
|
public HttpPost getHttpPost(String url) {
|
||||||
HttpPost httpPost = new HttpPost(url);
|
HttpPost httpPost = new HttpPost(url);
|
||||||
|
@ -651,9 +636,15 @@ public class HttpUtils {
|
||||||
CloseableHttpResponse response = null;
|
CloseableHttpResponse response = null;
|
||||||
try {
|
try {
|
||||||
response = httpClient.execute(request);
|
response = httpClient.execute(request);
|
||||||
|
} catch (Exception e) {
|
||||||
|
log.error(" http调用失败:" + Util.getErrString(e));
|
||||||
|
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
|
||||||
|
ExtendedIOUtils.closeQuietly(httpClient);
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
try {
|
||||||
consumer.accept(response);
|
consumer.accept(response);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
toolUtil.writeErrorLog(" http调用失败:" + e);
|
|
||||||
throw e;
|
throw e;
|
||||||
} finally {
|
} finally {
|
||||||
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
|
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
|
||||||
|
@ -667,9 +658,15 @@ public class HttpUtils {
|
||||||
ResponeVo apply = null;
|
ResponeVo apply = null;
|
||||||
try {
|
try {
|
||||||
response = httpClient.execute(request);
|
response = httpClient.execute(request);
|
||||||
|
} catch (Exception e) {
|
||||||
|
log.error(" http调用失败:" + Util.getErrString(e));
|
||||||
|
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
|
||||||
|
ExtendedIOUtils.closeQuietly(httpClient);
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
try {
|
||||||
apply = consumer.apply(response);
|
apply = consumer.apply(response);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
toolUtil.writeErrorLog(" http调用失败:" + e);
|
|
||||||
throw e;
|
throw e;
|
||||||
} finally {
|
} finally {
|
||||||
HttpUtilParamInfo httpUtilParamInfo = HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.get();
|
HttpUtilParamInfo httpUtilParamInfo = HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.get();
|
||||||
|
@ -677,11 +674,13 @@ public class HttpUtils {
|
||||||
httpUtilParamInfo = new HttpUtilParamInfo();
|
httpUtilParamInfo = new HttpUtilParamInfo();
|
||||||
}
|
}
|
||||||
httpUtilParamInfo.setResponse(apply);
|
httpUtilParamInfo.setResponse(apply);
|
||||||
|
if (apply != null) {
|
||||||
if (apply.getResponseMap() == null) {
|
if (apply.getResponseMap() == null) {
|
||||||
httpUtilParamInfo.setResponseString(apply.getEntityString());
|
httpUtilParamInfo.setResponseString(apply.getEntityString());
|
||||||
} else {
|
} else {
|
||||||
httpUtilParamInfo.setResponseMap(apply.getResponseMap());
|
httpUtilParamInfo.setResponseMap(apply.getResponseMap());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
httpUtilParamInfo.setResponseDate(new Date());
|
httpUtilParamInfo.setResponseDate(new Date());
|
||||||
try {
|
try {
|
||||||
log.info(Util.logStr("url [{}] request info : [\n{}\n];", httpUtilParamInfo.getUrl(),
|
log.info(Util.logStr("url [{}] request info : [\n{}\n];", httpUtilParamInfo.getUrl(),
|
||||||
|
@ -704,9 +703,16 @@ public class HttpUtils {
|
||||||
ResponeVo apply = null;
|
ResponeVo apply = null;
|
||||||
try {
|
try {
|
||||||
response = httpClient.execute(request);
|
response = httpClient.execute(request);
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
|
||||||
|
log.error(" http调用失败:" + Util.getErrString(e));
|
||||||
|
ExtendedIOUtils.closeQuietly(httpClient);
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
try {
|
||||||
apply = consumer.apply(requestParam, response);
|
apply = consumer.apply(requestParam, response);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
toolUtil.writeErrorLog(" http调用失败:" + e);
|
|
||||||
throw e;
|
throw e;
|
||||||
} finally {
|
} finally {
|
||||||
HttpUtilParamInfo httpUtilParamInfo = HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.get();
|
HttpUtilParamInfo httpUtilParamInfo = HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.get();
|
||||||
|
@ -714,11 +720,13 @@ public class HttpUtils {
|
||||||
httpUtilParamInfo = new HttpUtilParamInfo();
|
httpUtilParamInfo = new HttpUtilParamInfo();
|
||||||
}
|
}
|
||||||
httpUtilParamInfo.setResponse(apply);
|
httpUtilParamInfo.setResponse(apply);
|
||||||
|
if (apply != null) {
|
||||||
if (apply.getResponseMap() == null) {
|
if (apply.getResponseMap() == null) {
|
||||||
httpUtilParamInfo.setResponseString(apply.getEntityString());
|
httpUtilParamInfo.setResponseString(apply.getEntityString());
|
||||||
} else {
|
} else {
|
||||||
httpUtilParamInfo.setResponseMap(apply.getResponseMap());
|
httpUtilParamInfo.setResponseMap(apply.getResponseMap());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
httpUtilParamInfo.setResponseDate(new Date());
|
httpUtilParamInfo.setResponseDate(new Date());
|
||||||
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
|
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
|
||||||
try {
|
try {
|
||||||
|
@ -769,7 +777,7 @@ public class HttpUtils {
|
||||||
|
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
toolUtil.writeErrorLog(" http调用失败:" + Util.getErrString(e));
|
log.error(" http调用失败:" + Util.getErrString(e));
|
||||||
try {
|
try {
|
||||||
httpUtilParamInfo.setResponseDate(new Date());
|
httpUtilParamInfo.setResponseDate(new Date());
|
||||||
log.info(Util.logStr("url [{}] request info : [\n{}\n];", httpUtilParamInfo.getUrl(),
|
log.info(Util.logStr("url [{}] request info : [\n{}\n];", httpUtilParamInfo.getUrl(),
|
||||||
|
@ -1263,7 +1271,7 @@ public class HttpUtils {
|
||||||
total.append(line);
|
total.append(line);
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
toolUtil.writeErrorLog(e.getLocalizedMessage() + "\n" + e);
|
log.error(e.getLocalizedMessage() + "\n" + e);
|
||||||
}
|
}
|
||||||
return total.toString();
|
return total.toString();
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,10 +61,14 @@ public interface UtilMapper {
|
||||||
@Select("select id,docid doc_id,imagefileid image_file_id,imagefilename image_file_name from docimagefile where docid = #{docId}")
|
@Select("select id,docid doc_id,imagefileid image_file_id,imagefilename image_file_name from docimagefile where docid = #{docId}")
|
||||||
DocImageInfo selectDocImageInfo(@ParamMapper("docId") String docId);
|
DocImageInfo selectDocImageInfo(@ParamMapper("docId") String docId);
|
||||||
|
|
||||||
@Select("select id,docid doc_id,imagefileid image_file_id,imagefilename image_file_name from docimagefile where docid in ($t{docIds})")
|
@Select("select id,docid doc_id," +
|
||||||
|
"imagefileid image_file_id, docfiletype doc_file_type," +
|
||||||
|
"imagefilename image_file_name from docimagefile where docid in ($t{docIds})")
|
||||||
List<DocImageInfo> selectDocImageInfos(@ParamMapper("docIds") String docIds);
|
List<DocImageInfo> selectDocImageInfos(@ParamMapper("docIds") String docIds);
|
||||||
|
|
||||||
@Select("select id,docid doc_id,imagefileid image_file_id,imagefilename image_file_name from docimagefile where docid in (${docIds})")
|
@Select("select id,docid doc_id,imagefileid image_file_id," +
|
||||||
|
"docfiletype doc_file_type," +
|
||||||
|
"imagefilename image_file_name from docimagefile where docid in (${docIds})")
|
||||||
List<DocImageInfo> selectDocImageInfos(@ParamMapper("docIds") String[] docIds);
|
List<DocImageInfo> selectDocImageInfos(@ParamMapper("docIds") String[] docIds);
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,7 @@ import aiyh.utils.Util;
|
||||||
import aiyh.utils.action.SafeCusBaseAction;
|
import aiyh.utils.action.SafeCusBaseAction;
|
||||||
import aiyh.utils.annotation.*;
|
import aiyh.utils.annotation.*;
|
||||||
import aiyh.utils.excention.CustomerException;
|
import aiyh.utils.excention.CustomerException;
|
||||||
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.google.common.base.Strings;
|
import com.google.common.base.Strings;
|
||||||
import ebu7common.youhong.ai.bean.Builder;
|
import ebu7common.youhong.ai.bean.Builder;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
|
@ -12,6 +13,7 @@ import lombok.ToString;
|
||||||
import weaver.hrm.User;
|
import weaver.hrm.User;
|
||||||
import weaver.soa.workflow.request.RequestInfo;
|
import weaver.soa.workflow.request.RequestInfo;
|
||||||
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.dto.UpdateDetailRowDto;
|
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.dto.UpdateDetailRowDto;
|
||||||
|
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.entity.ConditionsSetValueConfigMain;
|
||||||
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.service.WorkflowConditionsSetValueService;
|
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.service.WorkflowConditionsSetValueService;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
@ -31,7 +33,7 @@ public class WorkflowConditionsSetValueAction extends SafeCusBaseAction {
|
||||||
|
|
||||||
@RequiredMark("流程条件赋值配置表唯一标识字段值")
|
@RequiredMark("流程条件赋值配置表唯一标识字段值")
|
||||||
@PrintParamMark
|
@PrintParamMark
|
||||||
@ActionDefaultTestValue("test")
|
@ActionDefaultTestValue("getdata")
|
||||||
private String onlyMark;
|
private String onlyMark;
|
||||||
|
|
||||||
@ActionOptionalParam(desc = "条件修改所在明细表,1-明细1,2-明细2", value = "")
|
@ActionOptionalParam(desc = "条件修改所在明细表,1-明细1,2-明细2", value = "")
|
||||||
|
@ -54,14 +56,15 @@ public class WorkflowConditionsSetValueAction extends SafeCusBaseAction {
|
||||||
try {
|
try {
|
||||||
Map<String, Object> workflowData = new HashMap<>(16);
|
Map<String, Object> workflowData = new HashMap<>(16);
|
||||||
Map<String, Object> workflowMainData = super.getObjMainTableValue(requestInfo);
|
Map<String, Object> workflowMainData = super.getObjMainTableValue(requestInfo);
|
||||||
|
ConditionsSetValueConfigMain conditionsSetValueConfigMain = service.getConditionConfigMain(onlyMark);
|
||||||
if (Strings.isNullOrEmpty(detailNo)) {
|
if (Strings.isNullOrEmpty(detailNo)) {
|
||||||
/* ******************* 数据修改主表 ******************* */
|
/* ******************* 数据修改主表 ******************* */
|
||||||
Map<String, Object> conditionsValue = service.getConditionsValue(onlyMark, workflowData).get(billTable);
|
Map<String, Object> conditionsValue = service.getConditionsValue(conditionsSetValueConfigMain, workflowData).get(billTable);
|
||||||
service.updateWorkflowData(conditionsValue, billTable, requestId);
|
service.updateWorkflowData(conditionsValue, billTable, requestId);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* ******************* 明细表 ******************* */
|
/* ******************* 明细表 ******************* */
|
||||||
List<Map<String, Object>> detailData = super.getDetailTableObjValueByDetailNo(Integer.parseInt(detailNo), requestInfo);
|
List<Map<String, Object>> detailData = super.getDetailTableObjValueByDetailNo(Integer.parseInt(detailNo) - 1, requestInfo);
|
||||||
workflowData.put("main", workflowMainData);
|
workflowData.put("main", workflowMainData);
|
||||||
workflowData.put("_user_", user);
|
workflowData.put("_user_", user);
|
||||||
workflowData.put("_workflowId_", workflowId);
|
workflowData.put("_workflowId_", workflowId);
|
||||||
|
@ -71,7 +74,7 @@ public class WorkflowConditionsSetValueAction extends SafeCusBaseAction {
|
||||||
List<UpdateDetailRowDto> detail = new ArrayList<>();
|
List<UpdateDetailRowDto> detail = new ArrayList<>();
|
||||||
for (Map<String, Object> detailDatum : detailData) {
|
for (Map<String, Object> detailDatum : detailData) {
|
||||||
workflowData.put("detail_" + detailNo, detailDatum);
|
workflowData.put("detail_" + detailNo, detailDatum);
|
||||||
Map<String, Map<String, Object>> conditionsValues = service.getConditionsValue(onlyMark, workflowData);
|
Map<String, Map<String, Object>> conditionsValues = service.getConditionsValue(conditionsSetValueConfigMain, workflowData);
|
||||||
Map<String, Object> mainConditions = conditionsValues.get(billTable);
|
Map<String, Object> mainConditions = conditionsValues.get(billTable);
|
||||||
if (!Objects.isNull(mainConditions) && !mainConditions.isEmpty()) {
|
if (!Objects.isNull(mainConditions) && !mainConditions.isEmpty()) {
|
||||||
main.add(Builder.builder(UpdateDetailRowDto::new)
|
main.add(Builder.builder(UpdateDetailRowDto::new)
|
||||||
|
@ -89,6 +92,8 @@ public class WorkflowConditionsSetValueAction extends SafeCusBaseAction {
|
||||||
.build());
|
.build());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
log.info("条件值: " + JSON.toJSONString(main));
|
||||||
|
log.info("条件值: " + JSON.toJSONString(detail));
|
||||||
service.updateWorkflowDetailData(main, billTable, null);
|
service.updateWorkflowDetailData(main, billTable, null);
|
||||||
service.updateWorkflowDetailData(detail, billTable + "_dt" + detailNo, detailNo);
|
service.updateWorkflowDetailData(detail, billTable + "_dt" + detailNo, detailNo);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
@ -101,6 +106,8 @@ public class WorkflowConditionsSetValueAction extends SafeCusBaseAction {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void submitWorkflow(String requestId, Integer userId) {
|
public void submitWorkflow(String requestId, Integer userId) {
|
||||||
Util.submitWorkflowThread(Integer.parseInt(requestId), userId, "邮件发送附件提交流程!");
|
if (Boolean.parseBoolean(submitAction)) {
|
||||||
|
Util.submitWorkflowThread(Integer.parseInt(requestId), userId, "流程条件赋值提交流程!");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package weaver.youhong.ai.pcn.actioin.conditionssetvalue.service;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import aiyh.utils.tool.Assert;
|
import aiyh.utils.tool.Assert;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.dto.ConditionValueDto;
|
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.dto.ConditionValueDto;
|
||||||
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.dto.UpdateDetailRowDto;
|
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.dto.UpdateDetailRowDto;
|
||||||
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.entity.ConditionItem;
|
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.entity.ConditionItem;
|
||||||
|
@ -28,17 +29,13 @@ public class WorkflowConditionsSetValueService {
|
||||||
/**
|
/**
|
||||||
* <h2>获取条件赋值映射规则处理后的字段值</h2>
|
* <h2>获取条件赋值映射规则处理后的字段值</h2>
|
||||||
*
|
*
|
||||||
* @param onlyMark 配置表唯一标识
|
* @param conditionsSetValueConfigMain 配置表信息
|
||||||
* @param workflowData 流程表数据
|
* @param workflowData 流程表数据
|
||||||
* @return 映射结果
|
* @return 映射结果
|
||||||
*/
|
*/
|
||||||
public Map<String, Map<String, Object>> getConditionsValue(String onlyMark, Map<String, Object> workflowData) {
|
public Map<String, Map<String, Object>> getConditionsValue(ConditionsSetValueConfigMain conditionsSetValueConfigMain, Map<String, Object> workflowData) {
|
||||||
|
|
||||||
/* ******************* 查询配置表 ******************* */
|
|
||||||
ConditionsSetValueConfigMain conditionsSetValueConfigMain = mapper.selectConfigByOnlyMark(onlyMark);
|
|
||||||
Assert.notNull(conditionsSetValueConfigMain, "can not query configuration by onlyMark [{}]", onlyMark);
|
|
||||||
List<ConditionItem> conditionItemList = conditionsSetValueConfigMain.getConditionItemList();
|
List<ConditionItem> conditionItemList = conditionsSetValueConfigMain.getConditionItemList();
|
||||||
Assert.notEmpty(conditionItemList, "can not query conditionItemList by onlyMark [{}]", onlyMark);
|
|
||||||
/* ******************* 映射规则处理 ,责任链初始化 ******************* */
|
/* ******************* 映射规则处理 ,责任链初始化 ******************* */
|
||||||
ConditionsTypeTreatment conditionsTypeTreatment = new ConditionsTypeTreatment(
|
ConditionsTypeTreatment conditionsTypeTreatment = new ConditionsTypeTreatment(
|
||||||
new ConditionsTreatment(
|
new ConditionsTreatment(
|
||||||
|
@ -68,6 +65,16 @@ public class WorkflowConditionsSetValueService {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
public ConditionsSetValueConfigMain getConditionConfigMain(String onlyMark) {
|
||||||
|
/* ******************* 查询配置表 ******************* */
|
||||||
|
ConditionsSetValueConfigMain conditionsSetValueConfigMain = mapper.selectConfigByOnlyMark(onlyMark);
|
||||||
|
Assert.notNull(conditionsSetValueConfigMain, "can not query configuration by onlyMark [{}]", onlyMark);
|
||||||
|
List<ConditionItem> conditionItemList = conditionsSetValueConfigMain.getConditionItemList();
|
||||||
|
Assert.notEmpty(conditionItemList, "can not query conditionItemList by onlyMark [{}]", onlyMark);
|
||||||
|
return conditionsSetValueConfigMain;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h2>更新明细表数据</h2>
|
* <h2>更新明细表数据</h2>
|
||||||
*
|
*
|
||||||
|
@ -94,6 +101,9 @@ public class WorkflowConditionsSetValueService {
|
||||||
StringBuilder sb = new StringBuilder("update ");
|
StringBuilder sb = new StringBuilder("update ");
|
||||||
sb.append(billTable).append(" set ");
|
sb.append(billTable).append(" set ");
|
||||||
for (Map.Entry<String, Object> entry : updateBatchData.get(0).entrySet()) {
|
for (Map.Entry<String, Object> entry : updateBatchData.get(0).entrySet()) {
|
||||||
|
if (entry.getKey().equals("_id_")) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
sb.append(entry.getKey())
|
sb.append(entry.getKey())
|
||||||
.append(" = #{item.")
|
.append(" = #{item.")
|
||||||
.append(entry.getKey())
|
.append(entry.getKey())
|
||||||
|
|
|
@ -51,6 +51,7 @@ public class ValueSetRulesTreatment {
|
||||||
return Builder.builder(ConditionValueDto::new)
|
return Builder.builder(ConditionValueDto::new)
|
||||||
.with(ConditionValueDto::setFieldName, conditionItem.getTargetField().getFieldName())
|
.with(ConditionValueDto::setFieldName, conditionItem.getTargetField().getFieldName())
|
||||||
.with(ConditionValueDto::setValue, value)
|
.with(ConditionValueDto::setValue, value)
|
||||||
|
.with(ConditionValueDto::setTableName, conditionItem.getTargetField().getTableName())
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,100 @@
|
||||||
|
package weaver.youhong.ai.pcn.actioin.docfieltoattachment;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.action.SafeCusBaseAction;
|
||||||
|
import aiyh.utils.annotation.ActionDesc;
|
||||||
|
import aiyh.utils.annotation.ActionOptionalParam;
|
||||||
|
import aiyh.utils.annotation.PrintParamMark;
|
||||||
|
import aiyh.utils.annotation.RequiredMark;
|
||||||
|
import aiyh.utils.entity.DocImageInfo;
|
||||||
|
import aiyh.utils.excention.CustomerException;
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import lombok.ToString;
|
||||||
|
import weaver.file.ImageFileManager;
|
||||||
|
import weaver.hrm.User;
|
||||||
|
import weaver.soa.workflow.request.RequestInfo;
|
||||||
|
import weaver.youhong.ai.pcn.actioin.docfieltoattachment.mapper.CopyDocFileToAttachmentMapper;
|
||||||
|
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>文档字段中附件复制到附件字段中</h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/21 18:40</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
@ToString
|
||||||
|
@ActionDesc(value = "文档字段中附件复制到附件字段中", author = "youhong.ai")
|
||||||
|
public class CopyDocFileToAttachmentAction extends SafeCusBaseAction {
|
||||||
|
@PrintParamMark
|
||||||
|
@ActionOptionalParam(value = "true", desc = "是否失败后阻断流程")
|
||||||
|
private String block = "true";
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("字段映射配置字段: 文档字段:附件字段;文档字段:附件字段")
|
||||||
|
private String fieldMappings;
|
||||||
|
|
||||||
|
private final CopyDocFileToAttachmentMapper mapper = Util.getMapper(CopyDocFileToAttachmentMapper.class);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestInfo requestInfo) {
|
||||||
|
try {
|
||||||
|
String[] fieldMappingArr = fieldMappings.split(";");
|
||||||
|
Map<String, String> mainTableValue = super.getMainTableValue(requestInfo);
|
||||||
|
Map<String, Object> sqlValue = new HashMap<>();
|
||||||
|
for (String fieldMapping : fieldMappingArr) {
|
||||||
|
copyFile(fieldMapping, mainTableValue, sqlValue, String.valueOf(workflowId), billTable, user.getUID());
|
||||||
|
}
|
||||||
|
StringBuilder sb = new StringBuilder("update ");
|
||||||
|
sb.append(billTable).append(" set ");
|
||||||
|
for (Map.Entry<String, Object> entry : sqlValue.entrySet()) {
|
||||||
|
sb.append(entry.getKey()).append(" = ").append("#{").append(entry.getKey()).append("},");
|
||||||
|
}
|
||||||
|
sb.deleteCharAt(sb.length() - 1);
|
||||||
|
sb.append(" where requestid = ").append(requestId);
|
||||||
|
if (mapper.updateDocIds(sb.toString(), sqlValue)) {
|
||||||
|
Thread.sleep(500);
|
||||||
|
mapper.updateDocIds(sb.toString(), sqlValue);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
if (Boolean.parseBoolean(block)) {
|
||||||
|
throw new CustomerException(e.getMessage(), e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void copyFile(String fieldMapping, Map<String, String> mainTableValue,
|
||||||
|
Map<String, Object> sqlValue, String workflowId,
|
||||||
|
String billTable, int userId) {
|
||||||
|
List<Integer> docIds = new ArrayList<>();
|
||||||
|
String[] split = fieldMapping.split(":");
|
||||||
|
String docField = split[0];
|
||||||
|
String fileField = split[1];
|
||||||
|
String docId = mainTableValue.get(docField);
|
||||||
|
List<DocImageInfo> docImageInfos = Util.selectImageInfoByDocIds(docId);
|
||||||
|
for (DocImageInfo docImageInfo : docImageInfos) {
|
||||||
|
if (docImageInfo.getDocFileType() != 2) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
InputStream inputStreamById = ImageFileManager.getInputStreamById(docImageInfo.getImageFileId());
|
||||||
|
String docCategorysByTable = Util.getDocCategorysByTable(workflowId, fileField, billTable);
|
||||||
|
String[] categoryArr = docCategorysByTable.split(",");
|
||||||
|
String category = categoryArr[categoryArr.length - 1];
|
||||||
|
try {
|
||||||
|
int doc = Util.createDoc(docImageInfo.getImageFileName(), Integer.parseInt(category), inputStreamById, userId);
|
||||||
|
docIds.add(doc);
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
sqlValue.put(fileField, Util.intJoin(docIds, ","));
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,22 @@
|
||||||
|
package weaver.youhong.ai.pcn.actioin.docfieltoattachment.mapper;
|
||||||
|
|
||||||
|
import aiyh.utils.annotation.recordset.SqlMapper;
|
||||||
|
import aiyh.utils.annotation.recordset.SqlString;
|
||||||
|
import aiyh.utils.annotation.recordset.Update;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/21 19:13</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@SqlMapper
|
||||||
|
public interface CopyDocFileToAttachmentMapper {
|
||||||
|
|
||||||
|
@Update(custom = true)
|
||||||
|
boolean updateDocIds(@SqlString String sql,
|
||||||
|
Map<String, Object> map);
|
||||||
|
}
|
|
@ -0,0 +1,94 @@
|
||||||
|
package weaver.youhong.ai.pcn.actioin.generateloginid;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.action.SafeCusBaseAction;
|
||||||
|
import aiyh.utils.annotation.ActionDesc;
|
||||||
|
import aiyh.utils.annotation.ActionOptionalParam;
|
||||||
|
import aiyh.utils.annotation.PrintParamMark;
|
||||||
|
import aiyh.utils.annotation.RequiredMark;
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import lombok.ToString;
|
||||||
|
import weaver.hrm.User;
|
||||||
|
import weaver.soa.workflow.request.RequestInfo;
|
||||||
|
import weaver.youhong.ai.pcn.actioin.generateloginid.mapper.GenerateLoginIdMapper;
|
||||||
|
|
||||||
|
import java.text.NumberFormat;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>生成loginid</h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/21 19:46</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
@ToString
|
||||||
|
@ActionDesc(value = "根据分部生成对应的登录名", author = "youhong.ai")
|
||||||
|
public class GenerateLoginIdAction extends SafeCusBaseAction {
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("流程回写登录名字段名")
|
||||||
|
private String loginIdField;
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("分部简称流程字段名")
|
||||||
|
private String subCompanyTextField;
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@ActionOptionalParam(value = "4", desc = "登录名序列数字位长度,序列不足时前缀补0,如0001,默认长度4位")
|
||||||
|
private String numberFillQuantity = "4";
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@ActionOptionalParam(value = "true", desc = "是否失败后阻断流程")
|
||||||
|
private String block = "true";
|
||||||
|
|
||||||
|
private final GenerateLoginIdMapper mapper = Util.getMapper(GenerateLoginIdMapper.class);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestInfo requestInfo) {
|
||||||
|
try {
|
||||||
|
Map<String, String> mainTableValue = super.getMainTableValue(requestInfo);
|
||||||
|
String subCompanyName = mainTableValue.get(subCompanyTextField);
|
||||||
|
String subCompanyId = mapper.selectSubCompanyIdBySubCompanyName(subCompanyName);
|
||||||
|
Map<String, String> lastLoginIdInfo = mapper.selectLastLoginId(subCompanyName, subCompanyId, subCompanyName + "%");
|
||||||
|
String loginIdNo = lastLoginIdInfo.get("loginIdNo");
|
||||||
|
String loginId = prefixFill(loginIdNo, subCompanyName);
|
||||||
|
if (mapper.updateLoginId(billTable, requestId, loginId, loginIdField)) {
|
||||||
|
try {
|
||||||
|
Thread.sleep(500);
|
||||||
|
} catch (Exception ignore) {
|
||||||
|
}
|
||||||
|
mapper.updateLoginId(billTable, requestId, loginId, loginIdField);
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
if (Boolean.parseBoolean(block)) {
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>前缀补齐</h2>
|
||||||
|
*
|
||||||
|
* @param lastLoginIdNo 最后登录名编号
|
||||||
|
* @param prefix 前缀
|
||||||
|
* @return 登录名
|
||||||
|
*/
|
||||||
|
private String prefixFill(String lastLoginIdNo, String prefix) {
|
||||||
|
NumberFormat numberFormat = NumberFormat.getInstance();
|
||||||
|
// 禁用数字格式化分组。
|
||||||
|
numberFormat.setGroupingUsed(false);
|
||||||
|
// 保留最小位数
|
||||||
|
numberFormat.setMinimumIntegerDigits(Integer.parseInt(numberFillQuantity));
|
||||||
|
// 保留最大位数
|
||||||
|
numberFormat.setMaximumIntegerDigits(Integer.parseInt(numberFillQuantity));
|
||||||
|
int newLoginId = Integer.parseInt(lastLoginIdNo) + 1;
|
||||||
|
return prefix + numberFormat.format(newLoginId);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,64 @@
|
||||||
|
package weaver.youhong.ai.pcn.actioin.generateloginid.mapper;
|
||||||
|
|
||||||
|
import aiyh.utils.annotation.recordset.ParamMapper;
|
||||||
|
import aiyh.utils.annotation.recordset.Select;
|
||||||
|
import aiyh.utils.annotation.recordset.SqlMapper;
|
||||||
|
import aiyh.utils.annotation.recordset.Update;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/2/21 20:31</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@SqlMapper
|
||||||
|
public interface GenerateLoginIdMapper {
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>通过分部简称查询分部id</h2>
|
||||||
|
*
|
||||||
|
* @param subCompanyName 分部简称
|
||||||
|
* @return 分部id
|
||||||
|
*/
|
||||||
|
@Select("select id from hrmsubcompany where SUBCOMPANYNAME = #{subCompanyName}")
|
||||||
|
String selectSubCompanyIdBySubCompanyName(String subCompanyName);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>查询当前分部的人员的登录名的最后一个编号</h2>
|
||||||
|
*
|
||||||
|
* @param loginIdPrefix 登录名前缀
|
||||||
|
* @param subCompanyId 分部id
|
||||||
|
* @param loginLike 登录名前缀+%
|
||||||
|
* @return 当前分部人员id和登录名编号
|
||||||
|
*/
|
||||||
|
@Select("select id,substring(LOGINID,length(#{loginIdPrefix}) + 1) login_id_no \n" +
|
||||||
|
"from hrmresource \n" +
|
||||||
|
"where SUBCOMPANYID1 = #{subCompanyId} and LOGINID like #{loginLike} \n" +
|
||||||
|
" order by cast(substring(LOGINID,length(#{loginIdPrefix}) + 1) as decimal) \n" +
|
||||||
|
" desc limit 1")
|
||||||
|
Map<String, String> selectLastLoginId(
|
||||||
|
@ParamMapper("loginIdPrefix") String loginIdPrefix,
|
||||||
|
@ParamMapper("subCompanyId") String subCompanyId,
|
||||||
|
@ParamMapper("loginLike") String loginLike
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>更新流程中的loginId字段</h2>
|
||||||
|
*
|
||||||
|
* @param billTable 流程表
|
||||||
|
* @param requestId 请求id
|
||||||
|
* @param loginId 登录id
|
||||||
|
* @param loginIdField 登录id所属字段
|
||||||
|
* @return 是否更新成功
|
||||||
|
*/
|
||||||
|
@Update("update $t{billTable} set $t{loginIdField} where requestid = #{requestId}")
|
||||||
|
boolean updateLoginId(@ParamMapper("billTable") String billTable,
|
||||||
|
@ParamMapper("requestId") String requestId,
|
||||||
|
@ParamMapper("loginId") String loginId,
|
||||||
|
@ParamMapper("loginIdField") String loginIdField);
|
||||||
|
}
|
|
@ -20,4 +20,10 @@ public class TestHaRiPiJiu extends BaseTest {
|
||||||
GenerateFileUtil.createActionDocument(VoucherPayableAction.class);
|
GenerateFileUtil.createActionDocument(VoucherPayableAction.class);
|
||||||
GenerateFileUtil.createActionDocument(ReceiptAndPaymentAction.class);
|
GenerateFileUtil.createActionDocument(ReceiptAndPaymentAction.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void test1() {
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,7 @@ import com.engine.hrm.service.impl.RolesMembersServiceImpl;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import weaver.hrm.User;
|
import weaver.hrm.User;
|
||||||
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.WorkflowConditionsSetValueAction;
|
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.WorkflowConditionsSetValueAction;
|
||||||
|
import weaver.youhong.ai.pcn.actioin.generateloginid.GenerateLoginIdAction;
|
||||||
import weaver.youhong.ai.pcn.schedule.addrolebyhasundering.RegisterRoleMemberByHasUnderingCronJob;
|
import weaver.youhong.ai.pcn.schedule.addrolebyhasundering.RegisterRoleMemberByHasUnderingCronJob;
|
||||||
import weaver.youhong.ai.pcn.schedule.addrolemember.RegisterRoleMemberCronJob;
|
import weaver.youhong.ai.pcn.schedule.addrolemember.RegisterRoleMemberCronJob;
|
||||||
|
|
||||||
|
@ -75,6 +76,6 @@ public class RolesTest extends BaseTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void generateFile() {
|
public void generateFile() {
|
||||||
GenerateFileUtil.createActionDocument(WorkflowConditionsSetValueAction.class);
|
GenerateFileUtil.createActionDocument(GenerateLoginIdAction.class);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,7 +59,8 @@ select wb.id,
|
||||||
when wb.FIELDHTMLTYPE = '3' then '流览框'
|
when wb.FIELDHTMLTYPE = '3' then '流览框'
|
||||||
when wb.FIELDHTMLTYPE = '4' then 'check框'
|
when wb.FIELDHTMLTYPE = '4' then 'check框'
|
||||||
when wb.FIELDHTMLTYPE = '5' then '选择框'
|
when wb.FIELDHTMLTYPE = '5' then '选择框'
|
||||||
else '附件上传' end) fieldhtmltype
|
else '附件上传' end) fieldhtmltype,
|
||||||
|
wb.FIELDHTMLTYPE fieldtype
|
||||||
from workflow_billfield wb
|
from workflow_billfield wb
|
||||||
left join htmllabelindex ht on wb.fieldlabel = ht.id;
|
left join htmllabelindex ht on wb.fieldlabel = ht.id;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue