TmstruckMeasureCommissionServiceImpl.java 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504
  1. package com.steerinfo.dil.service.impl;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.steerinfo.dil.mapper.RulesMapper;
  5. import com.steerinfo.dil.mapper.TmstruckMeasureCommissionMapper;
  6. import com.steerinfo.dil.mapper.UtilsMapper;
  7. import com.steerinfo.dil.model.TmstruckMeasureCommission;
  8. import com.steerinfo.dil.service.ITmstruckMeasureCommissionService;
  9. import com.steerinfo.dil.util.DataChange;
  10. import com.steerinfo.dil.util.HTTPRequestUtils;
  11. import org.springframework.beans.factory.annotation.Autowired;
  12. import org.springframework.stereotype.Service;
  13. import org.springframework.transaction.annotation.Transactional;
  14. import java.io.IOException;
  15. import java.math.BigDecimal;
  16. import java.util.*;
  17. /**
  18. * TmstruckMeasureCommission服务实现:
  19. * @author generator
  20. * @version 1.0-SNAPSHORT 2021-09-09 10:28
  21. * 类描述
  22. * 修订历史:
  23. * 日期:2021-09-09
  24. * 作者:generator
  25. * 参考:
  26. * 描述:TmstruckMeasureCommission服务实现
  27. * @see null
  28. * @Copyright 湖南视拓信息技术股份有限公司. All rights reserved.
  29. */
  30. @Service(value = "tmstruckMeasureCommissionService")
  31. public class TmstruckMeasureCommissionServiceImpl implements ITmstruckMeasureCommissionService{
  32. @Autowired
  33. private TmstruckMeasureCommissionMapper tmstruckMeasureCommissionMapper;
  34. @Autowired
  35. private RulesMapper rulesMapper;
  36. @Autowired
  37. UtilsMapper utilsMapper;
  38. @Autowired
  39. private RulesServiceImpl rulesService;
  40. /**
  41. * 查询计量委托 0 :计皮 1:计毛
  42. * @param map orderTypee 订单类型 type 是计皮还是计毛
  43. * @return
  44. */
  45. @Override
  46. public List<Map<String, Object>> getAllMeasureCommission(Map<String, Object> map) {
  47. Integer orderType = (Integer) map.get("orderTypee");
  48. switch (orderType){
  49. case 1:
  50. break;
  51. case 2:
  52. break;
  53. case 3:
  54. break;
  55. case 4:
  56. break;
  57. case 5:
  58. break;
  59. case 6:
  60. break;
  61. case 7:
  62. break;
  63. case 8:
  64. return tmstruckMeasureCommissionMapper.getMeasureCommission(map);
  65. case 9:
  66. break;
  67. case 10:
  68. break;
  69. case 11:
  70. }
  71. return null;
  72. }
  73. /**
  74. * 添加计量委托 并发送采购订单计量委托
  75. * @param map {orderTypee: 订单类型
  76. * resultTotalId:总实绩ID orderId: 订单ID
  77. * 总实绩ID }
  78. * @return
  79. */
  80. public int addMaoMeasureCommission(Map<String, Object> map){
  81. int i = 0;
  82. addMeasureCommission(map); // 添加计毛委托
  83. //发送数据给计量系统 必要数据 orderTypee:订单类型 resultTotalId: 总实绩Id orderId
  84. //获取当前订单是属于哪个厂区订单
  85. Integer receiveId = 0 ;
  86. if (DataChange.dataToBigDecimal(map.get("orderTypee")).intValue() == 11){//判断如果是纯内转,向达州钢铁发送委托
  87. i += sendMeasureCommissionMes(map);
  88. }
  89. if(DataChange.dataToBigDecimal(map.get("orderTypee")).intValue() == 10){
  90. receiveId = tmstruckMeasureCommissionMapper.getReceiveIdByRequirementOrderId(DataChange.dataToBigDecimal(map.get("orderId")));
  91. }else{
  92. //查询采购订单中的组织
  93. receiveId = tmstruckMeasureCommissionMapper.getReceiveIdByOrderId(DataChange.dataToBigDecimal(map.get("orderId")));
  94. }
  95. if(receiveId == 1){
  96. //发送委托给达州钢铁
  97. i += sendMeasureCommissionMes(map);
  98. }
  99. if(receiveId == 2) {
  100. //发送委托给达兴能源
  101. i += sendDXMeasureCommissionMes(map);
  102. }
  103. return i;
  104. }
  105. //发送计量委托
  106. @Override
  107. @Transactional(rollbackFor = Exception.class)
  108. public int sendMeasureCommssion(Map<String, Object> map) throws Exception {
  109. int i=0;
  110. //获取订单类型
  111. BigDecimal orderId = DataChange.dataToBigDecimal(map.get("orderId"));
  112. BigDecimal orderType = utilsMapper.getOrderTypeByOrderId(orderId);
  113. //根据运输订单id查找运输订单号
  114. switch (orderType.intValue()){
  115. case 1: //查询未装车实绩
  116. List<Map<String, Object>> mapList = rulesService.judgeLastMaterial(DataChange.dataToBigDecimal(map.get("orderId")));
  117. map.put("materialId", mapList.get(0).get("materialId"));
  118. i+=addXSMeasureCommission(map);
  119. case 2:
  120. case 3: //通过物资ID查询订单ID(针对单拼)
  121. List<Integer> materialIdList = utilsMapper.getMaterialIdByOrderId(orderId);
  122. map.put("materialId", materialIdList.get(0));
  123. i+=addXSMeasureCommission(map);
  124. break;
  125. case 12:
  126. case 13:
  127. case 15:
  128. case 20:
  129. case 16: //发送计量委托(查询物资顺序第一个装卸货的物资)
  130. //拿到需要计量的物资ID
  131. Integer materialId = utilsMapper.getLxFirstMaterialId(DataChange.dataToBigDecimal(map.get("orderId")));
  132. map.put("materialId", materialId);
  133. i+=addLXMeasureCommission(map);
  134. break;
  135. case 5:
  136. case 6:
  137. case 7:
  138. case 8:
  139. case 9:
  140. case 17:
  141. case 18://通过订单ID查询物资Id
  142. List<Integer> materialIds = utilsMapper.getMaterialIdByOrderId(DataChange.dataToBigDecimal(map.get("orderId")));
  143. map.put("materialId", materialIds.get(0));
  144. i+=addMaoMeasureCommission(map);
  145. break;
  146. case 10:
  147. case 11:
  148. i+=addMaoMeasureCommission(map);
  149. }
  150. if (i==0){
  151. throw new Exception("委托发送失败");
  152. }
  153. return i;
  154. }
  155. /**
  156. * 发送销售订单计量委托
  157. * @param map
  158. * @return
  159. */
  160. public int addXSMeasureCommission(Map<String, Object> map){
  161. int i = 0;
  162. addMeasureCommission(map); // 添加计毛委托
  163. //发送数据给计量系统 必要数据 orderTypee:订单类型 resultTotalId: 总实绩Id orderId
  164. //获取当前订单是属于哪个厂区订单
  165. Integer shipperId = tmstruckMeasureCommissionMapper.getShipperIdByOrderId(DataChange.dataToBigDecimal(map.get("orderId")));
  166. if(shipperId == 1){
  167. //发送委托给达州钢铁
  168. i += sendMeasureCommissionMes(map);
  169. }
  170. if(shipperId == 2) {
  171. //发送委托给达兴能源
  172. i += sendDXMeasureCommissionMes(map);
  173. }
  174. return i;
  175. }
  176. /**
  177. * 添加零星物资计量委托
  178. * @param map
  179. * @return
  180. */
  181. public int addLXMeasureCommission(Map<String, Object> map){
  182. Integer orderType = DataChange.dataToBigDecimal(map.get("orderTypee")).intValue();
  183. BigDecimal orderId = DataChange.dataToBigDecimal(map.get("orderId"));
  184. int i = 0;
  185. if(orderType == 12) {
  186. //查询进厂收货单位
  187. Integer receiveId = tmstruckMeasureCommissionMapper.getLxRealReceiveIdByOrderId(orderId);
  188. if(receiveId == 1){
  189. //给达钢发送委托
  190. i = sendMeasureCommissionMes(map);
  191. }else if(receiveId == 2){
  192. //给达兴发送委托
  193. i = sendDXMeasureCommissionMes(map);
  194. }
  195. }else if(orderType == 13){
  196. Integer sendId = tmstruckMeasureCommissionMapper.getLxRealSendUnitIdByOrderId(orderId);
  197. if(sendId == 1){
  198. i = sendMeasureCommissionMes(map);
  199. }else if(sendId == 2){
  200. i = sendDXMeasureCommissionMes(map);
  201. }
  202. }else if(orderType == 15){
  203. //进厂,收货单位
  204. //如果是15类型的订单寻找订单父级发货单位 (现只有进厂)
  205. Integer receiveId = tmstruckMeasureCommissionMapper.getLxRealReceiveIdByOrderId(orderId);
  206. if(receiveId == 1){
  207. i = sendMeasureCommissionMes(map);
  208. }else if (receiveId == 2){
  209. i = sendDXMeasureCommissionMes(map);
  210. }
  211. }else if(orderType == 16){
  212. //出厂,发货单位
  213. Integer sendUnitId = tmstruckMeasureCommissionMapper.getLxRealSendUnitIdByOrderId(orderId);
  214. if(sendUnitId == 1){
  215. i = sendMeasureCommissionMes(map);
  216. }else if (sendUnitId == 2){
  217. i = sendDXMeasureCommissionMes(map);
  218. }
  219. }
  220. else if(orderType == 20) {//内转零星进厂
  221. //查询还未计量实绩
  222. Integer noNetWeightResult = rulesMapper.getNoNetWeightResult(orderId);
  223. if(noNetWeightResult != 2){
  224. i = sendMeasureCommissionMes(map);
  225. }else {
  226. i = sendDXMeasureCommissionMes(map);//如果有两条没有净重的实绩则需要给达兴发委托 否则给达钢发委托
  227. }
  228. }
  229. addMeasureCommission(map); // 添加计毛委托
  230. return i;
  231. }
  232. /**
  233. * 新增计毛、计皮委托
  234. * @return
  235. */
  236. @Override
  237. public int addMeasureCommission(Map<String, Object> map) {
  238. TmstruckMeasureCommission tmstruckMeasureCommission = new TmstruckMeasureCommission();
  239. //生成主键Id
  240. tmstruckMeasureCommission.setCommssionId(tmstruckMeasureCommissionMapper.selectMaxId());
  241. //添加物资ID
  242. tmstruckMeasureCommission.setMaterialId(DataChange.dataToBigDecimal(map.get("materialId")));
  243. //添加汽车衡Id
  244. if(map.get("grossPlaceId") != null){
  245. tmstruckMeasureCommission.setCalculateId(DataChange.dataToBigDecimal(map.get("grossPlaceId")));
  246. }
  247. if(map.get("tarePlaceId") != null){
  248. tmstruckMeasureCommission.setCalculateId(DataChange.dataToBigDecimal(map.get("tarePlaceId")));
  249. }
  250. //添加实绩总表Id
  251. tmstruckMeasureCommission.setResultTotalId(DataChange.dataToBigDecimal(map.get("resultTotalId")));
  252. tmstruckMeasureCommission.setInsertTime(new Date());
  253. tmstruckMeasureCommission.setInsertUsername("admin");
  254. return tmstruckMeasureCommissionMapper.insertSelective(tmstruckMeasureCommission);
  255. }
  256. /**
  257. * 查询计量委托并向计量系统发送数据 调用他们接口
  258. * 1:销售订单;2:焦炭发运计划;3:水渣发运计划;4:内转到异地库;5:采购辅料订单;6:采购老区燃料订单;
  259. * 7:采购新区燃料订单;8:采购进口矿(万州-厂内);9:采购内转(达州-厂内);10:采购内转(老区-厂内); 11:厂内内转
  260. * @param map orderTypee 订单类型 type 计皮0还是计毛1类型 orderId 订单ID
  261. */
  262. public int sendMeasureCommissionMes(Map<String, Object> map){
  263. Map<String, Object> measureCommission = null;
  264. //查询计量委托
  265. BigDecimal orderType = DataChange.dataToBigDecimal(map.get("orderTypee"));
  266. switch (orderType.intValue()){
  267. case 1:
  268. break;
  269. case 2:
  270. break;
  271. case 3:
  272. break;
  273. case 10:
  274. break;
  275. case 11://纯内转发送计量委托
  276. measureCommission=tmstruckMeasureCommissionMapper.purchaseNzMeasure(map);
  277. measureCommission.put("isRelationEAS", false);
  278. measureCommission.put("flowTo", "进厂");
  279. measureCommission.put("isDel", false);
  280. measureCommission.put("isInsert", true);
  281. measureCommission.put("IsAssembly", false);
  282. measureCommission.put("deliveryMethod", "磅重交货");
  283. measureCommission.put("packagesNum", 0);
  284. measureCommission.put("ReceivUnit","四川省达州钢铁集团有限责任公司");
  285. measureCommission.put("sendUnit","四川省达州钢铁集团有限责任公司");
  286. break;
  287. case 4:
  288. break;
  289. case 5:
  290. case 6:
  291. case 7:
  292. case 8:
  293. case 9:
  294. measureCommission = tmstruckMeasureCommissionMapper.purchaseMeasure(map);
  295. measureCommission.put("isRelationEAS", false);
  296. measureCommission.put("flowTo", "进厂");
  297. measureCommission.put("isDel", false);
  298. measureCommission.put("isInsert", true);
  299. measureCommission.put("IsAssembly", false);
  300. measureCommission.put("deliveryMethod", "磅重交货");
  301. measureCommission.put("packagesNum", 0);
  302. break;
  303. case 12:
  304. case 13:
  305. //内转零星进厂(老厂区)
  306. //零星计量委托(老厂区)
  307. measureCommission = tmstruckMeasureCommissionMapper.sproadicMeasure(map);
  308. measureCommission.put("isRelationEAS",false);
  309. measureCommission.put("flowTo","进厂");
  310. measureCommission.put("isDel", false);
  311. measureCommission.put("isInsert", true);
  312. measureCommission.put("IsAssembly", false);
  313. measureCommission.put("deliveryMethod", "磅重交货");
  314. measureCommission.put("packagesNum", 0);
  315. break;
  316. case 15:
  317. case 16:
  318. //零星计量委托(老厂区) 会有多拼
  319. measureCommission = tmstruckMeasureCommissionMapper.sproadicMeasure(map);
  320. measureCommission.put("isRelationEAS",false);
  321. measureCommission.put("flowTo","出厂");
  322. measureCommission.put("isDel", false);
  323. measureCommission.put("isInsert", true);
  324. measureCommission.put("deliveryMethod", "磅重交货");
  325. measureCommission.put("packagesNum", 0);
  326. break;
  327. case 20://采购内转委托总厂区
  328. measureCommission=tmstruckMeasureCommissionMapper.purchaseXqCgNzMeasure(map);
  329. measureCommission.put("isRelationEAS",false);
  330. measureCommission.put("flowTo","进厂");
  331. measureCommission.put("isDel",false);
  332. measureCommission.put("isInsert",true);
  333. measureCommission.put("deliveryMethod", "磅重交货");
  334. measureCommission.put("packagesNum", 0);
  335. }
  336. /*访问接口发送数据*/
  337. return sendMesToMeasure(measureCommission);
  338. }
  339. /**
  340. * 发送计量委托给达兴能源 计量
  341. * @param map
  342. * @return
  343. */
  344. public int sendDXMeasureCommissionMes(Map<String, Object> map){
  345. Map<String, Object> measureCommission = null;
  346. //查询计量委托
  347. BigDecimal orderType = DataChange.dataToBigDecimal(map.get("orderTypee"));
  348. switch (orderType.intValue()){
  349. case 1:
  350. case 2:
  351. case 3:
  352. measureCommission = tmstruckMeasureCommissionMapper.saleDXMeasure(map); //订单ID 物资ID 计量实绩ID
  353. if(measureCommission == null)
  354. return 0;
  355. measureCommission.put("deliveryType", "计重");
  356. measureCommission.put("billType", "1");
  357. measureCommission.put("crname", "admin");
  358. measureCommission.put("ended", "0");
  359. break;
  360. case 4:
  361. break;
  362. case 5:
  363. case 6:
  364. case 7:
  365. case 8:
  366. case 17:
  367. case 18:
  368. measureCommission = tmstruckMeasureCommissionMapper.purchaseDXMeasure(map);
  369. if(measureCommission == null)
  370. return 0;
  371. measureCommission.put("deliveryType", "计重");
  372. measureCommission.put("billType", "0");
  373. measureCommission.put("crname", "admin");
  374. measureCommission.put("ended", "0");
  375. case 9:
  376. break;
  377. case 10:
  378. case 20:
  379. //新区采购内转
  380. measureCommission = tmstruckMeasureCommissionMapper.purchaseXqCgNzDXMeasure(map);
  381. if(measureCommission == null)
  382. return 0;
  383. measureCommission.put("deliveryType", "计重");
  384. measureCommission.put("crname", "admin");
  385. //判断还没有净重的计量实绩
  386. Integer weightResultCount = tmstruckMeasureCommissionMapper.selectNoNetWeightResult(DataChange.dataToBigDecimal(map.get("resultTotalId")));
  387. if(weightResultCount == 1){
  388. //如果只剩一条未计量的数据则需要走金蝶(进厂卸货)
  389. measureCommission.put("orderSource", measureCommission.get("chooseOrderSource"));
  390. measureCommission.put("billType", "0");
  391. measureCommission.put("item", measureCommission.get("item") + ",1");
  392. measureCommission.put("goodsName",measureCommission.get("goodsName") + "null");
  393. }else {
  394. measureCommission.put("orderSource", "0");
  395. measureCommission.put("billType", "2");
  396. }
  397. measureCommission.put("ended", "0");
  398. break;
  399. case 11:
  400. break;
  401. case 12:
  402. case 13:
  403. case 15:
  404. case 16:
  405. measureCommission = tmstruckMeasureCommissionMapper.sporadicDXMeasure(map);
  406. if(measureCommission == null)
  407. return 0;
  408. measureCommission.put("regionName", "无法确定汽车衡"); //无法确定汽车衡
  409. measureCommission.put("deliveryType", "计重");
  410. measureCommission.put("billType", "2");
  411. measureCommission.put("planQuantity", "0");
  412. measureCommission.put("crname", "admin");
  413. measureCommission.put("orderSource", "0");
  414. measureCommission.put("ended", "0");
  415. break;
  416. }
  417. /*访问接口发送数据*/
  418. return sendMesToDXMeasure(measureCommission);
  419. }
  420. /**
  421. *
  422. * 访问老厂区计量接口方法
  423. * @param map
  424. * @return
  425. */
  426. public int sendMesToMeasure(Map<String, Object> map){
  427. List<Map<String, Object>> sendMap = new ArrayList<>();
  428. sendMap.add(map);
  429. JSONObject jsonObject = new JSONObject();
  430. jsonObject.put("data", sendMap);
  431. String url = "http://172.16.33.122:44325/api/logistics/TareApplyFor";
  432. String jsonData = null;
  433. try {
  434. jsonData = HTTPRequestUtils.send(url, jsonObject, "utf-8");
  435. } catch (IOException e) {
  436. e.printStackTrace();
  437. }
  438. if(!"null".equals(jsonData)){
  439. System.out.println(jsonData);
  440. HashMap hashMap = JSON.parseObject(jsonData, HashMap.class);
  441. boolean success = (boolean) hashMap.get("success");
  442. System.out.println(hashMap.get("msg"));
  443. if(success){
  444. return 1;
  445. }
  446. }
  447. return 0;
  448. }
  449. /**
  450. * 访问新厂区达兴能源计量接口方法
  451. * @param map
  452. * @return
  453. */
  454. public int sendMesToDXMeasure(Map<String, Object> map){
  455. JSONObject jsonObject = new JSONObject();
  456. jsonObject.putAll(map);
  457. String url = "http://172.16.59.251:8121/daXingWeight/OrderBusiness/addOrder.do";
  458. String jsonData = null;
  459. try {
  460. jsonData = HTTPRequestUtils.send(url, jsonObject, "utf-8");
  461. } catch (IOException e) {
  462. e.printStackTrace();
  463. }
  464. if(!"null".equals(jsonData)){
  465. System.out.println(jsonData);
  466. HashMap hashMap = JSON.parseObject(jsonData, HashMap.class);
  467. String code = (String) hashMap.get("code");
  468. System.out.println(hashMap.get("msg"));
  469. if("0".equals(code)){
  470. return 1;
  471. }
  472. }
  473. return 0;
  474. }
  475. }