Compare commits
2 Commits
cdda440ef2
...
8f2c58978e
Author | SHA1 | Date |
---|---|---|
wangxuanran | 8f2c58978e | |
wangxuanran | 36ed42ce30 |
|
@ -57,7 +57,7 @@ function submitCallback(detailTable, detail2PayProportionId){
|
||||||
let rowIndex = rowArr[i];
|
let rowIndex = rowArr[i];
|
||||||
if(rowIndex !== ""){
|
if(rowIndex !== ""){
|
||||||
let field = `${detail2PayProportionId}_${rowIndex}`;
|
let field = `${detail2PayProportionId}_${rowIndex}`;
|
||||||
sum += parseFloat(WfForm.getFieldValue(field));//遍历明细行字段
|
sum = addFloat(sum, parseFloat(WfForm.getFieldValue(field)));//遍历明细行字段
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
console.log('sum => ', sum)
|
console.log('sum => ', sum)
|
||||||
|
@ -65,6 +65,11 @@ function submitCallback(detailTable, detail2PayProportionId){
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function addFloat(a, b) {
|
||||||
|
let precision = Math.pow(10, 10); // 设置精度,根据需要调整
|
||||||
|
return (Math.round(a * precision) + Math.round(b * precision)) / precision;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 明细表字段发生变化进行日期计算
|
* 明细表字段发生变化进行日期计算
|
||||||
* @param bindField
|
* @param bindField
|
||||||
|
|
|
@ -1,27 +1,27 @@
|
||||||
// 首台销售日期
|
// 首台销售日期
|
||||||
const firstSaleDateField = WfForm.convertFieldNameToId("stxsrq");
|
var firstSaleDateField = WfForm.convertFieldNameToId("stxsrq");
|
||||||
// 跟踪时间
|
// 跟踪时间
|
||||||
const trackTimeField = WfForm.convertFieldNameToId("gzsj");
|
var trackTimeField = WfForm.convertFieldNameToId("gzsj");
|
||||||
// 跟踪时间为三个月以内
|
// 跟踪时间为三个月以内
|
||||||
const threeMonthIndex = 1;
|
var threeMonthIndex = 1;
|
||||||
// 是否提交等待节点
|
// 是否提交等待节点
|
||||||
const submitWaitNode = WfForm.convertFieldNameToId("sftjddjd");
|
var submitWaitNode = WfForm.convertFieldNameToId("sftjddjd");
|
||||||
// 下次超时提醒日期
|
// 下次超时提醒日期
|
||||||
const timeoutRemindDateFiled = WfForm.convertFieldNameToId("cstxrq");
|
var timeoutRemindDateFiled = WfForm.convertFieldNameToId("cstxrq");
|
||||||
// 跟踪天数 <= 1 ? 15 : 30;
|
// 跟踪天数 <= 1 ? 15 : 30;
|
||||||
const trackingDaysField = WfForm.convertFieldNameToId("gzts")
|
var trackingDaysField = WfForm.convertFieldNameToId("gzts")
|
||||||
// 跟踪触发行数
|
// 跟踪触发行数
|
||||||
const trackingLineField = WfForm.convertFieldNameToId("gzcfxs");
|
var trackingLineField = WfForm.convertFieldNameToId("gzcfxs");
|
||||||
$(() => {
|
jQuery(document).ready(function (){
|
||||||
let detail2LineNum = WfForm.getDetailRowCount("detail_2");
|
var detail2LineNum = WfForm.getDetailRowCount("detail_2");
|
||||||
// let firstTrack = Boolean(true);
|
// let firstTrack = Boolean(true);
|
||||||
// if (new Date(firstSaleDate) < new Date(currentDate) && dayDiff > 0) {
|
// if (new Date(firstSaleDate) < new Date(currentDate) && dayDiff > 0) {
|
||||||
// firstTrack = false;
|
// firstTrack = false;
|
||||||
// }
|
// }
|
||||||
// console.log('firstTrack ', firstTrack)
|
// console.log('firstTrack ', firstTrack)
|
||||||
// 到达节点次数
|
// 到达节点次数
|
||||||
const nodeNum = getNodeNum();
|
var nodeNum = getNodeNum();
|
||||||
let trackingLine = parseInt(WfForm.getFieldValue(trackingLineField));
|
var trackingLine = parseInt(WfForm.getFieldValue(trackingLineField));
|
||||||
// 如果不是则自动添加一行明细让他自己填写
|
// 如果不是则自动添加一行明细让他自己填写
|
||||||
if (detail2LineNum < trackingLine && detail2LineNum < nodeNum) {
|
if (detail2LineNum < trackingLine && detail2LineNum < nodeNum) {
|
||||||
console.log('添加一行明细!');
|
console.log('添加一行明细!');
|
||||||
|
@ -33,32 +33,32 @@ $(() => {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
initTimeoutDate();
|
initTimeoutDate();
|
||||||
WfForm.bindFieldChangeEvent(`${firstSaleDateField},${trackTimeField}`,()=>{
|
WfForm.bindFieldChangeEvent(firstSaleDateField + "," + trackTimeField,function (){
|
||||||
initTimeoutDate();
|
initTimeoutDate();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
function getNodeNum(){
|
function getNodeNum(){
|
||||||
let firstSaleDate = WfForm.getFieldValue(firstSaleDateField);
|
var firstSaleDate = WfForm.getFieldValue(firstSaleDateField);
|
||||||
console.log('首台销售日期 ', firstSaleDate);
|
console.log('首台销售日期 ', firstSaleDate);
|
||||||
let currentDate = getCurrentDate();
|
var currentDate = getCurrentDate();
|
||||||
let dayDiff = getDaysDiff(firstSaleDate, currentDate);
|
var dayDiff = getDaysDiff(firstSaleDate, currentDate);
|
||||||
console.log('当前天数与首台销售日期相差天数 : ', dayDiff)
|
console.log('当前天数与首台销售日期相差天数 : ', dayDiff)
|
||||||
let trackingDays = WfForm.getFieldValue(trackingDaysField);
|
var trackingDays = WfForm.getFieldValue(trackingDaysField);
|
||||||
return Math.floor(dayDiff / trackingDays) + 1;
|
return Math.floor(dayDiff / trackingDays) + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
function initTimeoutDate(){
|
function initTimeoutDate(){
|
||||||
console.log('==== initTimeoutDate begin ====')
|
console.log('==== initTimeoutDate begin ====')
|
||||||
let firstSaleDate = WfForm.getFieldValue(firstSaleDateField);
|
var firstSaleDate = WfForm.getFieldValue(firstSaleDateField);
|
||||||
const nodeNum = getNodeNum();
|
var nodeNum = getNodeNum();
|
||||||
console.log('到达节点次数 ', nodeNum);
|
console.log('到达节点次数 ', nodeNum);
|
||||||
let trackingDays = WfForm.getFieldValue(trackingDaysField);
|
var trackingDays = WfForm.getFieldValue(trackingDaysField);
|
||||||
console.log('跟踪天数 ', trackingDays);
|
console.log('跟踪天数 ', trackingDays);
|
||||||
let computeTimeoutDate = addDays(firstSaleDate, nodeNum * trackingDays);
|
var computeTimeoutDate = addDays(firstSaleDate, nodeNum * trackingDays);
|
||||||
console.log('计算下次超时日期 ', computeTimeoutDate);
|
console.log('计算下次超时日期 ', computeTimeoutDate);
|
||||||
let trackingLine = parseInt(WfForm.getFieldValue(trackingLineField));
|
var trackingLine = parseInt(WfForm.getFieldValue(trackingLineField));
|
||||||
let detail2LineNum = WfForm.getDetailRowCount("detail_2");
|
var detail2LineNum = WfForm.getDetailRowCount("detail_2");
|
||||||
setTimeout(()=>{
|
setTimeout(()=>{
|
||||||
WfForm.changeFieldValue(timeoutRemindDateFiled, {value: computeTimeoutDate});
|
WfForm.changeFieldValue(timeoutRemindDateFiled, {value: computeTimeoutDate});
|
||||||
// 判断流程提交走向
|
// 判断流程提交走向
|
||||||
|
@ -72,7 +72,7 @@ function initTimeoutDate(){
|
||||||
if (detail2LineNum < trackingLine) {
|
if (detail2LineNum < trackingLine) {
|
||||||
WfForm.showMessage('请填写明细表信息!');
|
WfForm.showMessage('请填写明细表信息!');
|
||||||
detail2LineNum = WfForm.getDetailRowCount("detail_2");
|
detail2LineNum = WfForm.getDetailRowCount("detail_2");
|
||||||
for (let i = 0; i < trackingLine - parseInt(detail2LineNum); i++) {
|
for (var i = 0; i < trackingLine - parseInt(detail2LineNum); i++) {
|
||||||
WfForm.addDetailRow("detail_2", {});
|
WfForm.addDetailRow("detail_2", {});
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -89,8 +89,8 @@ function initTimeoutDate(){
|
||||||
function getDaysDiff(date1, date2) {
|
function getDaysDiff(date1, date2) {
|
||||||
date1 = new Date(date1);
|
date1 = new Date(date1);
|
||||||
date2 = new Date(date2);
|
date2 = new Date(date2);
|
||||||
const oneDay = 24 * 60 * 60 * 1000; // 一天的毫秒数
|
var oneDay = 24 * 60 * 60 * 1000; // 一天的毫秒数
|
||||||
const timeDiff = Math.abs(date1.getTime() - date2.getTime()); // 两个日期对象的毫秒数差值
|
var timeDiff = Math.abs(date1.getTime() - date2.getTime()); // 两个日期对象的毫秒数差值
|
||||||
// 将毫秒数差值转换为天数差值并四舍五入
|
// 将毫秒数差值转换为天数差值并四舍五入
|
||||||
return Math.round(timeDiff / oneDay);
|
return Math.round(timeDiff / oneDay);
|
||||||
}
|
}
|
||||||
|
@ -100,14 +100,14 @@ function getCurrentDate() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function parseDate(date) {
|
function parseDate(date) {
|
||||||
const currentYear = date.getFullYear();
|
var currentYear = date.getFullYear();
|
||||||
const currentMonth = date.getMonth() + 1; // getMonth()返回0~11,需要加1
|
var currentMonth = date.getMonth() + 1; // getMonth()返回0~11,需要加1
|
||||||
const currentDay = date.getDate();
|
var currentDay = date.getDate();
|
||||||
return currentYear + '-' + currentMonth + '-' + currentDay;
|
return currentYear + '-' + currentMonth + '-' + currentDay;
|
||||||
}
|
}
|
||||||
|
|
||||||
function addDays(date, days) {
|
function addDays(date, days) {
|
||||||
const newDate = new Date(date);
|
var newDate = new Date(date);
|
||||||
newDate.setDate(newDate.getDate() + days);
|
newDate.setDate(newDate.getDate() + days);
|
||||||
console.log('newDate ', newDate)
|
console.log('newDate ', newDate)
|
||||||
return parseDate(newDate);
|
return parseDate(newDate);
|
||||||
|
|
|
@ -69,7 +69,7 @@ public class OtherSystemToOAServiceImpl implements OtherSystemToOAService {
|
||||||
String sql = "select id from hrmresource where " + Util.null2DefaultStr(ShBigDataUtil.getPropertiesValByKey("ssoOaCompareField"),"outkey") + " = #{outKey}";
|
String sql = "select id from hrmresource where " + Util.null2DefaultStr(ShBigDataUtil.getPropertiesValByKey("ssoOaCompareField"),"outkey") + " = #{outKey}";
|
||||||
int id = otherSystemToOAMapper.selectUserIdByOutKey(sql, oaOutKey);
|
int id = otherSystemToOAMapper.selectUserIdByOutKey(sql, oaOutKey);
|
||||||
if(id < 0){
|
if(id < 0){
|
||||||
throw new CustomerException(Util.logStr("code : {} not found in OA!", id));
|
throw new CustomerException(Util.logStr("code : {} not found in OA!", oaOutKey));
|
||||||
}
|
}
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,8 +2,10 @@ package weaver.xuanran.wang.immc.cusfieldvalue;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import com.alibaba.fastjson.JSONObject;
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import org.apache.commons.collections.CollectionUtils;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
|
import weaver.general.TimeUtil;
|
||||||
import weaver.xiao.commons.config.interfacies.CusInterfaceGetValue;
|
import weaver.xiao.commons.config.interfacies.CusInterfaceGetValue;
|
||||||
import weaver.xiao.commons.config.interfacies.CusInterfaceListValue;
|
import weaver.xiao.commons.config.interfacies.CusInterfaceListValue;
|
||||||
import weaver.xuanran.wang.immc.mapper.ImMcMapper;
|
import weaver.xuanran.wang.immc.mapper.ImMcMapper;
|
||||||
|
@ -27,24 +29,31 @@ public class CusListValue implements CusInterfaceGetValue {
|
||||||
log.info("pathParam : \n" + JSONObject.toJSONString(pathParam));
|
log.info("pathParam : \n" + JSONObject.toJSONString(pathParam));
|
||||||
String attachmentField = Util.null2DefaultStr(pathParam.get("attachmentField"), "");
|
String attachmentField = Util.null2DefaultStr(pathParam.get("attachmentField"), "");
|
||||||
String cusSql = Util.null2DefaultStr(pathParam.get("cusSql"), "");
|
String cusSql = Util.null2DefaultStr(pathParam.get("cusSql"), "");
|
||||||
|
// 如果fileName不为空则对集合中每个map添加"fileName":value value则是附件字段名称
|
||||||
|
String fileName = Util.null2DefaultStr(pathParam.get("fileName"), "");
|
||||||
if(StringUtils.isNotBlank(cusSql)){
|
if(StringUtils.isNotBlank(cusSql)){
|
||||||
String docIds = "";
|
|
||||||
if (StringUtils.isNotBlank(attachmentField)) {
|
if (StringUtils.isNotBlank(attachmentField)) {
|
||||||
List<String> attachment = new ArrayList<>();
|
|
||||||
for (String item : attachmentField.split(",")) {
|
for (String item : attachmentField.split(",")) {
|
||||||
String filedValue = Util.null2DefaultStr(mainMap.get(item),"");
|
String filedValue = Util.null2DefaultStr(mainMap.get(item),"");
|
||||||
if(StringUtils.isNotBlank(Util.null2DefaultStr(mainMap.get(item),""))){
|
if(StringUtils.isNotBlank(Util.null2DefaultStr(mainMap.get(filedValue),""))){
|
||||||
attachment.add(filedValue);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
docIds = StringUtils.join(attachment, ",");
|
|
||||||
}
|
|
||||||
cusSql = cusSql
|
cusSql = cusSql
|
||||||
.replace("{?docIds}", "( " + docIds + " )")
|
.replace("{?docIds}", "( " + filedValue + " )")
|
||||||
.replace("{?requestid}",Util.null2DefaultStr(mainMap.get("requestid"),""));
|
.replace("{?requestid}",Util.null2DefaultStr(mainMap.get("requestid"),""));
|
||||||
List<Map<String, String>> attachmentInfo = mapper.getAttachmentInfo(cusSql);
|
List<Map<String, String>> attachmentInfo = mapper.getAttachmentInfo(cusSql);
|
||||||
|
if(CollectionUtils.isEmpty(attachmentInfo)){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
// 往map中put附件字段名
|
||||||
|
if(StringUtils.isBlank(fileName)){
|
||||||
|
attachmentInfo.forEach(file ->{
|
||||||
|
file.put(fileName, item);
|
||||||
|
});
|
||||||
|
}
|
||||||
list.addAll(attachmentInfo);
|
list.addAll(attachmentInfo);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,6 +42,7 @@ public class WorkFlowToVmsAndMQService {
|
||||||
// 表单字段
|
// 表单字段
|
||||||
private static final String VMS_SUCCESS = "vms_success";
|
private static final String VMS_SUCCESS = "vms_success";
|
||||||
private static final String SUCCESS = "0";
|
private static final String SUCCESS = "0";
|
||||||
|
|
||||||
{
|
{
|
||||||
httpUtils.getGlobalCache().header.put("Content-Type", MediaType.APPLICATION_JSON); // 全局请求头
|
httpUtils.getGlobalCache().header.put("Content-Type", MediaType.APPLICATION_JSON); // 全局请求头
|
||||||
}
|
}
|
||||||
|
@ -88,11 +89,12 @@ public class WorkFlowToVmsAndMQService {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1>解析响应对象</h1>
|
* <h1>解析响应对象</h1>
|
||||||
* @author xuanran.wang
|
*
|
||||||
* @dateTime 2022/12/23 11:25
|
|
||||||
* @param responseVo 响应对象
|
* @param responseVo 响应对象
|
||||||
* @param url 地址
|
* @param url 地址
|
||||||
* @param requestParam 请求
|
* @param requestParam 请求
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2022/12/23 11:25
|
||||||
**/
|
**/
|
||||||
private void parseResponseVo(ResponeVo responseVo, String url, Map<String, Object> requestParam, VmsResponseVoField vmsResponseVoField) {
|
private void parseResponseVo(ResponeVo responseVo, String url, Map<String, Object> requestParam, VmsResponseVoField vmsResponseVoField) {
|
||||||
if (responseVo.getCode() != SUCCESS_CODE) { // 相应状态码
|
if (responseVo.getCode() != SUCCESS_CODE) { // 相应状态码
|
||||||
|
@ -112,10 +114,11 @@ public class WorkFlowToVmsAndMQService {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1>将流程信息发送到kafka</h1>
|
* <h1>将流程信息发送到kafka</h1>
|
||||||
* @author xuanran.wang
|
*
|
||||||
* @dateTime 2023/3/30 14:56
|
|
||||||
* @param kafkaConfig kafka配置文件名称
|
* @param kafkaConfig kafka配置文件名称
|
||||||
* @param message 消息对象
|
* @param message 消息对象
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2023/3/30 14:56
|
||||||
**/
|
**/
|
||||||
public void sendToMQ(String kafkaConfig, Map<String, Object> message) {
|
public void sendToMQ(String kafkaConfig, Map<String, Object> message) {
|
||||||
KafkaProducer<String, String> producer = null;
|
KafkaProducer<String, String> producer = null;
|
||||||
|
@ -159,11 +162,12 @@ public class WorkFlowToVmsAndMQService {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1>更新流程sql</h1>
|
* <h1>更新流程sql</h1>
|
||||||
* @author xuanran.wang
|
*
|
||||||
* @dateTime 2023/3/30 19:18
|
|
||||||
* @param field 主表字段
|
* @param field 主表字段
|
||||||
* @param tableName 表名
|
* @param tableName 表名
|
||||||
* @param requestId 请求id
|
* @param requestId 请求id
|
||||||
|
* @author xuanran.wang
|
||||||
|
* @dateTime 2023/3/30 19:18
|
||||||
**/
|
**/
|
||||||
public void updateWorkFlow(String field, String tableName, String requestId) {
|
public void updateWorkFlow(String field, String tableName, String requestId) {
|
||||||
String updateSQL = "update " + tableName + " set " + field + " = " + SUCCESS + " where requestid = ?";
|
String updateSQL = "update " + tableName + " set " + field + " = " + SUCCESS + " where requestid = ?";
|
||||||
|
|
|
@ -74,6 +74,11 @@ public class SendTodoTaskUtil {
|
||||||
todoTask.setAgentid(agentId);
|
todoTask.setAgentid(agentId);
|
||||||
todoTask.setTaskName(obj.getRequestnamenew());
|
todoTask.setTaskName(obj.getRequestnamenew());
|
||||||
todoTask.setTaskDesc(obj.getRequestnamenew());
|
todoTask.setTaskDesc(obj.getRequestnamenew());
|
||||||
|
String pcAgentId = ShBigDataUtil.getPropertiesValByKey("pcAgentId");
|
||||||
|
if(StringUtils.isBlank(pcAgentId)){
|
||||||
|
pcAgentId = agentId;
|
||||||
|
}
|
||||||
|
todoTask.setPcAgentId(pcAgentId);
|
||||||
String todoSSOCallBackUrl = ShBigDataUtil.getPropertiesValByKey("todoSSOCallBackUrl");
|
String todoSSOCallBackUrl = ShBigDataUtil.getPropertiesValByKey("todoSSOCallBackUrl");
|
||||||
StringBuilder sb = new StringBuilder(todoSSOCallBackUrl);
|
StringBuilder sb = new StringBuilder(todoSSOCallBackUrl);
|
||||||
sb.append("?user=")
|
sb.append("?user=")
|
||||||
|
|
|
@ -37,6 +37,7 @@ public class ShBigDataUtil {
|
||||||
WHILTE_LIST.add("getUserIdDebugOutKey");
|
WHILTE_LIST.add("getUserIdDebugOutKey");
|
||||||
WHILTE_LIST.add("ssoInterfaceCompareField");
|
WHILTE_LIST.add("ssoInterfaceCompareField");
|
||||||
WHILTE_LIST.add("ssoOaCompareField");
|
WHILTE_LIST.add("ssoOaCompareField");
|
||||||
|
WHILTE_LIST.add("pcAgentId");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -26,4 +26,5 @@ public class CusTodoTask {
|
||||||
protected String mobileLinkUrl;
|
protected String mobileLinkUrl;
|
||||||
protected String receiver;
|
protected String receiver;
|
||||||
protected String sender;
|
protected String sender;
|
||||||
|
protected String pcAgentId;
|
||||||
}
|
}
|
||||||
|
|
|
@ -391,8 +391,8 @@ public class BigDataTest extends BaseTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testG(){
|
public void testG(){
|
||||||
String oaOutKey = "111";
|
String oaOutKey = "wld";
|
||||||
String sql = "select id from hrmresource where " + Util.null2DefaultStr(ShBigDataUtil.getPropertiesValByKey("ssoOaCompareField"),"outkey") + " = #{outKey}";
|
String sql = "select id from hrmresource where loginid = #{outKey}";
|
||||||
int id = otherSystemToOAMapper.selectUserIdByOutKey(sql, oaOutKey);
|
int id = otherSystemToOAMapper.selectUserIdByOutKey(sql, oaOutKey);
|
||||||
log.info("id => " + id);
|
log.info("id => " + id);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue