FormPublicUtils.java 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446
  1. package jnpf.base.util;
  2. import cn.hutool.core.util.ObjectUtil;
  3. import jnpf.model.visualJson.FieLdsModel;
  4. import jnpf.model.visualJson.config.ConfigModel;
  5. import jnpf.util.*;
  6. import jnpf.util.visiual.JnpfKeyConsts;
  7. import java.math.BigDecimal;
  8. import java.text.ParseException;
  9. import java.text.SimpleDateFormat;
  10. import java.util.*;
  11. import java.util.stream.Collectors;
  12. /**
  13. * 在线开发公用
  14. *
  15. * @author JNPF开发平台组
  16. * @version V3.1.0
  17. * @copyright 引迈信息技术有限公司(https://www.jnpfsoft.com)
  18. * @date 2021/7/28
  19. */
  20. public class FormPublicUtils {
  21. /**
  22. * 递归控件,除子表外控件全部提到同级
  23. * 取子集,子表不外提
  24. *
  25. * @return
  26. */
  27. public static void recursionFieldsExceptChild(List<FieLdsModel> allFields, List<FieLdsModel> fieLdsModelList) {
  28. for (FieLdsModel fieLdsModel : fieLdsModelList) {
  29. ConfigModel config = fieLdsModel.getConfig();
  30. String jnpfKey = config.getJnpfKey();
  31. if (JnpfKeyConsts.CHILD_TABLE.equals(jnpfKey)) {
  32. allFields.add(fieLdsModel);
  33. continue;
  34. } else {
  35. if (config.getChildren() != null) {
  36. recursionFieldsExceptChild(allFields, config.getChildren());
  37. } else {
  38. if (jnpfKey == null) {
  39. continue;
  40. }
  41. allFields.add(fieLdsModel);
  42. }
  43. }
  44. }
  45. }
  46. /**
  47. * 转换时间格式
  48. *
  49. * @param time
  50. * @return
  51. */
  52. public static String getTimeFormat(String time) {
  53. String result;
  54. switch (time.length()) {
  55. case 16:
  56. result = time + ":00";
  57. break;
  58. case 19:
  59. result = time;
  60. break;
  61. case 21:
  62. result = time.substring(0, time.length() - 2);
  63. break;
  64. case 10:
  65. result = time + " 00:00:00";
  66. break;
  67. case 8:
  68. result = "2000-01-01 " + time;
  69. break;
  70. case 7:
  71. result = time + "-01 00:00:00";
  72. break;
  73. case 4:
  74. result = time + "-01-01 00:00:00";
  75. break;
  76. default:
  77. result = "";
  78. break;
  79. }
  80. return result;
  81. }
  82. public static String getLastTimeFormat(String time) {
  83. String result;
  84. switch (time.length()) {
  85. case 16:
  86. result = time + ":00";
  87. break;
  88. case 19:
  89. result = time;
  90. break;
  91. case 10:
  92. result = time + " 23:59:59";
  93. break;
  94. case 8:
  95. result = "2000-01-01 " + time;
  96. break;
  97. case 7:
  98. //获取月份最后一天
  99. String[] split = time.split("-");
  100. Calendar cale = Calendar.getInstance();
  101. cale.set(Calendar.YEAR, Integer.valueOf(split[0]));//赋值年份
  102. cale.set(Calendar.MONTH, Integer.valueOf(split[1]) - 1);//赋值月份
  103. int lastDay = cale.getActualMaximum(Calendar.DAY_OF_MONTH);//获取月最大天数
  104. cale.set(Calendar.DAY_OF_MONTH, lastDay);//设置日历中月份的最大天数
  105. cale.set(Calendar.HOUR_OF_DAY, 23);
  106. cale.set(Calendar.SECOND, 59);
  107. cale.set(Calendar.MINUTE, 59);
  108. result = DateUtil.daFormatHHMMSS(cale.getTime().getTime());
  109. break;
  110. case 4:
  111. result = time + "-12-31 23:59:59";
  112. break;
  113. default:
  114. result = "";
  115. break;
  116. }
  117. return result;
  118. }
  119. /**
  120. * 判断时间是否在设置范围内
  121. *
  122. * @param swapDataVo
  123. * @param format
  124. * @param value
  125. * @param data
  126. * @param jnpfKey
  127. * @return
  128. */
  129. public static boolean dateTimeCondition(FieLdsModel swapDataVo, String format, Object value, Map<String, Object> data, String jnpfKey) {
  130. long valueTimeLong;
  131. //输入值转long
  132. if (value instanceof String) {
  133. valueTimeLong = cn.hutool.core.date.DateUtil.parse(String.valueOf(value), format).getTime();
  134. } else {
  135. //输入值按格式补全
  136. String timeFormat = getTimeFormat(String.valueOf(value));
  137. valueTimeLong = DateUtil.stringToDate(timeFormat).getTime();
  138. }
  139. boolean timeHasRangeError = false;
  140. //开始时间判断
  141. if (swapDataVo.getConfig().getStartTimeRule()) {
  142. String startTimeValue = swapDataVo.getConfig().getStartTimeValue();
  143. String startTimeType = swapDataVo.getConfig().getStartTimeType();
  144. String startTimeTarget = swapDataVo.getConfig().getStartTimeTarget();
  145. String startTimeRelationField = swapDataVo.getConfig().getStartRelationField();
  146. //根据类型获取开始时间戳
  147. long startTimeLong = getDateTimeLong(data, jnpfKey, startTimeValue, startTimeType, startTimeTarget, startTimeRelationField, format);
  148. if (startTimeLong != 0 && valueTimeLong < startTimeLong) {
  149. timeHasRangeError = true;
  150. }
  151. }
  152. //结束时间判断
  153. if (swapDataVo.getConfig().getEndTimeRule()) {
  154. String endTimeValue = swapDataVo.getConfig().getEndTimeValue();
  155. String endTimeType = swapDataVo.getConfig().getEndTimeType();
  156. String endTimeTarget = swapDataVo.getConfig().getEndTimeTarget();
  157. String endTimeRelationField = swapDataVo.getConfig().getEndRelationField();
  158. //根据类型获取开始时间戳
  159. long endTimeLong = getDateTimeLong(data, jnpfKey, endTimeValue, endTimeType, endTimeTarget, endTimeRelationField, format);
  160. if (endTimeLong != 0 && valueTimeLong > endTimeLong) {
  161. timeHasRangeError = true;
  162. }
  163. }
  164. return timeHasRangeError;
  165. }
  166. /**
  167. * 根据类型获取时间戳
  168. *
  169. * @param data
  170. * @param jnpfKey
  171. * @param timeValue
  172. * @param timeType
  173. * @param timeTarget
  174. * @return
  175. */
  176. public static long getDateTimeLong(Map<String, Object> data, String jnpfKey, String timeValue, String timeType, String timeTarget,
  177. String stringimeRelationField, String format) {
  178. if (StringUtil.isEmpty(timeValue)) {
  179. timeValue = "0";
  180. }
  181. long startTimeLong = 0;
  182. //当前格式的当前时间戳
  183. long timestampInMillis = new Date().getTime();
  184. try {
  185. SimpleDateFormat sdf = new SimpleDateFormat(format);
  186. String s = sdf.format(new Date());
  187. timestampInMillis = sdf.parse(s).getTime();
  188. } catch (ParseException e) {
  189. }
  190. switch (timeType) {
  191. case "1"://特定时间
  192. if (JnpfKeyConsts.DATE.equals(jnpfKey)) {
  193. startTimeLong = Long.parseLong(timeValue);
  194. } else {
  195. String newDateStr = DateUtil.daFormat(new Date()) + " " + timeValue + (timeValue.length() > 6 ? "" : ":00");
  196. startTimeLong = DateUtil.stringToDate(newDateStr).getTime();
  197. }
  198. break;
  199. case "2"://表单字段
  200. if (stringimeRelationField != null) {
  201. String fieldValue = "";
  202. if (stringimeRelationField.toLowerCase().contains(JnpfKeyConsts.CHILD_TABLE_PREFIX)) {//子
  203. String[] split = stringimeRelationField.split("-");
  204. fieldValue = data.get(split[1]) != null ? data.get(split[1]).toString() : "";
  205. } else {//主副
  206. Map<String, Object> mainAndMast = data.get("mainAndMast") != null ? JsonUtil.entityToMap(data.get("mainAndMast")) : data;
  207. fieldValue = mainAndMast.get(stringimeRelationField) != null ? mainAndMast.get(stringimeRelationField).toString() : "";
  208. }
  209. if (StringUtil.isNotEmpty(fieldValue)) {
  210. String timeFormat = getTimeFormat(fieldValue);
  211. startTimeLong = cn.hutool.core.date.DateUtil.parse(timeFormat, "yyyy-MM-dd HH:mm:ss").getTime();
  212. }
  213. }
  214. break;
  215. case "3"://填写当前时间
  216. startTimeLong = timestampInMillis;
  217. break;
  218. case "4"://当前时间前
  219. Calendar caledel = Calendar.getInstance();
  220. caledel.setTimeInMillis(timestampInMillis);
  221. if (JnpfKeyConsts.DATE.equals(jnpfKey)) {
  222. switch (timeTarget) {
  223. case "1"://年
  224. caledel.set(Calendar.YEAR, caledel.get(Calendar.YEAR) - Integer.valueOf(timeValue));//赋值年份
  225. break;
  226. case "2"://月
  227. caledel.set(Calendar.MONTH, caledel.get(Calendar.MONTH) - Integer.valueOf(timeValue));
  228. break;
  229. case "3"://日
  230. caledel.set(Calendar.DAY_OF_MONTH, caledel.get(Calendar.DAY_OF_MONTH) - Integer.valueOf(timeValue));
  231. break;
  232. }
  233. } else {
  234. switch (timeTarget) {
  235. case "1"://时
  236. caledel.set(Calendar.HOUR_OF_DAY, caledel.get(Calendar.HOUR_OF_DAY) - Integer.valueOf(timeValue));
  237. break;
  238. case "2"://分
  239. caledel.set(Calendar.MINUTE, caledel.get(Calendar.MINUTE) - Integer.valueOf(timeValue));
  240. break;
  241. case "3"://秒
  242. caledel.set(Calendar.SECOND, caledel.get(Calendar.SECOND) - Integer.valueOf(timeValue));
  243. break;
  244. }
  245. }
  246. startTimeLong = caledel.getTime().getTime();
  247. break;
  248. case "5"://当前时间后
  249. Calendar cale = Calendar.getInstance();
  250. cale.setTimeInMillis(timestampInMillis);
  251. if (JnpfKeyConsts.DATE.equals(jnpfKey)) {
  252. switch (timeTarget) {
  253. case "1"://年
  254. cale.set(Calendar.YEAR, cale.get(Calendar.YEAR) + Integer.valueOf(timeValue));//赋值年份
  255. break;
  256. case "2"://月
  257. cale.set(Calendar.MONTH, cale.get(Calendar.MONTH) + Integer.valueOf(timeValue));
  258. break;
  259. case "3"://日
  260. cale.set(Calendar.DAY_OF_MONTH, cale.get(Calendar.DAY_OF_MONTH) + Integer.valueOf(timeValue));
  261. break;
  262. }
  263. } else {
  264. switch (timeTarget) {
  265. case "1"://时
  266. cale.set(Calendar.HOUR_OF_DAY, cale.get(Calendar.HOUR_OF_DAY) + Integer.valueOf(timeValue));
  267. break;
  268. case "2"://分
  269. cale.set(Calendar.MINUTE, cale.get(Calendar.MINUTE) + Integer.valueOf(timeValue));
  270. break;
  271. case "3"://秒
  272. cale.set(Calendar.SECOND, cale.get(Calendar.SECOND) + Integer.valueOf(timeValue));
  273. break;
  274. }
  275. }
  276. startTimeLong = cale.getTime().getTime();
  277. break;
  278. default:
  279. break;
  280. }
  281. return startTimeLong;
  282. }
  283. /**
  284. * 字符串转数组
  285. *
  286. * @param value 值
  287. * @return
  288. */
  289. public static Object getDataConversion(Object value) {
  290. if (value instanceof Integer || value instanceof Long || value instanceof Float || value instanceof Double || value instanceof BigDecimal)
  291. return value;
  292. Object dataValue = getDataConversion(null, value, false, "/");
  293. return dataValue;
  294. }
  295. /**
  296. * 字符串转数组
  297. *
  298. * @param redis 转换对象
  299. * @param value 值
  300. * @return
  301. */
  302. public static Object getDataConversion(Map<String, Object> redis, Object value, boolean isMultiple, String separator) {
  303. Object dataValue = value;
  304. boolean iszhuanhuan = redis != null;
  305. try {
  306. List<List> list = JsonUtil.getJsonToList(String.valueOf(value), List.class);
  307. dataValue = list;
  308. if (iszhuanhuan) {
  309. //一级分隔符
  310. StringJoiner joiner = new StringJoiner(",");
  311. for (List listChild : list) {
  312. StringJoiner aa = new StringJoiner(separator);
  313. for (Object object : listChild) {
  314. String value1 = redis.get(String.valueOf(object)) != null ? String.valueOf(redis.get(String.valueOf(object))) : "";
  315. if (StringUtil.isNotEmpty(value1)) {
  316. aa.add(value1);
  317. }
  318. }
  319. joiner.add(aa.toString());
  320. }
  321. dataValue = joiner.toString();
  322. }
  323. } catch (Exception e) {
  324. try {
  325. List<String> list = JsonUtil.getJsonToList(String.valueOf(value), String.class);
  326. dataValue = list;
  327. if (iszhuanhuan) {
  328. if (isMultiple) {//一级分隔符
  329. separator = ",";
  330. }
  331. StringJoiner joiner = new StringJoiner(separator);
  332. for (Object listChild : list) {
  333. String value1 = redis.get(String.valueOf(listChild)) != null ? String.valueOf(redis.get(String.valueOf(listChild))) : "";
  334. if (StringUtil.isNotEmpty(value1)) {
  335. joiner.add(value1);
  336. }
  337. }
  338. dataValue = joiner.toString();
  339. }
  340. } catch (Exception e1) {
  341. dataValue = String.valueOf(value);
  342. if (iszhuanhuan) {
  343. dataValue = redis.get(String.valueOf(value)) != null ? String.valueOf(redis.get(String.valueOf(value))) : "";
  344. }
  345. }
  346. }
  347. return dataValue;
  348. }
  349. /**
  350. * 给列表数据添加id
  351. *
  352. * @param dataList
  353. * @param key
  354. */
  355. public static List<Map<String, Object>> addIdToList(List<Map<String, Object>> dataList, String key) {
  356. return dataList.stream().map(data -> {
  357. data.put(FlowFormConstant.ID, data.get(key));
  358. String flwoId = null;
  359. if (data.get(TableFeildsEnum.FLOWID.getField()) != null) {
  360. flwoId = String.valueOf(data.get(TableFeildsEnum.FLOWID.getField()));
  361. }
  362. if (data.get(TableFeildsEnum.FLOWID.getField().toUpperCase()) != null) {
  363. flwoId = String.valueOf(data.get(TableFeildsEnum.FLOWID.getField().toUpperCase()));
  364. }
  365. data.put(FlowFormConstant.FLOWID, flwoId);
  366. String flowTaskId = null;
  367. if (data.get(TableFeildsEnum.FLOWTASKID.getField()) != null) {
  368. flowTaskId = String.valueOf(data.get(TableFeildsEnum.FLOWTASKID.getField()));
  369. }
  370. if (data.get(TableFeildsEnum.FLOWTASKID.getField().toUpperCase()) != null) {
  371. flowTaskId = String.valueOf(data.get(TableFeildsEnum.FLOWTASKID.getField().toUpperCase()));
  372. }
  373. data.put(FlowFormConstant.FLOWTASKID, flowTaskId);
  374. return data;
  375. }).collect(Collectors.toList());
  376. }
  377. /**
  378. * 关联表单获取原字段数据(数据类型也要转换)
  379. *
  380. * @param dataMap
  381. * @param jnpfKey
  382. * @param obj
  383. * @param vModel
  384. */
  385. public static void relationGetJnpfId(Map<String, Object> dataMap, String jnpfKey, Object obj, String vModel) {
  386. String vModeljnpfId = vModel + "_jnpfId";
  387. switch (jnpfKey) {
  388. case JnpfKeyConsts.CREATETIME:
  389. case JnpfKeyConsts.MODIFYTIME:
  390. case JnpfKeyConsts.DATE:
  391. case JnpfKeyConsts.DATE_CALCULATE:
  392. Long dateTime = DateTimeFormatConstant.getDateObjToLong(dataMap.get(vModel));
  393. dataMap.put(vModeljnpfId, dateTime != null ? dateTime : dataMap.get(vModel));
  394. break;
  395. case JnpfKeyConsts.CHILD_TABLE:
  396. break;
  397. case JnpfKeyConsts.SWITCH:
  398. case JnpfKeyConsts.SLIDER:
  399. case JnpfKeyConsts.RATE:
  400. case JnpfKeyConsts.CALCULATE:
  401. case JnpfKeyConsts.NUM_INPUT:
  402. dataMap.put(vModeljnpfId, ObjectUtil.isNotEmpty(obj) ? new BigDecimal(String.valueOf(obj)) : dataMap.get(vModel));
  403. break;
  404. default:
  405. dataMap.put(vModeljnpfId, obj);
  406. break;
  407. }
  408. if (JnpfKeyConsts.getArraysKey().contains(jnpfKey) && obj != null) {
  409. String o = String.valueOf(obj);
  410. try {
  411. List<List> jsonToList = JsonUtil.getJsonToList(o, List.class);
  412. List<Object> res = new ArrayList<>();
  413. for (List listChild : jsonToList) {
  414. List<Object> res2 = new ArrayList<>();
  415. for (Object object : listChild) {
  416. if (object != null && StringUtil.isNotEmpty(String.valueOf(object))) {
  417. res2.add(object);
  418. }
  419. }
  420. res.add(res2);
  421. }
  422. dataMap.put(vModeljnpfId, res);
  423. } catch (Exception e) {
  424. try {
  425. List<Object> jsonToList = JsonUtil.getJsonToList(o, Object.class);
  426. dataMap.put(vModeljnpfId, jsonToList);
  427. } catch (Exception e1) {
  428. }
  429. }
  430. }
  431. }
  432. }