KdHuaGaoServiceImpl.java 59 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213
  1. package com.malk.huagao.service.impl;
  2. import cn.hutool.core.date.DateUtil;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.google.gson.Gson;
  5. import com.kingdee.bos.webapi.entity.IdentifyInfo;
  6. import com.kingdee.bos.webapi.entity.RepoRet;
  7. import com.kingdee.bos.webapi.sdk.K3CloudApi;
  8. import com.malk.huagao.KdEntity.BillQuery;
  9. import com.malk.huagao.KdEntity.View;
  10. import com.malk.huagao.config.KDWebApiConf;
  11. import com.malk.huagao.service.KdHuaGaoService;
  12. import com.malk.server.aliwork.YDConf;
  13. import com.malk.server.aliwork.YDParam;
  14. import com.malk.server.aliwork.YDSearch;
  15. import com.malk.server.common.McR;
  16. import com.malk.server.dingtalk.DDConf;
  17. import com.malk.server.dingtalk.DDR_New;
  18. import com.malk.service.aliwork.YDClient;
  19. import com.malk.service.dingtalk.DDClient;
  20. import com.malk.utils.UtilHttp;
  21. import com.malk.utils.UtilMap;
  22. import lombok.extern.slf4j.Slf4j;
  23. import org.apache.logging.log4j.util.Strings;
  24. import org.slf4j.MDC;
  25. import org.springframework.beans.factory.annotation.Autowired;
  26. import org.springframework.scheduling.annotation.Async;
  27. import org.springframework.stereotype.Service;
  28. import java.time.LocalDate;
  29. import java.time.LocalDateTime;
  30. import java.time.ZoneId;
  31. import java.time.ZonedDateTime;
  32. import java.time.temporal.TemporalAdjusters;
  33. import java.time.temporal.WeekFields;
  34. import java.util.*;
  35. import java.util.stream.Collectors;
  36. import static org.junit.Assert.fail;
  37. @Slf4j
  38. @Service
  39. public class KdHuaGaoServiceImpl implements KdHuaGaoService {
  40. @Autowired
  41. private KDWebApiConf kdWebApiConf;
  42. @Autowired
  43. private YDClient ydClient;
  44. @Autowired
  45. private DDClient ddClient;
  46. @Autowired
  47. private DDConf ddConf;
  48. //在库状态
  49. private static final Map<String,String> STOCK_STATUS = new HashMap<>();
  50. static{
  51. STOCK_STATUS.put("0","待入库");
  52. STOCK_STATUS.put("1","在库");
  53. STOCK_STATUS.put("2","待出库");
  54. STOCK_STATUS.put("3","出库");
  55. STOCK_STATUS.put("4","待售出");
  56. STOCK_STATUS.put("5","售出");
  57. STOCK_STATUS.put("6","待退料");
  58. STOCK_STATUS.put("7","退料");
  59. }
  60. @Override
  61. public void syncBDSerialMainFile(String userId) {
  62. MDC.put("MDC_KEY_PID","1002");
  63. //创建看板更新记录
  64. if (Strings.isBlank(userId)){
  65. userId = "yida_pub_account";
  66. }
  67. String formInstId = ydClient.operateData(YDParam.builder()
  68. .formUuid("FORM-0BEA655A36724D509A2CF21C4BA38D367YF7")
  69. .formDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mfmhvkey, selectField_mhsjnn2r, dateField_mhsjnn2s, employeeField_mhswy0xy", "成品库存天数看板", "更新中", System.currentTimeMillis(),Arrays.asList(userId))))
  70. .build(), YDConf.FORM_OPERATION.create).toString();
  71. // 获取当前日期
  72. LocalDate today = LocalDate.now();
  73. int year = today.getYear();//获取当前年份
  74. int month = today.getMonthValue();//当前月份
  75. WeekFields weekFields = WeekFields.of(Locale.getDefault());
  76. int weekOfMonth = today.get(weekFields.weekOfMonth());//当前日期是当月的第几周
  77. try {
  78. //删除宜搭当周序列号主档数据
  79. log.info("开始删除序列号主档数据:{}年,{}月,{}周",year,month,weekOfMonth);
  80. List<List<String>> formInstanceIdListList = new ArrayList<>();//实例id集合,每100条
  81. DDR_New ddrNew = new DDR_New();
  82. int pageSize = 50;
  83. int pageNumber = 0;
  84. do {
  85. pageNumber++;
  86. ddrNew = ydClient.queryData(YDParam.builder()
  87. .formUuid("FORM-3B2E5C93D7E6494B9AD920B48A90159F7DZ4")
  88. .searchFieldJson(JSONObject.toJSONString(UtilMap.map("numberField_mev270x6, numberField_mev270x5, textField_mev2ers5", Arrays.asList(year,year), Arrays.asList(month,month), weekOfMonth)))
  89. .pageNumber(pageNumber)
  90. .pageSize(pageSize)
  91. .build(), YDConf.FORM_QUERY.retrieve_search_form_id);
  92. formInstanceIdListList.addAll(Collections.singleton((List<String>) ddrNew.getData()));
  93. Thread.sleep(1000);
  94. }while (ddrNew.getPageNumber() * pageSize < ddrNew.getTotalCount());
  95. for (List<String> formInstanceIdList : formInstanceIdListList) {
  96. if (!formInstanceIdList.isEmpty()){
  97. ydClient.operateData(YDParam.builder()
  98. .formUuid("FORM-3B2E5C93D7E6494B9AD920B48A90159F7DZ4")
  99. .formInstanceIdList(formInstanceIdList)
  100. .build(), YDConf.FORM_OPERATION.delete_batch);
  101. }
  102. Thread.sleep(1000);
  103. }
  104. log.info("删除序列号主档数据完成:{}年,{}月,{}周",year,month,weekOfMonth);
  105. K3CloudApi client = new K3CloudApi(initIden());
  106. int startRow = 0;
  107. int limit = 2000;
  108. BillQuery billQuery = new BillQuery();
  109. billQuery.setLimit(limit);
  110. billQuery.setFormId("BD_SerialMainFile");
  111. billQuery.setFieldKeys("FNumber,FMaterialID.FNumber,FMaterialID.FName,FMaterialID.FSpecification,FMaterialID.F_QUXZ_Assistant,FZKTS,FStockStatus,FStockId.FName,FStockLocID.FF100001.FName,FCustId.FName");
  112. List<Map> filterString = new ArrayList<>();
  113. //仓库等于成品仓 仓位等于默认仓位或样机仓位 在库状态等于待入库或在库
  114. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FStockId.FName","67","成品仓","","","0"));//仓库名称等于XX
  115. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FStockLocId.FF100001.FName","67","默认仓位","(","","1"));//仓位等于XX
  116. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FStockLocId.FF100001.FName","67","样机仓位","",")","0"));//仓位等于XX
  117. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FStockStatus","29","0","(","","1"));//在库状态等于XX
  118. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FStockStatus","29","1","",")","0"));//在库状态等于XX
  119. billQuery.setFilterString(filterString);
  120. List<Map> result = new ArrayList<>();
  121. List<Map> list = new ArrayList<>();
  122. do {
  123. billQuery.setStartRow(startRow);
  124. String s = client.billQuery(JSONObject.toJSONString(billQuery));
  125. result = (List<Map>)JSONObject.parse(s);
  126. list.addAll(result);
  127. startRow += limit;
  128. }while (result.size() == limit);
  129. List<Map> originList = new ArrayList<>();
  130. for (Map map : list) {
  131. Map formData = new HashMap();
  132. formData.put("textField_mev1n46z",UtilMap.getString(map,"FNumber"));//序列号
  133. formData.put("textField_mev1n470",UtilMap.getString(map,"FMaterialID.FNumber"));//物料编码
  134. formData.put("textField_mev1n471",UtilMap.getString(map,"FMaterialID.FName"));//物料名称
  135. formData.put("textField_mev1n472",UtilMap.getString(map,"FMaterialID.FSpecification"));//规格型号
  136. String ssxl = UtilMap.getString(map, "FMaterialID.F_QUXZ_Assistant");
  137. formData.put("textField_mev1n477", ssxl);//所属系列
  138. Double zkts = UtilMap.getDouble(map, "FZKTS");
  139. formData.put("numberField_mev1n478", zkts);//在库天数
  140. String stockStatus = STOCK_STATUS.get(UtilMap.getString(map, "FStockStatus"));
  141. formData.put("textField_mev1n476", stockStatus);//在库状态
  142. formData.put("textField_mev1n473",UtilMap.getString(map,"FStockId.FName"));//仓库
  143. String cw = UtilMap.getString(map, "FStockLocID.FF100001.FName");
  144. formData.put("textField_mev1n474", cw);//仓位
  145. formData.put("textField_mev1n475",UtilMap.getString(map,"FCustId.FName"));//客户
  146. //在库天数分类
  147. int zktsfl = 1;
  148. if ("待入库".equals(stockStatus)){
  149. zktsfl = 1;
  150. }else {
  151. if (zkts <= 30){
  152. zktsfl = 2;
  153. }else if (zkts <= 60){
  154. zktsfl = 3;
  155. }else if (zkts <= 90){
  156. zktsfl = 4;
  157. }else {
  158. zktsfl = 5;
  159. }
  160. }
  161. formData.put("selectField_mf205zr0",zktsfl);
  162. formData.put("numberField_mev270x6",year);
  163. formData.put("numberField_mev270x5",month);
  164. formData.put("textField_mev2ers5",weekOfMonth);
  165. formData.put("numberField_mfat6egj",1);//统计数值,默认1
  166. ydClient.operateData(YDParam.builder()
  167. .formUuid("FORM-3B2E5C93D7E6494B9AD920B48A90159F7DZ4")
  168. .formDataJson(JSONObject.toJSONString(formData))
  169. .build(), YDConf.FORM_OPERATION.create);
  170. Map origin = new HashMap();
  171. origin.put("cw",cw);
  172. origin.put("ssxl",ssxl);
  173. origin.put("zktsfl",zktsfl);
  174. origin.put("value",1);
  175. originList.add(origin);
  176. }
  177. //删除宜搭历史最新库存信息
  178. List<Map> data = (List<Map>) ydClient.queryData(YDParam.builder()
  179. .formUuid("FORM-4CB51E04B8344622BE880C9D573F68CANKWU")
  180. .searchFieldJson(JSONObject.toJSONString(UtilMap.map("numberField_mev270x6, numberField_mev270x5",Arrays.asList(year,year), Arrays.asList(month,month))))
  181. .build(), YDConf.FORM_QUERY.retrieve_list).getData();
  182. List<String> formInstanceIdList = new ArrayList<>();
  183. for (Map datum : data) {
  184. formInstanceIdList.add(UtilMap.getString(datum,"formInstanceId"));
  185. }
  186. if (!formInstanceIdList.isEmpty()){
  187. ydClient.operateData(YDParam.builder()
  188. .formUuid("FORM-4CB51E04B8344622BE880C9D573F68CANKWU")
  189. .formInstanceIdList(formInstanceIdList)
  190. .build(), YDConf.FORM_OPERATION.delete_batch);
  191. }
  192. List<Map> data2 = (List<Map>) ydClient.queryData(YDParam.builder()
  193. .formUuid("FORM-5764CC3F6D964FD3A165BD7D4D75999FO8NQ")
  194. .searchFieldJson(JSONObject.toJSONString(UtilMap.map("numberField_mev270x6",Arrays.asList(year,year))))
  195. .build(), YDConf.FORM_QUERY.retrieve_list).getData();
  196. List<String> formInstanceIdList2 = new ArrayList<>();
  197. for (Map datum : data2) {
  198. formInstanceIdList2.add(UtilMap.getString(datum,"formInstanceId"));
  199. }
  200. if (!formInstanceIdList2.isEmpty()){
  201. ydClient.operateData(YDParam.builder()
  202. .formUuid("FORM-5764CC3F6D964FD3A165BD7D4D75999FO8NQ")
  203. .formInstanceIdList(formInstanceIdList2)
  204. .build(), YDConf.FORM_OPERATION.delete_batch);
  205. }
  206. //将最新库存信息写入宜搭
  207. List<Map> grouprList = originList.stream()
  208. .collect(Collectors.groupingBy(
  209. item -> Arrays.asList(
  210. item.get("cw"),
  211. item.get("ssxl"),
  212. item.get("zktsfl")
  213. ),
  214. Collectors.summingInt(item -> UtilMap.getInt(item, "value"))
  215. )).entrySet()
  216. .stream()
  217. .map(entry -> {
  218. // 将分组键(List<Object>)和汇总值转换为 Map
  219. List<Object> key = entry.getKey();
  220. Map<String, Object> groupedItem = new LinkedHashMap<>();
  221. groupedItem.put("textField_mev1n474", key.get(0));
  222. groupedItem.put("textField_mev1n477", key.get(1));
  223. groupedItem.put("selectField_mf205zr0", key.get(2));
  224. groupedItem.put("numberField_mev270x6", year);
  225. groupedItem.put("numberField_mev270x5", month);
  226. groupedItem.put("numberField_mfat6egj", entry.getValue());
  227. return groupedItem;
  228. }).collect(Collectors.toList());
  229. for (Map groupMap : grouprList) {
  230. ydClient.operateData(YDParam.builder()
  231. .formUuid("FORM-4CB51E04B8344622BE880C9D573F68CANKWU")
  232. .formDataJson(JSONObject.toJSONString(groupMap))
  233. .build(), YDConf.FORM_OPERATION.create);
  234. ydClient.operateData(YDParam.builder()
  235. .formUuid("FORM-5764CC3F6D964FD3A165BD7D4D75999FO8NQ")
  236. .formDataJson(JSONObject.toJSONString(groupMap))
  237. .build(), YDConf.FORM_OPERATION.create);
  238. }
  239. //更新看板更新记录
  240. ydClient.operateData(YDParam.builder()
  241. .formInstId(formInstId)
  242. .updateFormDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mhsjnn2r, dateField_mhsjnn2t", "已完成", System.currentTimeMillis())))
  243. .build(), YDConf.FORM_OPERATION.update);
  244. }catch (Exception e){
  245. //更新看板更新记录
  246. ydClient.operateData(YDParam.builder()
  247. .formInstId(formInstId)
  248. .updateFormDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mhsjnn2r, dateField_mhsjnn2t, textareaField_mir0zmpo", "异常", System.currentTimeMillis(),e.getMessage())))
  249. .build(), YDConf.FORM_OPERATION.update);
  250. throw new RuntimeException(e);
  251. }
  252. }
  253. @Override
  254. public void syncSTKInventory(String userId) {
  255. MDC.put("MDC_KEY_PID","1002");
  256. //创建看板更新记录
  257. if (Strings.isBlank(userId)){
  258. userId = "yida_pub_account";
  259. }
  260. String formInstId = ydClient.operateData(YDParam.builder()
  261. .formUuid("FORM-0BEA655A36724D509A2CF21C4BA38D367YF7")
  262. .formDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mfmhvkey, selectField_mhsjnn2r, dateField_mhsjnn2s, employeeField_mhswy0xy", "成品/组件库存看板", "更新中", System.currentTimeMillis(),Arrays.asList(userId))))
  263. .build(), YDConf.FORM_OPERATION.create).toString();
  264. // 获取当前日期
  265. LocalDate today = LocalDate.now();
  266. int year = today.getYear();//获取当前年份
  267. int month = today.getMonthValue();//当前月份
  268. WeekFields weekFields = WeekFields.of(Locale.getDefault());
  269. int weekOfMonth = today.get(weekFields.weekOfMonth());//当前日期是当月的第几周
  270. try {
  271. //删除宜搭当周库存信息
  272. log.info("开始删除即时库存数据:{}年,{}月,{}周",year,month,weekOfMonth);
  273. List<List<String>> formInstanceIdListList = new ArrayList<>();//实例id集合,每100条
  274. DDR_New ddrNew = new DDR_New();
  275. int pageSize = 50;
  276. int pageNumber = 0;
  277. do {
  278. pageNumber++;
  279. ddrNew = ydClient.queryData(YDParam.builder()
  280. .formUuid("FORM-06C833A3B1804929987033DD6B0E7B2F73JP")
  281. .searchFieldJson(JSONObject.toJSONString(UtilMap.map("numberField_mev270x6, numberField_mev270x5, textField_mev2ers5", Arrays.asList(year,year), Arrays.asList(month,month), weekOfMonth)))
  282. .pageNumber(pageNumber)
  283. .pageSize(pageSize)
  284. .build(), YDConf.FORM_QUERY.retrieve_search_form_id);
  285. formInstanceIdListList.addAll(Collections.singleton((List<String>) ddrNew.getData()));
  286. }while (ddrNew.getPageNumber() * pageSize < ddrNew.getTotalCount());
  287. for (List<String> formInstanceIdList : formInstanceIdListList) {
  288. if (!formInstanceIdList.isEmpty()){
  289. ydClient.operateData(YDParam.builder()
  290. .formUuid("FORM-06C833A3B1804929987033DD6B0E7B2F73JP")
  291. .formInstanceIdList(formInstanceIdList)
  292. .build(), YDConf.FORM_OPERATION.delete_batch);
  293. }
  294. Thread.sleep(1000);
  295. }
  296. log.info("删除即时库存数据完成:{}年,{}月,{}周",year,month,weekOfMonth);
  297. log.info("开始同步即时库存数据:{}年,{}月,{}周",year,month,weekOfMonth);
  298. K3CloudApi client = new K3CloudApi(initIden());
  299. int startRow = 0;
  300. int limit = 2000;
  301. BillQuery billQuery = new BillQuery();
  302. billQuery.setLimit(limit);
  303. billQuery.setFormId("STK_Inventory");
  304. billQuery.setFieldKeys("FMaterialID.FNumber,FMaterialID.FName,FMaterialID.FSpecification,FMaterialID.F_QUXZ_Assistant,FMaterialID.FSTOREURNOM,FMaterialID.FSTOREURNUM,FMaterialID.FZJ,FStockId,FStockId.FName,FLot,FLot.FName,FStockUnitId,FStockUnitId.FName,FBaseQty,FStockStatusId.FName");
  305. List<Map> filterString = new ArrayList<>();
  306. //仓库等于成品仓或组装半成品仓
  307. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FStockName","338","成品仓,组装半成品仓","","","0"));//仓库名称 IN XX
  308. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FBaseQty","21",0,"","","0"));//库存量(主单位) > 0
  309. billQuery.setFilterString(filterString);
  310. List<Map> result = new ArrayList<>();
  311. List<Map> list = new ArrayList<>();
  312. do {
  313. billQuery.setStartRow(startRow);
  314. String s = client.billQuery(JSONObject.toJSONString(billQuery));
  315. result = (List<Map>)JSONObject.parse(s);
  316. list.addAll(result);
  317. startRow += limit;
  318. }while (result.size() == limit);
  319. List<Map> originList = new ArrayList<>();
  320. for (Map map : list) {
  321. Map formData = new HashMap();
  322. String FMaterialNumber = UtilMap.getString(map,"FMaterialID.FNumber");//物料编码
  323. String FMaterialName = UtilMap.getString(map,"FMaterialID.FName");//物料名称
  324. String FMaterialSpecification = UtilMap.getString(map,"FMaterialID.FSpecification");//物料规格
  325. String FQUXZAssistant = Objects.nonNull(map.get("FMaterialID.F_QUXZ_Assistant")) ? UtilMap.getString(map,"FMaterialID.F_QUXZ_Assistant") : "--";//所属系列
  326. String Fzj = UtilMap.getString(map,"FMaterialID.FZJ");//组件
  327. String FStockName = UtilMap.getString(map,"FStockId.FName");//仓库名称
  328. String FLotName = UtilMap.getString(map,"FLot.FName");//批号
  329. String FStockUnitName = UtilMap.getString(map,"FStockUnitId.FName");//库存主单位
  330. Double FBaseQty = UtilMap.getDouble(map,"FBaseQty");//库存数量
  331. String FStockStatusName = UtilMap.getString(map,"FStockStatusId.FName");//库存状态
  332. Double FSTOREURNOM = UtilMap.getDouble(map, "FMaterialID.FSTOREURNOM");
  333. Double FSTOREURNUM = UtilMap.getDouble(map, "FMaterialID.FSTOREURNUM");
  334. if ("组装半成品仓".equals(FStockName)){
  335. if (FMaterialName.contains("组件") && !FMaterialName.contains("面板") && !FMaterialName.contains("包装")){
  336. }else {
  337. continue;
  338. }
  339. }
  340. Double FQty = FBaseQty * FSTOREURNOM / FSTOREURNUM;//库存量(主单位)
  341. formData.put("textField_mfarr0ei",FMaterialNumber);
  342. formData.put("textField_mfarr0en",FMaterialName);
  343. formData.put("textField_mfarr0eo",FMaterialSpecification);
  344. formData.put("textField_mflwgj61", FQUXZAssistant);
  345. formData.put("textField_mipr1qrc", Fzj);
  346. formData.put("textField_mfarr0et",FStockName);
  347. formData.put("textField_mfarr0eu",FLotName);
  348. formData.put("textField_mfarr0ev",FStockUnitName);
  349. formData.put("numberField_mfarr0f2",FQty);
  350. formData.put("textField_mfarr0f4",FStockStatusName);
  351. formData.put("numberField_mev270x6",year);
  352. formData.put("numberField_mev270x5",month);
  353. formData.put("textField_mev2ers5",weekOfMonth);
  354. ydClient.operateData(YDParam.builder()
  355. .formUuid("FORM-06C833A3B1804929987033DD6B0E7B2F73JP")
  356. .formDataJson(JSONObject.toJSONString(formData))
  357. .build(), YDConf.FORM_OPERATION.create);
  358. Map origin = new HashMap();
  359. origin.put("ck",FStockName);
  360. origin.put("ssxl",FQUXZAssistant);
  361. origin.put("value",FQty);
  362. originList.add(origin);
  363. }
  364. log.info("同步即时库存数据结束:{}年,{}月,{}周",year,month,weekOfMonth);
  365. //删除宜搭历史最新库存信息
  366. List<Map> data = (List<Map>) ydClient.queryData(YDParam.builder()
  367. .formUuid("FORM-35A70C47B4904437B05935AC0B23F981TR4B")
  368. .searchFieldJson(JSONObject.toJSONString(UtilMap.map("numberField_mev270x6, numberField_mev270x5",Arrays.asList(year,year), Arrays.asList(month,month))))
  369. .build(), YDConf.FORM_QUERY.retrieve_list).getData();
  370. List<String> formInstanceIdList = new ArrayList<>();
  371. for (Map datum : data) {
  372. formInstanceIdList.add(UtilMap.getString(datum,"formInstanceId"));
  373. }
  374. if (!formInstanceIdList.isEmpty()){
  375. ydClient.operateData(YDParam.builder()
  376. .formUuid("FORM-35A70C47B4904437B05935AC0B23F981TR4B")
  377. .formInstanceIdList(formInstanceIdList)
  378. .build(), YDConf.FORM_OPERATION.delete_batch);
  379. }
  380. List<Map> data2 = (List<Map>) ydClient.queryData(YDParam.builder()
  381. .formUuid("FORM-842BAB01084747E5B7E0811A16BE6AA56FUH")
  382. .searchFieldJson(JSONObject.toJSONString(UtilMap.map("numberField_mev270x6",Arrays.asList(year,year))))
  383. .build(), YDConf.FORM_QUERY.retrieve_list).getData();
  384. List<String> formInstanceIdList2 = new ArrayList<>();
  385. for (Map datum : data2) {
  386. formInstanceIdList2.add(UtilMap.getString(datum,"formInstanceId"));
  387. }
  388. if (!formInstanceIdList2.isEmpty()){
  389. ydClient.operateData(YDParam.builder()
  390. .formUuid("FORM-842BAB01084747E5B7E0811A16BE6AA56FUH")
  391. .formInstanceIdList(formInstanceIdList2)
  392. .build(), YDConf.FORM_OPERATION.delete_batch);
  393. }
  394. //将最新库存信息写入宜搭
  395. List<Map> grouprList = originList.stream()
  396. .collect(Collectors.groupingBy(
  397. item -> Arrays.asList(
  398. item.get("ck"),
  399. item.get("ssxl")
  400. ),
  401. Collectors.summingDouble(item -> UtilMap.getDouble(item, "value"))
  402. )).entrySet()
  403. .stream()
  404. .map(entry -> {
  405. // 将分组键(List<Object>)和汇总值转换为 Map
  406. List<Object> key = entry.getKey();
  407. Map<String, Object> groupedItem = new LinkedHashMap<>();
  408. groupedItem.put("textField_mfarr0et", key.get(0));
  409. groupedItem.put("textField_mflwgj61", key.get(1));
  410. groupedItem.put("numberField_mev270x6", year);
  411. groupedItem.put("numberField_mev270x5", month);
  412. groupedItem.put("numberField_mfarr0f2", entry.getValue());
  413. return groupedItem;
  414. }).collect(Collectors.toList());
  415. for (Map groupMap : grouprList) {
  416. ydClient.operateData(YDParam.builder()
  417. .formUuid("FORM-35A70C47B4904437B05935AC0B23F981TR4B")
  418. .formDataJson(JSONObject.toJSONString(groupMap))
  419. .build(), YDConf.FORM_OPERATION.create);
  420. ydClient.operateData(YDParam.builder()
  421. .formUuid("FORM-842BAB01084747E5B7E0811A16BE6AA56FUH")
  422. .formDataJson(JSONObject.toJSONString(groupMap))
  423. .build(), YDConf.FORM_OPERATION.create);
  424. }
  425. //更新看板更新记录
  426. ydClient.operateData(YDParam.builder()
  427. .formInstId(formInstId)
  428. .updateFormDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mhsjnn2r, dateField_mhsjnn2t", "已完成", System.currentTimeMillis())))
  429. .build(), YDConf.FORM_OPERATION.update);
  430. }catch (Exception e){
  431. //更新看板更新记录
  432. ydClient.operateData(YDParam.builder()
  433. .formInstId(formInstId)
  434. .updateFormDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mhsjnn2r, dateField_mhsjnn2t, textareaField_mir0zmpo", "异常", System.currentTimeMillis(),e.getMessage())))
  435. .build(), YDConf.FORM_OPERATION.update);
  436. throw new RuntimeException(e);
  437. }
  438. }
  439. //定时同步昨日到今天的
  440. @Override
  441. public void syncPRDReturnMtrl(String userId) {
  442. MDC.put("MDC_KEY_PID","1002");
  443. log.info("开始同步生产退料明细");
  444. //创建看板更新记录
  445. if (Strings.isBlank(userId)){
  446. userId = "yida_pub_account";
  447. }
  448. //创建看板更新记录
  449. String formInstId = ydClient.operateData(YDParam.builder()
  450. .formUuid("FORM-0BEA655A36724D509A2CF21C4BA38D367YF7")
  451. .formDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mfmhvkey, selectField_mhsjnn2r, dateField_mhsjnn2s, employeeField_mhswy0xy", "不良物料退库统计看板", "更新中", System.currentTimeMillis(),Arrays.asList(userId))))
  452. .build(), YDConf.FORM_OPERATION.create).toString();
  453. try {
  454. K3CloudApi client = new K3CloudApi(initIden());
  455. int startRow = 0;
  456. int limit = 2000;
  457. BillQuery billQuery = new BillQuery();
  458. billQuery.setLimit(limit);
  459. billQuery.setFormId("PRD_ReturnMtrl");
  460. billQuery.setFieldKeys("FBillNo,FDate,FPPBOMEntryId,FMaterialId.FNumber,FMaterialId.FName,FMaterialId.FSpecification,FMaterialId.FDefaultVendor,FReturnType,FQty");
  461. List<Map> filterString = new ArrayList<>();
  462. //审核日期为昨日到现在且单据状态等于已审核
  463. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FApproveDate","265",1,"","","0"));//审核日期在今天之前XX天之后
  464. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FDocumentStatus","105","C","","","0"));//单据状态等于XX
  465. // filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FApproveDate","420","2025-01-01","","","0"));//审核日期等于XX年
  466. billQuery.setFilterString(filterString);
  467. List<Map> result = new ArrayList<>();
  468. List<Map> list = new ArrayList<>();
  469. do {
  470. billQuery.setStartRow(startRow);
  471. result = (List<Map>)JSONObject.parse(client.billQuery(JSONObject.toJSONString(billQuery)));
  472. list.addAll(result);
  473. startRow += limit;
  474. }while (result.size() == limit);
  475. for (Map map : list) {
  476. Map formData = new HashMap();
  477. String fBillNo = UtilMap.getString(map, "FBillNo");
  478. formData.put("textField_mfm7o4wb", fBillNo);//单据编号
  479. String fDate = UtilMap.getString(map, "FDate");
  480. // 解析字符串为 LocalDateTime
  481. LocalDateTime localDateTime = LocalDateTime.parse(fDate);
  482. // 将 LocalDateTime 转换为 ZonedDateTime
  483. ZonedDateTime zonedDateTime = localDateTime.atZone(ZoneId.systemDefault());
  484. formData.put("dateField_mfm7o4wc", zonedDateTime.toInstant().toEpochMilli());//单据日期
  485. String fppbomEntryId = UtilMap.getString(map, "FPPBOMEntryId");
  486. formData.put("textField_mfmaqppu", fppbomEntryId);//分录明细id
  487. formData.put("textField_mfm7o4we", UtilMap.getString(map,"FMaterialId.FNumber"));//物料编码
  488. formData.put("textField_mfm7o4wf", UtilMap.getString(map,"FMaterialId.FName"));//物料名称
  489. formData.put("textField_mfm7o4wg", UtilMap.getString(map,"FMaterialId.FSpecification"));//物料规格
  490. formData.put("textField_mfq6bwfl", UtilMap.getString(map,"FMaterialId.FDefaultVendor"));//默认供应商
  491. //退料类型
  492. String type = UtilMap.getString(map, "FReturnType");
  493. String typeValue = "";
  494. switch (type){
  495. case "1": typeValue = "良品退料";break;
  496. case "2": typeValue = "来料不良退料";break;
  497. case "3": typeValue = "作业不良退料";break;
  498. default:break;
  499. }
  500. formData.put("textField_mfm7o4wh", typeValue);
  501. formData.put("numberField_mfm7o4wj", UtilMap.getDouble(map,"FQty"));//退料数量
  502. ydClient.operateData(YDParam.builder()
  503. .formUuid("FORM-D21383AF87AC48BEB577485C37F46E8FUAIK")
  504. .searchCondition(JSONObject.toJSONString(UtilMap.map("textField_mfm7o4wb, textField_mfmaqppu, textField_mfm7o4wh",fBillNo,fppbomEntryId,typeValue)))
  505. .formDataJson(JSONObject.toJSONString(formData))
  506. .build(), YDConf.FORM_OPERATION.upsert);
  507. }
  508. //更新看板更新记录
  509. ydClient.operateData(YDParam.builder()
  510. .formInstId(formInstId)
  511. .updateFormDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mhsjnn2r, dateField_mhsjnn2t", "已完成", System.currentTimeMillis())))
  512. .build(), YDConf.FORM_OPERATION.update);
  513. }catch (Exception e){
  514. //更新看板更新记录
  515. ydClient.operateData(YDParam.builder()
  516. .formInstId(formInstId)
  517. .updateFormDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mhsjnn2r, dateField_mhsjnn2t, textareaField_mir0zmpo", "异常", System.currentTimeMillis(),e.getMessage())))
  518. .build(), YDConf.FORM_OPERATION.update);
  519. throw new RuntimeException(e);
  520. }
  521. }
  522. @Async
  523. @Override
  524. public void syncReport(String type,String userId) {
  525. MDC.put("MDC_KEY_PID","1002");
  526. try {
  527. switch (type){
  528. case "成品库存天数看板": syncBDSerialMainFile(userId);break;
  529. case "成品/组件库存看板": syncSTKInventory(userId);break;
  530. case "不良物料退库统计看板": syncPRDReturnMtrl(userId);break;
  531. case "成品/样机出库看板": syncDLVNotice(userId);break;
  532. default:break;
  533. }
  534. //发送工作通知
  535. if (Objects.nonNull(userId)){
  536. sendDdMsg(ddClient.getAccessToken(),ddConf.getAgentId(),userId,"更新" + type + "完成 时间:" + DateUtil.format(new Date(),"yyyy-MM-dd HH:mm:ss"));
  537. }
  538. }catch (Exception e){
  539. //发送工作通知
  540. if (Objects.nonNull(userId)){
  541. sendDdMsg(ddClient.getAccessToken(),ddConf.getAgentId(),userId,"更新" + type + "异常:" + e.getMessage() + " 时间:" + DateUtil.format(new Date(),"yyyy-MM-dd HH:mm:ss"));
  542. }
  543. throw new RuntimeException(e);
  544. }
  545. }
  546. @Override
  547. public void syncPendingProducts() {
  548. MDC.put("MDC_KEY_PID","1002");
  549. // 获取当前日期
  550. LocalDate today = LocalDate.now();
  551. int year = today.getYear();//获取当前年份
  552. int month = today.getMonthValue();//当前月份
  553. WeekFields weekFields = WeekFields.of(Locale.getDefault());
  554. int weekOfMonth = today.get(weekFields.weekOfMonth());//当前日期是当月的第几周
  555. /*int year = 2025;//获取当前年份
  556. int month = 9;//当前月份
  557. int weekOfMonth = 4;//当前日期是当月的第几周*/
  558. DDR_New ddrNew = new DDR_New();
  559. int pageSize = 100;
  560. int pageNumber = 0;
  561. List<Map> list = new ArrayList<>();
  562. do {
  563. pageNumber++;
  564. ddrNew = ydClient.queryData(YDParam.builder()
  565. .formUuid("FORM-C4751EF730D74299A0449E40C2601AE5L2BU")
  566. .searchCondition(JSONObject.toJSONString(UtilMap.map("numberField_mev270x6, numberField_mev270x5, textField_mev2ers5", Arrays.asList(year,year), Arrays.asList(month,month), weekOfMonth)))
  567. .pageNumber(pageNumber)
  568. .pageSize(pageSize)
  569. .build(), YDConf.FORM_QUERY.retrieve_list);
  570. List<Map> data = (List<Map>) ddrNew.getData();
  571. for (Map datum : data) {
  572. list.add(UtilMap.getMap(datum,"formData"));
  573. }
  574. }while (ddrNew.getPageNumber() * pageSize < ddrNew.getTotalCount());
  575. //删除宜搭历史最新库存信息
  576. List<Map> data = (List<Map>) ydClient.queryData(YDParam.builder()
  577. .formUuid("FORM-BC40899D61134DDFB80E6C693E9EA930Y6NW")
  578. .searchFieldJson(JSONObject.toJSONString(UtilMap.map("numberField_mev270x6, numberField_mev270x5",Arrays.asList(year,year), Arrays.asList(month,month))))
  579. .build(), YDConf.FORM_QUERY.retrieve_list).getData();
  580. List<String> formInstanceIdList = new ArrayList<>();
  581. for (Map datum : data) {
  582. formInstanceIdList.add(UtilMap.getString(datum,"formInstanceId"));
  583. }
  584. if (!formInstanceIdList.isEmpty()){
  585. ydClient.operateData(YDParam.builder()
  586. .formUuid("FORM-BC40899D61134DDFB80E6C693E9EA930Y6NW")
  587. .formInstanceIdList(formInstanceIdList)
  588. .build(), YDConf.FORM_OPERATION.delete_batch);
  589. }
  590. List<Map> data2 = (List<Map>) ydClient.queryData(YDParam.builder()
  591. .formUuid("FORM-28F9CA5CEBFA488A83B1A20721692B6CD3P8")
  592. .searchFieldJson(JSONObject.toJSONString(UtilMap.map("numberField_mev270x6",Arrays.asList(year,year))))
  593. .build(), YDConf.FORM_QUERY.retrieve_list).getData();
  594. List<String> formInstanceIdList2 = new ArrayList<>();
  595. for (Map datum : data2) {
  596. formInstanceIdList2.add(UtilMap.getString(datum,"formInstanceId"));
  597. }
  598. if (!formInstanceIdList2.isEmpty()){
  599. ydClient.operateData(YDParam.builder()
  600. .formUuid("FORM-28F9CA5CEBFA488A83B1A20721692B6CD3P8")
  601. .formInstanceIdList(formInstanceIdList2)
  602. .build(), YDConf.FORM_OPERATION.delete_batch);
  603. }
  604. //将最新库存信息写入宜搭
  605. List<Map> grouprList = list.stream()
  606. .collect(Collectors.groupingBy(
  607. item -> Arrays.asList(
  608. item.get("textField_mfes8fg5")
  609. ),
  610. Collectors.summingDouble(item -> UtilMap.getDouble(item, "numberField_mfes8fg7"))
  611. )).entrySet()
  612. .stream()
  613. .map(entry -> {
  614. // 将分组键(List<Object>)和汇总值转换为 Map
  615. List<Object> key = entry.getKey();
  616. Map<String, Object> groupedItem = new LinkedHashMap<>();
  617. groupedItem.put("textField_mfes8fg5", key.get(0));
  618. groupedItem.put("numberField_mev270x6", year);
  619. groupedItem.put("numberField_mev270x5", month);
  620. groupedItem.put("numberField_mfes8fg7", entry.getValue());
  621. return groupedItem;
  622. }).collect(Collectors.toList());
  623. for (Map groupMap : grouprList) {
  624. ydClient.operateData(YDParam.builder()
  625. .formUuid("FORM-BC40899D61134DDFB80E6C693E9EA930Y6NW")
  626. .formDataJson(JSONObject.toJSONString(groupMap))
  627. .build(), YDConf.FORM_OPERATION.create);
  628. ydClient.operateData(YDParam.builder()
  629. .formUuid("FORM-28F9CA5CEBFA488A83B1A20721692B6CD3P8")
  630. .formDataJson(JSONObject.toJSONString(groupMap))
  631. .build(), YDConf.FORM_OPERATION.create);
  632. }
  633. }
  634. @Override
  635. public void syncDLVNotice(String userId) {
  636. MDC.put("MDC_KEY_PID","1002");
  637. log.info("开始同步发货通知单");
  638. //创建看板更新记录
  639. if (Strings.isBlank(userId)){
  640. userId = "yida_pub_account";
  641. }
  642. //创建看板更新记录
  643. String formInstId = ydClient.operateData(YDParam.builder()
  644. .formUuid("FORM-0BEA655A36724D509A2CF21C4BA38D367YF7")
  645. .formDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mfmhvkey, selectField_mhsjnn2r, dateField_mhsjnn2s, employeeField_mhswy0xy", "成品/样机出库看板", "更新中", System.currentTimeMillis(),Arrays.asList(userId))))
  646. .build(), YDConf.FORM_OPERATION.create).toString();
  647. try {
  648. K3CloudApi client = new K3CloudApi(initIden());
  649. int startRow = 0;
  650. int limit = 2000;
  651. BillQuery billQuery = new BillQuery();
  652. billQuery.setLimit(limit);
  653. billQuery.setFormId("SAL_DELIVERYNOTICE");
  654. billQuery.setFieldKeys("FBillNo,FDate,FCustomerID.FName,F_QUXZ_Assistant.FNumber,FEntity_FEntryID,FMaterialId.FNumber,FMaterialId.FName,FMaterialId.FSpecification,FMaterialId.F_QUXZ_Assistant,FUnitID.FName,FQty,FIsFree,FHGZBDay.FNumber,FStockID.FName");
  655. List<Map> filterString = new ArrayList<>();
  656. //审核日期为昨日到现在且单据状态等于已审核且明细收件人电话不为空
  657. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FApproveDate","265",1,"","","0"));//审核日期在今天之前XX天之后
  658. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FDocumentStatus","105","C","","","0"));//单据状态等于XX
  659. // filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FHGReceiveDZ","52","","","","0"));//明细收件人地址不为空
  660. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FHGReceiveDh","52","","","","0"));//明细收件人电话不为空
  661. // filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FApproveDate","420","2025-01-01","","","0"));//审核日期等于XX年
  662. // filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FApproveDate","63","","","","0"));//审核日期等于本月
  663. billQuery.setFilterString(filterString);
  664. List<Map> result = new ArrayList<>();
  665. List<Map> list = new ArrayList<>();
  666. do {
  667. billQuery.setStartRow(startRow);
  668. result = (List<Map>)JSONObject.parse(client.billQuery(JSONObject.toJSONString(billQuery)));
  669. list.addAll(result);
  670. startRow += limit;
  671. }while (result.size() == limit);
  672. for (Map map : list) {
  673. Map formData = new HashMap();
  674. String fBillNo = UtilMap.getString(map, "FBillNo");
  675. formData.put("textField_mfqf1fj5", fBillNo);//单据编号
  676. String fDate = UtilMap.getString(map, "FDate");
  677. // 解析字符串为 LocalDateTime
  678. LocalDateTime localDateTime = LocalDateTime.parse(fDate);
  679. // 将 LocalDateTime 转换为 ZonedDateTime
  680. ZonedDateTime zonedDateTime = localDateTime.atZone(ZoneId.systemDefault());
  681. //localDateTime是当月的第几周
  682. int week = localDateTime.get(WeekFields.ISO.weekOfWeekBasedYear());
  683. formData.put("dateField_mfqf1fj4", zonedDateTime.toInstant().toEpochMilli());//单据日期
  684. formData.put("textField_mfqf1fj6",UtilMap.getString(map,"FCustomerID.FName"));//客户名称
  685. String F_QUXZ_AssistantFNumber = UtilMap.getString(map, "F_QUXZ_Assistant.FNumber");
  686. String F_QUXZ_Assistant = "";
  687. switch (F_QUXZ_AssistantFNumber){
  688. case "01": F_QUXZ_Assistant = "正常订单";break;
  689. case "02": F_QUXZ_Assistant = "样机订单";break;
  690. case "03": F_QUXZ_Assistant = "租赁订单";break;
  691. case "04": F_QUXZ_Assistant = "维修订单";break;
  692. case "05": F_QUXZ_Assistant = "研发订单";break;
  693. case "06": F_QUXZ_Assistant = "服务订单";break;
  694. case "10": F_QUXZ_Assistant = "营销支持";break;
  695. case "JD": F_QUXZ_Assistant = "京东订单";break;
  696. case "SHZY": F_QUXZ_Assistant = "售后专用";break;
  697. case "TM": F_QUXZ_Assistant = "天猫订单";break;
  698. default:break;
  699. }
  700. formData.put("textField_mfqhmwpu", F_QUXZ_Assistant);//销售类型
  701. String fEntityFEntryID = UtilMap.getString(map, "FEntity_FEntryID");
  702. formData.put("textField_mfqf1fjm", fEntityFEntryID);//销售订单分录id
  703. formData.put("textField_mfqf1fj7", UtilMap.getString(map,"FMaterialId.FNumber"));//物料编码
  704. formData.put("textField_mfqf1fj8", UtilMap.getString(map,"FMaterialId.FName"));//物料名称
  705. formData.put("textField_mfqf1fj9", UtilMap.getString(map,"FMaterialId.FSpecification"));//物料规格
  706. formData.put("textField_mfqf1fk3", UtilMap.getString(map,"FMaterialId.F_QUXZ_Assistant"));//所属系列
  707. formData.put("textField_mfqf1fjb", UtilMap.getString(map,"FUnitID.FName"));//销售单位
  708. formData.put("numberField_mfqf1fjd", UtilMap.getDouble(map,"FQty"));//销售数量
  709. formData.put("textField_mfqf1fjh", UtilMap.getBoolean(map,"FIsFree") ? "是" : "否");//是否赠品
  710. formData.put("textField_mfqf1fjj", UtilMap.getString(map,"FStockID.FName"));//出货仓库
  711. String FHGZBDayFNumber = UtilMap.getString(map, "FHGZBDay.FNumber");
  712. String FHGZBDay = "";
  713. switch (FHGZBDayFNumber){
  714. case "01": FHGZBDay = "1年";break;
  715. case "02": FHGZBDay = "2年";break;
  716. case "03": FHGZBDay = "3年";break;
  717. case "04": FHGZBDay = "4年";break;
  718. case "05": FHGZBDay = "5年";break;
  719. case "06": FHGZBDay = "15";break;
  720. case "07": FHGZBDay = "27";break;
  721. default:break;
  722. }
  723. formData.put("textField_mfqhmwpv", FHGZBDay);//质保期
  724. formData.put("textField_mfqithiv",getWeekOfMonth(localDateTime));//所属周
  725. ydClient.operateData(YDParam.builder()
  726. .formUuid("FORM-F7DB6FC6E47949A98BDD3DC344B3CBC1V7HY")
  727. .searchCondition(JSONObject.toJSONString(UtilMap.map("textField_mfqf1fj5, textField_mfqf1fjm",fBillNo,fEntityFEntryID)))
  728. .formDataJson(JSONObject.toJSONString(formData))
  729. .build(), YDConf.FORM_OPERATION.upsert);
  730. }
  731. //更新看板更新记录
  732. ydClient.operateData(YDParam.builder()
  733. .formInstId(formInstId)
  734. .updateFormDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mhsjnn2r, dateField_mhsjnn2t", "已完成", System.currentTimeMillis())))
  735. .build(), YDConf.FORM_OPERATION.update);
  736. }catch (Exception e){
  737. //更新看板更新记录
  738. ydClient.operateData(YDParam.builder()
  739. .formInstId(formInstId)
  740. .updateFormDataJson(JSONObject.toJSONString(UtilMap.map("selectField_mhsjnn2r, dateField_mhsjnn2t, textareaField_mir0zmpo", "异常", System.currentTimeMillis(),e.getMessage())))
  741. .build(), YDConf.FORM_OPERATION.update);
  742. throw new RuntimeException(e);
  743. }
  744. }
  745. @Override
  746. public void syncPUROrder(String userId) {
  747. MDC.put("MDC_KEY_PID","1003");
  748. log.info("开始同步采购订单");
  749. try {
  750. K3CloudApi client = new K3CloudApi(initIden());
  751. int startRow = 0;
  752. int limit = 2000;
  753. BillQuery billQuery = new BillQuery();
  754. billQuery.setLimit(limit);
  755. billQuery.setFormId("PUR_PurchaseOrder");
  756. billQuery.setFieldKeys("FBillNo,FBillTypeID.FName,FBusinessType,FDate,FSupplierId.FName,FSupplierId.FADDRESS,FProviderContactId.FName,FProviderContactId.FPost,FProviderContactId.FMobile,FPurchaserId.FName,FPurchaseDeptId.FName,FHGDBLX.FDataValue,FACCTYPE,FHGDBLX1.FDataValue,FHGFkJhDate,FChangeReason,FMaterialId.FNumber,FMaterialId.FName,FMaterialId.FSpecification,FUnitId.FName,FQty,FPriceUnitId.FName,FPriceUnitQty,FDeliveryDate,FPrice,FTaxPrice,FEntryTaxRate,FEntryTaxAmount,FAllAmount,FEntryAmount,FEntryNote");
  757. List<Map> filterString = new ArrayList<>();
  758. //单据状态等于已审核且修改日期为昨天至今天
  759. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FDocumentStatus","105","C","","","0"));//单据状态等于XX
  760. filterString.add(UtilMap.map("FieldName, Compare, Value, Left, Right, Logic","FModifyDate","265",10,"","","0"));//修改日期在今天之前XX天之后
  761. billQuery.setFilterString(filterString);
  762. List<Map> result = new ArrayList<>();
  763. List<Map> list = new ArrayList<>();
  764. do {
  765. billQuery.setStartRow(startRow);
  766. result = (List<Map>)JSONObject.parse(client.billQuery(JSONObject.toJSONString(billQuery)));
  767. list.addAll(result);
  768. startRow += limit;
  769. }while (result.size() == limit);
  770. System.out.println(list);
  771. List<Map<String,Object>> data = new ArrayList<>();
  772. for (Map map : list) {
  773. Map formData = new HashMap();
  774. String fBillNo = UtilMap.getString(map,"FBillNo");//单据编号
  775. String fBillType = UtilMap.getString(map,"FBillTypeID.FName");//单据类型
  776. String fBusinessType = UtilMap.getString(map, "FBusinessType");//业务类型
  777. String fBusinessTypeValue = "";
  778. switch (fBusinessType){
  779. case "DRPCG": fBusinessTypeValue = "分销购销";break;
  780. case "WW": fBusinessTypeValue = "标准委外";break;
  781. case "FYCG": fBusinessTypeValue = "费用采购";break;
  782. case "ZCCG": fBusinessTypeValue = "资产采购";break;
  783. case "ZYCG": fBusinessTypeValue = "直运采购";break;
  784. case "VMICG": fBusinessTypeValue = "VMI采购";break;
  785. case "cscg": fBusinessTypeValue = "测试采购";break;
  786. case "CG": fBusinessTypeValue = "标准采购";break;
  787. default:break;
  788. }
  789. long fDate = convertKdDate(UtilMap.getString(map, "FDate"));//采购日期
  790. String fSupplier = UtilMap.getString(map, "FSupplierId.FName");//供应商
  791. String fSupplierAddress = UtilMap.getString(map, "FSupplierId.FADDRESS");//供应商地址
  792. String fProviderContact = UtilMap.getString(map, "FProviderContactId.FName");//供应商联系人
  793. String fProviderContactPost = UtilMap.getString(map, "FProviderContactId.FPost");//供应商联系人职务
  794. String fProviderContactMobile = UtilMap.getString(map, "FProviderContactId.FMobile");//供应商联系人电话
  795. String fPurchaser = UtilMap.getString(map, "FPurchaserId.FName");//采购员
  796. String fPurchaseDept = UtilMap.getString(map, "FPurchaseDeptId.FName");//采购部门
  797. String fHGDBLX = UtilMap.getString(map, "FHGDBLX.FDataValue");//订单类型
  798. String fACCTYPE = UtilMap.getString(map, "FACCTYPE");//验收方式
  799. String fACCTYPEValue = "";
  800. switch (fACCTYPE){
  801. case "A": fACCTYPEValue = "金额验收";break;
  802. case "Q": fACCTYPEValue = "数量验收";break;
  803. case "R": fACCTYPEValue = "比例验收";break;
  804. }
  805. String fHGDBLX1 = UtilMap.getString(map, "FHGDBLX1.FDataValue");//采购类型
  806. // long fHGFkJhDate = convertKdDate(UtilMap.getString(map, "FHGFkJhDate"));//付款计划日期
  807. String fChangeReason = UtilMap.getString(map, "FChangeReason");//变更原因
  808. formData.put("textField_mizdd3p4",fBillNo);
  809. formData.put("textField_mizdd3p0",fBillType);
  810. formData.put("textField_mizdd3p3",fBusinessTypeValue);
  811. formData.put("textField_mizdd3p2",fPurchaser);
  812. formData.put("textField_mizdd3p5",fPurchaseDept);
  813. formData.put("dateField_mizdd3p6",fDate);
  814. formData.put("textField_mizdd3p7",fHGDBLX);
  815. formData.put("textField_mizdd3p8",fHGDBLX1);
  816. formData.put("textField_mizdd3p9",fACCTYPEValue);
  817. formData.put("dateField_mizdd3pa",Objects.nonNull(map.get("FHGFkJhDate")) ? convertKdDate(UtilMap.getString(map,"FHGFkJhDate")) : null);
  818. formData.put("textareaField_mizdd3pb",fChangeReason);
  819. formData.put("textField_mizdd3p1",fSupplier);
  820. formData.put("textField_mizdd3pg",fProviderContact);
  821. formData.put("textField_mizdd3pi",fProviderContactPost);
  822. formData.put("textField_mizdd3pk",fProviderContactMobile);
  823. formData.put("textField_mizdd3pm",fSupplierAddress);
  824. formData.put("selectField_mjs0s3ku","未完成");
  825. Map detail = new HashMap();
  826. detail.put("textField_mizdd3qg",UtilMap.getString(map,"FMaterialId.FNumber"));
  827. detail.put("textField_mizdd3qh",UtilMap.getString(map,"FMaterialId.FName"));
  828. detail.put("textField_mizdd3qi",UtilMap.getString(map,"FMaterialId.FSpecification"));
  829. detail.put("textField_mizdd3qj",UtilMap.getString(map,"FUnitId.FName"));
  830. detail.put("numberField_mizdd3ql",UtilMap.getDouble(map,"FQty"));
  831. detail.put("textField_mizdd3qk",UtilMap.getString(map,"FPriceUnitId.FName"));
  832. detail.put("numberField_mizdd3qn",UtilMap.getDouble(map,"FPriceUnitQty"));
  833. detail.put("dateField_mizdd3qp",Objects.nonNull(map.get("FDeliveryDate")) ? convertKdDate(UtilMap.getString(map,"FDeliveryDate")) : null);
  834. detail.put("numberField_mizdd3qr",UtilMap.getDouble(map,"FPrice"));
  835. detail.put("numberField_mizdd3qs",UtilMap.getDouble(map,"FTaxPrice"));
  836. detail.put("numberField_mizdd3qv",UtilMap.getDouble(map,"FEntryTaxRate"));
  837. detail.put("numberField_mizdd3qw",UtilMap.getDouble(map,"FEntryTaxAmount"));
  838. detail.put("numberField_mizdd3qx",UtilMap.getDouble(map,"FAllAmount"));
  839. detail.put("numberField_mizdd3qy",UtilMap.getDouble(map,"FEntryAmount"));
  840. detail.put("textField_mizdd3r0",UtilMap.getString(map,"FEntryNote"));
  841. List<Map> details = new ArrayList<>();
  842. details.add(detail);
  843. formData.put("tableField_mizdd3qf",details);
  844. data.add(formData);
  845. }
  846. List<Map<String, Object>> data2 = mergeListMap(data, "textField_mizdd3p4", "tableField_mizdd3qf");
  847. for (Map<String, Object> objectMap : data2) {
  848. String fbillNo = UtilMap.getString(objectMap, "textField_mizdd3p4");
  849. ydClient.operateData(YDParam.builder()
  850. .formUuid("FORM-1F4DC1A20E86452699AEEC682CBBEB4CS9DF")
  851. .formDataJson(JSONObject.toJSONString(objectMap))
  852. .searchCondition(JSONObject.toJSONString(UtilMap.map("textField_mizdd3p4",fbillNo))).build(), YDConf.FORM_OPERATION.upsert);
  853. }
  854. //发送工作通知
  855. if (Objects.nonNull(userId)){
  856. sendDdMsg(ddClient.getAccessToken(),ddConf.getAgentId(),userId,"更新采购订单完成 时间:" + DateUtil.format(new Date(),"yyyy-MM-dd HH:mm:ss"));
  857. }
  858. }catch (Exception e){
  859. throw new RuntimeException(e);
  860. }
  861. }
  862. public static int getWeekOfMonth(LocalDateTime dateTime) {
  863. LocalDateTime date = dateTime.toLocalDate().atStartOfDay();
  864. // 获取当月第一天
  865. LocalDateTime firstDayOfMonth = date.with(TemporalAdjusters.firstDayOfMonth());
  866. // 获取当月第一天是星期几(1-7,周一到周日)
  867. int firstDayOfWeek = firstDayOfMonth.getDayOfWeek().getValue();
  868. // 计算当前日期是当月的第几天
  869. int dayOfMonth = date.getDayOfMonth();
  870. // 计算周数(ISO标准,周一为一周开始)
  871. // 第一周从1号开始,即使1号不是周一
  872. int week = ((dayOfMonth + firstDayOfWeek - 2) / 7) + 1;
  873. return week;
  874. }
  875. //发送工作通知
  876. public void sendDdMsg(String access_token,Number agent_id, String userid_list, String content){
  877. if (Objects.nonNull(userid_list)){
  878. Map param2 = new HashMap();
  879. param2.put("access_token",access_token);
  880. Map body3 = new HashMap();
  881. body3.put("agent_id",agent_id);
  882. body3.put("userid_list",userid_list);
  883. Map msg = new HashMap();
  884. msg.put("msgtype","text");
  885. //获取当前时间 精确到秒
  886. String time = DateUtil.format(new Date(),"yyyy-MM-dd HH:mm:ss");
  887. msg.put("text", UtilMap.map("content, aa",content,""));
  888. body3.put("msg",msg);
  889. UtilHttp.doPost("https://oapi.dingtalk.com/topapi/message/corpconversation/asyncsend_v2",null,param2,body3);
  890. }
  891. }
  892. private IdentifyInfo initIden(){
  893. //注意 1:此处不再使用参数形式传入用户名及密码等敏感信息,改为在登录配置文件中设置。
  894. //注意 2:必须先配置第三方系统登录授权信息后,再进行业务操作,详情参考各语言版本SDK介绍中的登录配置文件说明。
  895. //读取配置,初始化SDK
  896. IdentifyInfo iden = new IdentifyInfo();
  897. iden.setUserName(kdWebApiConf.getXKDApiUserName());
  898. iden.setAppId(kdWebApiConf.getXKDApiAppID());
  899. iden.setdCID(kdWebApiConf.getXKDApiAcctID());
  900. iden.setAppSecret(kdWebApiConf.getXKDApiAppSec());
  901. iden.setServerUrl(kdWebApiConf.getXKDApiServerUrl());
  902. return iden;
  903. }
  904. private boolean isTrue(RepoRet repoRet){
  905. Gson gson = new Gson();
  906. if (repoRet.getResult().getResponseStatus().isIsSuccess()) {
  907. System.out.printf("接口返回结果: %s%n", gson.toJson(repoRet.getResult()));
  908. return true;
  909. } else {
  910. fail("接口返回结果: " + gson.toJson(repoRet.getResult().getResponseStatus()));
  911. return false;
  912. }
  913. }
  914. private String getMultiLanguageTextName(Object object){
  915. if (Objects.nonNull(object)){
  916. Map map = (Map) object;
  917. List<Map> multiLanguageText = (List<Map>) map.get("MultiLanguageText");
  918. String value = UtilMap.getString(multiLanguageText.get(0),"Name");
  919. return value;
  920. }
  921. return null;
  922. }
  923. private String getMultiLanguageTextSpecification(Object object){
  924. if (Objects.nonNull(object)){
  925. Map map = (Map) object;
  926. List<Map> multiLanguageText = (List<Map>) map.get("MultiLanguageText");
  927. String value = UtilMap.getString(multiLanguageText.get(0),"Specification");
  928. return value;
  929. }
  930. return null;
  931. }
  932. private String getNumber(Object object){
  933. if (Objects.nonNull(object)){
  934. Map map = (Map) object;
  935. String value = UtilMap.getString(map,"Number");
  936. return value;
  937. }
  938. return null;
  939. }
  940. public static List<Map<String, Object>> mergeListMap(List<Map<String, Object>> originalList,String key,String list) {
  941. // 使用 Map 来临时存储合并后的结果,key 为 code,value 为合并后的 Map
  942. Map<String, Map<String, Object>> mergedMap = new HashMap<>();
  943. for (Map<String, Object> item : originalList) {
  944. String code = (String) item.get(key);
  945. @SuppressWarnings("unchecked")
  946. List<Map<String, Object>> details = (List<Map<String, Object>>) item.get(list);
  947. if (mergedMap.containsKey(code)) {
  948. // 如果已存在该 code,只合并 details
  949. Map<String, Object> existingItem = mergedMap.get(code);
  950. @SuppressWarnings("unchecked")
  951. List<Map<String, Object>> existingDetails = (List<Map<String, Object>>) existingItem.get(list);
  952. existingDetails.addAll(details);
  953. } else {
  954. // 如果不存在该 key,保存整个 Map(包括其他 key)
  955. // 但需要深拷贝 list,避免后续修改影响原始数据
  956. Map<String, Object> newItem = new HashMap<>();
  957. for (Map.Entry<String, Object> entry : item.entrySet()) {
  958. if ("details".equals(entry.getKey())) {
  959. // 深拷贝 details 列表
  960. @SuppressWarnings("unchecked")
  961. List<Map<String, Object>> originalDetails = (List<Map<String, Object>>) entry.getValue();
  962. newItem.put(entry.getKey(), new ArrayList<>(originalDetails));
  963. } else {
  964. newItem.put(entry.getKey(), entry.getValue());
  965. }
  966. }
  967. mergedMap.put(code, newItem);
  968. }
  969. }
  970. // 转换回 List
  971. return new ArrayList<>(mergedMap.values());
  972. }
  973. private long convertKdDate(String fDate){
  974. // 解析字符串为 LocalDateTime
  975. LocalDateTime localDateTime = LocalDateTime.parse(fDate);
  976. // 将 LocalDateTime 转换为 ZonedDateTime
  977. ZonedDateTime zonedDateTime = localDateTime.atZone(ZoneId.systemDefault());
  978. long epochMilli = zonedDateTime.toInstant().toEpochMilli();
  979. return epochMilli;
  980. }
  981. }