TmstruckWeightResultServiceImpl.java 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784
  1. package com.steerinfo.dil.service.impl;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.steerinfo.dil.feign.OmsFeign;
  4. import com.steerinfo.dil.feign.TmstruckFeign;
  5. import com.steerinfo.dil.mapper.*;
  6. import com.steerinfo.dil.model.TmstruckReceiveResult;
  7. import com.steerinfo.dil.model.TmstruckWeightResult;
  8. import com.steerinfo.dil.service.ITmstruckWeightResultService;
  9. import com.steerinfo.dil.util.DataChange;
  10. import com.steerinfo.dil.util.newFileTool;
  11. import org.apache.commons.lang.time.FastDateFormat;
  12. import org.slf4j.Logger;
  13. import org.slf4j.LoggerFactory;
  14. import org.springframework.beans.factory.annotation.Autowired;
  15. import org.springframework.stereotype.Service;
  16. import org.springframework.transaction.annotation.Transactional;
  17. import java.io.IOException;
  18. import java.text.ParseException;
  19. import java.text.SimpleDateFormat;
  20. import java.util.*;
  21. import java.math.BigDecimal;
  22. /**
  23. * TmstruckWeightResult服务实现:
  24. * @author generator
  25. * @version 1.0-SNAPSHORT 2021-10-25 02:28
  26. * 类描述
  27. * 修订历史:
  28. * 日期:2021-10-25
  29. * 作者:generator
  30. * 参考:
  31. * 描述:TmstruckWeightResult服务实现
  32. * @see null
  33. * @Copyright 湖南视拓信息技术股份有限公司. All rights reserved.
  34. */
  35. @Service(value = "tmstruckWeightResultService")
  36. public class TmstruckWeightResultServiceImpl implements ITmstruckWeightResultService {
  37. @Autowired
  38. KDWebServiceServiceImpl KDWebServiceServiceImpl;
  39. @Autowired
  40. TmstruckWeightResultMapper tmstruckWeightResultMapper;
  41. @Autowired
  42. UtilsServiceImpl utilsService;
  43. @Autowired
  44. UtilsMapper utilsMapper;
  45. @Autowired
  46. OmsFeign omsFeign;
  47. @Autowired
  48. TmstruckFeign tmstruckFeign;
  49. @Autowired
  50. TmstruckReceiveResultMapper tmstruckReceiveResultMapper;
  51. @Autowired
  52. TmstrainWeightResultServiceImpl tmstrainWeightResultService;
  53. //属于采购订单的订单类型(先计毛后计皮)
  54. final private List<Integer> judgeOrderTypeList = Arrays.asList(5, 6, 7, 8, 9, 12, 15, 17, 18,23,24,19);
  55. //老厂区需要给金蝶回传的数据订单类型
  56. final private List<Integer> judgeToKDTypeList = Arrays.asList(5,6,7,8,17,18,23,20);
  57. Logger logger = LoggerFactory.getLogger(getClass());
  58. /**
  59. * 接收达钢计量实绩信息
  60. * "orderNumber":"WYSDD2021091000000002",
  61. * "resultTareCalculateNumber":"1号汽车衡",
  62. * "resultCrossCalculateNumber":"1号汽车衡",
  63. * "resultTareWeight":40.00,
  64. * "resultCrossWeight":40.00,
  65. * "resultNetWeight":0,
  66. * "resultTareWeightTime":"2021-09-10 09:05:22",
  67. * "resultCrossWeightTime":"2021-09-10 09:05:22",
  68. * "resultPoundNo":"Bd123456780",
  69. * "materialId":40
  70. * @param mapList
  71. * @return
  72. */
  73. @Override
  74. @Transactional
  75. public String receiveTmsTruckWeightResultByDaGang(List<Map<String, Object>> mapList){
  76. //遍历列表
  77. StringBuilder sb = new StringBuilder();
  78. for (Map<String, Object> map : mapList) {
  79. sb.append(" ");
  80. String resultTareCalculateNumber = (String) map.get("resultTareCalculateNumber");
  81. //如果计量衡名字中含有铁专线 则代表是轨道衡 走轨道衡路线
  82. if(resultTareCalculateNumber.contains("铁专线")){
  83. sb.append(tmstrainWeightResultService.addTrainWeightResult(map));
  84. }else {
  85. //走汽车衡
  86. map.put("needCheckToKD", "1"); //老厂区专属变量 用于区分新、老厂区 老厂区部分秤需要给金蝶传输数据
  87. sb.append(addTruckWeightResult(map));
  88. }
  89. }
  90. return sb.toString();
  91. }
  92. /*
  93. * 接收达兴计量实绩
  94. * @Author TXF
  95. * @Date 2022/2/9 14:57
  96. * @param mapList
  97. * @return
  98. **/
  99. @Transactional
  100. @Override
  101. public String receiveTmsTruckWeightResultByDaXing(List<Map<String, Object>> mapList) {
  102. StringBuilder sb = new StringBuilder();
  103. //遍历列表
  104. for (Map<String, Object> map : mapList) {
  105. sb.append(addTruckWeightResult(map));
  106. }
  107. return sb.toString();
  108. }
  109. /**
  110. * 添加汽车衡计量实绩
  111. * @param map
  112. * @return
  113. */
  114. public String addTruckWeightResult(Map<String, Object> map) {
  115. System.out.println("---------------------------------" + new Date() + "新接收到的计量实绩" + "---------------------------------");
  116. JSONObject jsonObject = new JSONObject(map);
  117. logger.info("计量信息:{}", jsonObject.toString());
  118. System.out.println("---------------------------------" + new Date() + "新接收到的计量实绩" + "---------------------------------");
  119. //try {
  120. // newFileTool.newFile(jsonObject.toString(),"计量");
  121. //} catch (IOException e) {
  122. // e.printStackTrace();
  123. //}
  124. if(map.get("flag") != null && map.get("flag").equals("GCXS")){
  125. System.out.println("这是钢材销售");
  126. TmstruckWeightResult tmstruckWeightResult = null;
  127. try {
  128. tmstruckWeightResult = generateSteelWeightResult(map);
  129. tmstruckWeightResultMapper.updateByPrimaryKeySelective(tmstruckWeightResult);
  130. utilsService.pushMesToWebsocket((String) map.get("carNo"), "计量");
  131. return map.get("carNo") + "传输成功";
  132. } catch (Exception e) {
  133. System.out.println(map.get("carNo") + e.getMessage() + "传输失败");
  134. return map.get("carNo") + e.getMessage() + "传输失败";
  135. }
  136. }
  137. //首先通过运输订单号查询订单类型
  138. Map<String, Object> oneMap = utilsMapper.getOrderTypeByOrderNumber((String) map.get("orderNumber")); //用于判断订单类型
  139. if(oneMap == null){
  140. return map.get("orderNumber") + "系统无此订单";
  141. }
  142. int orderType= DataChange.dataToBigDecimal(oneMap.get("orderType")).intValue();
  143. if(orderType == 11 || orderType == 15 || orderType == 16){
  144. return insertWeightResultBy11(map, oneMap);
  145. }
  146. //为1的时候计量重新更新单据
  147. if(DataChange.dataToBigDecimal(map.get("WLReUpdateFlag")).intValue() == 1){
  148. return linkUpdateAPO(map, orderType);
  149. }
  150. //通过运输订单号查询计量实绩Id
  151. Map<String, Object> stringObjectMap = tmstruckWeightResultMapper.selectWeightIdByOrderId(map);
  152. if(stringObjectMap == null){
  153. //通过传来的运输订单号 与 物资ID查询计重实绩ID
  154. stringObjectMap = tmstruckWeightResultMapper.selectTotalIdByOrderNo(map);
  155. if(stringObjectMap == null){
  156. return map.get("orderNumber") + "没有此订单信息或物资信息(" + map.get("materialId") + ")错误";
  157. }
  158. }
  159. map.putAll(stringObjectMap);
  160. TmstruckWeightResult tmstruckWeightResult = null;
  161. try {
  162. tmstruckWeightResult = generateWeightResult(map);
  163. } catch (Exception e) {
  164. return e.getMessage();
  165. }
  166. //如果含有这个变量则代表是老区订单需要判断是否回传给金蝶
  167. if(map.get("needCheckToKD") != null){
  168. if(map.get("resultNetWeight") != null){
  169. Object resultCrossWeightTime = map.get("resultCrossWeightTime");
  170. if (judgeToKDTypeList.contains(orderType) && resultCrossWeightTime != null && !"".equals(resultCrossWeightTime)) {
  171. String resultNetWeight = String.valueOf(map.get("resultNetWeight")); //如果净重不为空 或者净重不为0
  172. if (!"null".equals(resultNetWeight) && !"".equals(resultNetWeight) && !"0".equals(resultNetWeight)) {
  173. //回传数据给金蝶方法
  174. sendMesToKD(map, orderType);
  175. }
  176. }
  177. }
  178. }
  179. tmstruckWeightResultMapper.updateByPrimaryKeySelective(tmstruckWeightResult);
  180. //如果订单类型是零星订单 需要查询一下是否还有未计量物资
  181. if(orderType == 12 || orderType == 13){
  182. dealWithLxOrder(map, stringObjectMap);
  183. }
  184. //推送数据
  185. try {
  186. utilsService.pushMesToWebsocket((String) oneMap.get("capacityNumber"), "计量");
  187. } catch (Exception e) {
  188. e.printStackTrace();
  189. }
  190. return map.get("orderNumber") + "成功";
  191. }
  192. private TmstruckWeightResult generateSteelWeightResult(Map<String, Object> map) throws Exception {
  193. TmstruckWeightResult tmstruckWeightResult = new TmstruckWeightResult();
  194. //该数据为不走物流扫码的数据
  195. //1.通过车号去寻找正在作业的5的运输订单号
  196. String carNo = (String) map.get("carNo");
  197. Map<String,Object> orderMes = tmstruckWeightResultMapper.getOrderMes(carNo);
  198. if (orderMes == null){
  199. throw new Exception("该车没有正在运行中的信息");
  200. }
  201. map.putAll(orderMes);
  202. tmstruckWeightResult.setId(DataChange.dataToBigDecimal(map.get("weightTaskResultId")));
  203. int orderType = DataChange.dataToBigDecimal(orderMes.get("orderTypee")).intValue();
  204. //磅单号
  205. tmstruckWeightResult.setResultPoundNo((String) map.get("resultPoundNo"));
  206. String resultCrossWeightTime = (String) map.get("resultCrossWeightTime");
  207. if(map.get("orderNumber") != null) {
  208. tmstruckWeightResult.setInsertUpdateRemark((String)map.get("orderNumber"));
  209. }
  210. //根据传输过来的物资名称和规格型号
  211. Object resultNetWeight = map.get("resultNetWeight");
  212. if(resultNetWeight != null && !"".equals(resultNetWeight)) {
  213. BigDecimal materialId = tmstruckWeightResultMapper.getMaterialId(map);
  214. if(materialId == null){
  215. throw new Exception("系统找不到该物资");
  216. }
  217. map.put("materialId",materialId);
  218. //判断此物资是不是已经有净重了,如果有抛出异常
  219. int netWeightCount = tmstruckWeightResultMapper.getHaveNetWeightByMaterial(map);
  220. if(netWeightCount != 0){
  221. throw new Exception("该物资已有净重,不能再次录入");
  222. }
  223. tmstruckWeightResult.setMaterialId(materialId);
  224. tmstruckWeightResult.setMaterialNum(DataChange.dataToBigDecimal(map.get("goodNum")));
  225. BigDecimal materialNum = DataChange.dataToBigDecimal(map.get("goodNum"));
  226. //通过订单ID和物资id,查询当单个物资的理重方便后续计算
  227. Map<String, Object> saleMaterialMes = tmstruckWeightResultMapper.getSaleOrderMaterialNum(map);
  228. if(saleMaterialMes == null) {
  229. throw new Exception("该订单没有该物资分录");
  230. }
  231. BigDecimal saleMaterialId = DataChange.dataToBigDecimal(saleMaterialMes.get("saleMaterialId"));//销售订单存放物资子表id
  232. BigDecimal materialWeight = DataChange.dataToBigDecimal(saleMaterialMes.get("materialWeight"));//旧总理重
  233. BigDecimal newWeight = null;
  234. if (materialWeight.intValue() != 0) { //如果总重量不为0,才进行重量更新
  235. BigDecimal orderMaterialNumber = DataChange.dataToBigDecimal(saleMaterialMes.get("orderMaterialNumber"));//旧件数
  236. BigDecimal theoreticalWeight = materialWeight.multiply(materialNum);
  237. newWeight = theoreticalWeight.divide(orderMaterialNumber,3, 4);//得到现有理重
  238. map.put("newWeight",newWeight);
  239. //更新运输订单物资子表的件数和理论重量
  240. }
  241. tmstruckWeightResultMapper.updateOrderMaterial(map);
  242. tmstruckWeightResultMapper.updateSaleMaterialId(saleMaterialId,materialNum,newWeight);
  243. }
  244. addWeightResult(tmstruckWeightResult, map); //添加计量实绩数据
  245. // 更新订单中路段顺序号,如果毛重时间为空则为计皮:也就是销售第一次计皮,反之有毛重时间则为计毛
  246. if(resultCrossWeightTime == null || resultCrossWeightTime.length() == 0){
  247. map.put("segmentSqe", map.get("tareSegmentSqe")); //皮重路段顺序
  248. }else{
  249. map.put("segmentSqe", map.get("grossSegmentSqe")); //毛重路段顺序
  250. }
  251. if(orderType == 1 || orderType == 4){
  252. //如果是钢材订单,获取下一个还没计量的实绩 将毛重数据作为下一个计量实绩的皮重
  253. //并且是第二次传入重量才执行
  254. List<Map<String, Object>> steelMapList = tmstruckWeightResultMapper.getNoNetWeightResultId(DataChange.dataToBigDecimal(map.get("resultTotalId")));
  255. if(steelMapList.size() >= 2){ //当前更新还未提交所以如果是拼装需要查询两个出来 以第二个为准
  256. Map<String, Object> steelMap = steelMapList.get(1);
  257. if(resultNetWeight != null && !"".equals(resultNetWeight)){
  258. updateSteelAssemble(map, steelMap); //更新下一拼实绩
  259. map.put("segmentSqe", steelMap.get("tareSegmentSqe")); // 修改路段顺序号直接到下一皮重路段顺序
  260. }
  261. }
  262. }
  263. utilsService.updateOrderLineSequence(map);
  264. return tmstruckWeightResult;
  265. }
  266. /**
  267. * 生成汽运计量实体类
  268. * @Author TXF
  269. * @Date 2022/1/5 16:41
  270. * @param map
  271. * @return
  272. **/
  273. public TmstruckWeightResult generateWeightResult(Map<String, Object> map) throws Exception {
  274. TmstruckWeightResult tmstruckWeightResult = new TmstruckWeightResult();
  275. tmstruckWeightResult.setId(DataChange.dataToBigDecimal(map.get("weightTaskResultId")));
  276. int orderType = DataChange.dataToBigDecimal(map.get("orderTypee")).intValue();
  277. //磅单号
  278. tmstruckWeightResult.setResultPoundNo((String) map.get("resultPoundNo"));
  279. String resultCrossWeightTime = (String) map.get("resultCrossWeightTime");
  280. tmstruckWeightResult.setMaterialId(DataChange.dataToBigDecimal(map.get("materialId")));
  281. //如果是采购订单 先计毛再计皮
  282. if(judgeOrderTypeList.contains(orderType)){
  283. //如果毛重数据为空 则是第一次计量为毛重 此时第一次计量时间放皮重时间里面
  284. if(resultCrossWeightTime == null || resultCrossWeightTime.length() == 0){
  285. addMaoWeightResult(tmstruckWeightResult, map);
  286. //更新订单中路段顺序号
  287. map.put("segmentSqe", map.get("grossSegmentSqe")); //毛重路段顺序
  288. utilsService.updateOrderLineSequence(map);
  289. }else {
  290. addWeightResult(tmstruckWeightResult, map);
  291. //更新订单中路段顺序号
  292. map.put("segmentSqe", map.get("tareSegmentSqe")); //皮重路段顺序
  293. utilsService.updateOrderLineSequence(map);
  294. if (orderType==19){
  295. //获取第二个还未计量的物资将第一个物资的皮重作为第二个物资的毛重。
  296. List<Map<String, Object>> resultMapList = tmstruckWeightResultMapper.getNoNetWeightResultForSaleReturn(DataChange.dataToBigDecimal(map.get("resultTotalId")));
  297. if (resultMapList.size()>=2){//如果为多拼
  298. Map<String, Object> saleReturnMap = resultMapList.get(1);
  299. Object resultNetWeight = map.get("resultNetWeight");
  300. if(resultNetWeight != null && !"".equals(resultNetWeight)){
  301. updateSaleReturnAssemble(map, saleReturnMap); //更新下一拼实绩
  302. map.put("segmentSqe", saleReturnMap.get("tareSegmentSqe"));
  303. utilsService.updateOrderLineSequence(map);// 修改路段顺序号直接到下一皮重路段顺序
  304. }
  305. }
  306. }//添加计量实绩数据
  307. String orderNumber = (String) map.get("orderNumber");
  308. //如果是采购订单 计皮后自动完成签收
  309. //查询是此订单是否已签收过
  310. Integer check = utilsMapper.checkoutReceipt(orderNumber);
  311. if(check == null){
  312. autoReceipt(orderNumber, map.get("resultTareWeightTime"));
  313. }
  314. }
  315. }
  316. else if(orderType == 10 || orderType == 20 || orderType == 14){
  317. //查询还有几条没有净重的实绩
  318. Integer resultNum = tmstruckWeightResultMapper.selectNoNetWeightResult((String) map.get("orderNumber"));
  319. if(resultNum == 2){
  320. //如果有两条则是走先计皮后计毛顺序
  321. addWeightResult(tmstruckWeightResult, map); //添加计量实绩数据 (正常添加对应皮毛重方法)
  322. if(resultCrossWeightTime == null || resultCrossWeightTime.length() == 0){
  323. map.put("segmentSqe", map.get("tareSegmentSqe")); //皮重路段顺序
  324. }else{
  325. map.put("segmentSqe", map.get("grossSegmentSqe")); //毛重路段顺序
  326. }
  327. utilsService.updateOrderLineSequence(map);
  328. }else if(resultNum == 1){
  329. //只剩一条数据时则是计毛后计皮顺序
  330. //如果毛重数据为空 则是第一次计量为毛重 此时第一次计量时间放皮重时间里面
  331. if(resultCrossWeightTime == null || resultCrossWeightTime.length() == 0){
  332. addMaoWeightResult(tmstruckWeightResult, map);
  333. //更新订单中路段顺序号
  334. map.put("segmentSqe", map.get("grossSegmentSqe")); //毛重路段顺序
  335. utilsService.updateOrderLineSequence(map);
  336. }else {
  337. addWeightResult(tmstruckWeightResult, map); //添加计量实绩数据
  338. //更新订单中路段顺序号
  339. map.put("segmentSqe", map.get("tareSegmentSqe")); //皮重路段顺序
  340. utilsService.updateOrderLineSequence(map);
  341. String orderNumber = (String) map.get("orderNumber");
  342. //如果是采购订单 计皮后自动完成签收
  343. //查询是此订单是否已签收过
  344. Integer check = utilsMapper.checkoutReceipt(orderNumber);
  345. if(check == null){
  346. autoReceipt(orderNumber, map.get("resultTareWeightTime"));
  347. }
  348. if(orderType == 20){
  349. //此订单类型比较特殊 如果订单类型为20则需要回传金蝶
  350. sendMesToKD(map, orderType);
  351. }
  352. }
  353. }
  354. }
  355. else{
  356. addWeightResult(tmstruckWeightResult, map); //添加计量实绩数据
  357. // 更新订单中路段顺序号,如果毛重时间为空则为计皮:也就是销售第一次计皮,反之有毛重时间则为计毛
  358. if(resultCrossWeightTime == null || resultCrossWeightTime.length() == 0){
  359. map.put("segmentSqe", map.get("tareSegmentSqe")); //皮重路段顺序
  360. }else{
  361. map.put("segmentSqe", map.get("grossSegmentSqe")); //毛重路段顺序
  362. }
  363. if(orderType == 1 || orderType == 4){
  364. //如果是钢材订单,获取下一个还没计量的实绩 将毛重数据作为下一个计量实绩的皮重
  365. //并且是第二次传入重量才执行
  366. List<Map<String, Object>> steelMapList = tmstruckWeightResultMapper.getNoNetWeightResultId(DataChange.dataToBigDecimal(map.get("resultTotalId")));
  367. if(steelMapList.size() >= 2){ //当前更新还未提交所以如果是拼装需要查询两个出来 以第二个为准
  368. Map<String, Object> steelMap = steelMapList.get(1);
  369. Object resultNetWeight = map.get("resultNetWeight");
  370. if(resultNetWeight != null && !"".equals(resultNetWeight)){
  371. updateSteelAssemble(map, steelMap); //更新下一拼实绩
  372. map.put("segmentSqe", steelMap.get("tareSegmentSqe")); // 修改路段顺序号直接到下一皮重路段顺序
  373. }
  374. }
  375. }
  376. utilsService.updateOrderLineSequence(map);
  377. }
  378. return tmstruckWeightResult;
  379. }
  380. /**
  381. * 添加第一次为毛重数据的计量实绩
  382. * @param tmstruckWeightResult
  383. * @param map
  384. */
  385. public void addMaoWeightResult(TmstruckWeightResult tmstruckWeightResult, Map<String, Object> map) throws Exception{
  386. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  387. //设置毛重时间
  388. String firstTime = (String) map.get("resultTareWeightTime");
  389. tmstruckWeightResult.setResultGrossWeightTime(sdf.parse(firstTime));
  390. //添加毛重汽车衡
  391. Integer tareId = tmstruckWeightResultMapper.selectTruckCalculateId((String) map.get("resultTareCalculateNumber"));
  392. if(tareId == null){
  393. throw new Exception("没有此计量衡:" + map.get("resultTareCalculateNumber"));
  394. }
  395. tmstruckWeightResult.setResultGrossPlaceId(new BigDecimal(tareId));
  396. //设置毛重
  397. BigDecimal resultTareWeight = DataChange.dataToBigDecimal(map.get("resultTareWeight"));
  398. tmstruckWeightResult.setResultGrossWeight(resultTareWeight);
  399. tmstruckWeightResult.setInsertTime(new Date());
  400. tmstruckWeightResult.setInsertUsername("admin");
  401. }
  402. /**
  403. * 添加计量实绩添加数据
  404. * @param tmstruckWeightResult
  405. * @param map
  406. * @return
  407. */
  408. public void addWeightResult(TmstruckWeightResult tmstruckWeightResult, Map<String, Object> map) throws Exception{
  409. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  410. //设置皮重汽车衡
  411. String resultTareCalculateNumber = (String) map.get("resultTareCalculateNumber");
  412. if(resultTareCalculateNumber != null){
  413. if(!"".equals(resultTareCalculateNumber)){
  414. Integer tareId = tmstruckWeightResultMapper.selectTruckCalculateId(resultTareCalculateNumber);
  415. if(tareId == null){
  416. throw new Exception("没有此皮重汽车衡:" + map.get("resultTareCalculateNumber"));
  417. }
  418. tmstruckWeightResult.setResultTarePlaceId(new BigDecimal(tareId));
  419. }
  420. }
  421. //设置毛重汽车衡
  422. String resultCrossCalculateNumber = (String) map.get("resultCrossCalculateNumber");
  423. if(resultCrossCalculateNumber != null){
  424. if(!"".equals(resultCrossCalculateNumber)){
  425. Integer crossId = tmstruckWeightResultMapper.selectTruckCalculateId(resultCrossCalculateNumber);
  426. if(crossId == null){
  427. throw new Exception("没有此毛重汽车衡:" + map.get("resultCrossCalculateNumber"));
  428. }
  429. tmstruckWeightResult.setResultGrossPlaceId(new BigDecimal(crossId));
  430. }
  431. }
  432. //毛重
  433. if(map.get("resultCrossWeight") != null){
  434. String resultCrossWeight = String.valueOf(map.get("resultCrossWeight"));
  435. if(!"".equals(resultCrossWeight))
  436. tmstruckWeightResult.setResultGrossWeight(DataChange.dataToBigDecimal(resultCrossWeight));
  437. }
  438. //皮重
  439. if(map.get("resultTareWeight") != null){
  440. String resultTareWeight = String.valueOf(map.get("resultTareWeight"));
  441. if(!"".equals(resultTareWeight))
  442. tmstruckWeightResult.setResultTareWeight(DataChange.dataToBigDecimal(resultTareWeight));
  443. }
  444. //净重
  445. if(map.get("resultNetWeight") != null){
  446. String resultNetWeight = String.valueOf(map.get("resultNetWeight"));
  447. if(!"".equals(resultNetWeight)){
  448. tmstruckWeightResult.setResultNetWeight(DataChange.dataToBigDecimal(resultNetWeight));
  449. }
  450. }
  451. //设置皮重时间
  452. if(map.get("resultTareWeightTime") != null){
  453. String resultTareWeightTime = (String) map.get("resultTareWeightTime");
  454. if(!"".equals(resultTareWeightTime)){
  455. tmstruckWeightResult.setResultTareWeightTime(sdf.parse(resultTareWeightTime));
  456. }
  457. }
  458. //设置毛重时间
  459. if(map.get("resultCrossWeightTime") != null){
  460. String resultGrossWeightTime = (String) map.get("resultCrossWeightTime");
  461. if(!"".equals(resultGrossWeightTime)){
  462. tmstruckWeightResult.setResultGrossWeightTime(sdf.parse(resultGrossWeightTime));
  463. }
  464. }
  465. tmstruckWeightResult.setUpdateTime(new Date());
  466. tmstruckWeightResult.setUpdateUsername("admin");
  467. }
  468. /**
  469. * 自动签收
  470. * @return
  471. */
  472. public void autoReceipt(String orderNumber, Object tareWeightTime){
  473. TmstruckReceiveResult tmstruckReceiveResult = new TmstruckReceiveResult();
  474. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  475. //通过运输订单号查询总实绩ID
  476. BigDecimal resultTotalId = utilsMapper.getTotalIdByOrderNumber(orderNumber);
  477. tmstruckReceiveResult.setResultTotalId(resultTotalId);
  478. tmstruckReceiveResult.setStatus(new BigDecimal(1));
  479. tmstruckReceiveResult.setInsertUsername("admin");
  480. Date receiptTime;
  481. try {
  482. //取皮重时间为收货时间
  483. receiptTime = sdf.parse((String) tareWeightTime);
  484. } catch (ParseException e) {
  485. receiptTime = new Date();
  486. System.out.println(e.getMessage());
  487. }
  488. tmstruckReceiveResult.setInsertTime(receiptTime);
  489. tmstruckReceiveResult.setUpdateTime(receiptTime);
  490. int i = tmstruckReceiveResultMapper.updateByTotalResultId(tmstruckReceiveResult);
  491. if(i == 1) {
  492. System.out.println(orderNumber + "收货成功");
  493. }else {
  494. System.out.println(orderNumber + "收货失败");
  495. }
  496. }
  497. /**
  498. * 纯内转订单类型
  499. * @Author TXF
  500. * @Date 2022/2/18 9:55
  501. * @param map
  502. * @return
  503. **/
  504. public String insertWeightResultBy11(Map<String, Object> map, Map<String, Object> oneMap){
  505. TmstruckWeightResult tmstruckWeightResult = new TmstruckWeightResult();
  506. tmstruckWeightResult.setResultPoundNo((String) map.get("resultPoundNo"));
  507. tmstruckWeightResult.setMaterialId(DataChange.dataToBigDecimal(map.get("materialId")));
  508. int sqe = DataChange.dataToBigDecimal(oneMap.get("Sqe")).intValue(); //获取订单路段顺序号
  509. sqe = sqe + 1;
  510. Object resultNetWeight = map.get("resultNetWeight");
  511. if(resultNetWeight != null && !"".equals((String) resultNetWeight)){
  512. //判断是否有卸货实绩已经卸过货 如果有卸货实绩 则结束订单
  513. Integer resultId = utilsMapper.getUnloadResultByTotalId(DataChange.dataToBigDecimal(oneMap.get("totalId")));
  514. if(resultId != null){
  515. int orderIds = DataChange.dataToBigDecimal(oneMap.get("orderIds")).intValue();
  516. omsFeign.closeInwardOrder(orderIds, sqe, (String) resultNetWeight);
  517. }else {
  518. Map<String, Object> threeMap = new HashMap<>(); //用于更新路段顺序号
  519. threeMap.put("orderLineSequence", sqe);
  520. threeMap.put("orderNumber", map.get("orderNumber"));
  521. utilsMapper.updateLineSeqByOrderIdOrNum2(threeMap); //更新订单路段顺序号
  522. }
  523. }else {
  524. Map<String, Object> threeMap = new HashMap<>(); //用于更新路段顺序号
  525. threeMap.put("orderLineSequence", sqe);
  526. threeMap.put("orderNumber", map.get("orderNumber"));
  527. utilsMapper.updateLineSeqByOrderIdOrNum2(threeMap); //更新订单路段顺序号
  528. }
  529. //首先查询这个订单号的这个物资ID是否有计量实绩
  530. Map<String, Object> twoMap = tmstruckWeightResultMapper.selectResultIdByOrderNoAndMaterialId(map); //判断这个物资是否已经计量过
  531. Object resultCrossWeightTime = map.get("resultCrossWeightTime");
  532. if(twoMap == null){//如果查出来为空,则进行新增操作
  533. tmstruckWeightResult.setId(tmstruckWeightResultMapper.selectMaxId()); //新增主键
  534. tmstruckWeightResult.setResultTotalId(DataChange.dataToBigDecimal(oneMap.get("totalId"))); //新增总实绩ID
  535. if(resultCrossWeightTime == null || "".equals(String.valueOf(resultCrossWeightTime))){//只有一条数据的情况
  536. tmstruckWeightResult.setTareSegmentSqe(new BigDecimal(sqe));
  537. }
  538. else {
  539. tmstruckWeightResult.setTareSegmentSqe(new BigDecimal(sqe));
  540. tmstruckWeightResult.setGrossSegmentSqe(new BigDecimal(sqe));
  541. }
  542. try {
  543. addWeightResult(tmstruckWeightResult, map);
  544. } catch (Exception e) {
  545. return e.getMessage();
  546. }
  547. tmstruckWeightResultMapper.insertSelective(tmstruckWeightResult); //新增计量实绩
  548. }else {
  549. //如果不为空则证明进行过至少一次计量
  550. tmstruckWeightResult.setId(DataChange.dataToBigDecimal(twoMap.get("weightTaskResultId")));
  551. //取出计量数据与传进来的毛皮数据进行对比
  552. BigDecimal inTareWeight = DataChange.dataToBigDecimal(twoMap.get("resultTareWeight"));
  553. if(inTareWeight.compareTo(DataChange.dataToBigDecimal(map.get("resultTareWeight"))) > 0){
  554. //如果取出来的皮重 大于 传进来的皮重 则需要调换路段顺序号
  555. tmstruckWeightResult.setGrossSegmentSqe(DataChange.dataToBigDecimal(twoMap.get("tareSegmentSqe")));
  556. tmstruckWeightResult.setTareSegmentSqe(new BigDecimal(sqe));
  557. }else{
  558. tmstruckWeightResult.setGrossSegmentSqe(new BigDecimal(sqe));
  559. }
  560. try {
  561. addWeightResult(tmstruckWeightResult, map);
  562. } catch (Exception e) {
  563. return e.getMessage();
  564. }
  565. tmstruckWeightResultMapper.updateByPrimaryKeySelective(tmstruckWeightResult);
  566. }
  567. //推送数据
  568. utilsService.pushMesToWebsocket((String) oneMap.get("capacityNumber"), "计量");
  569. return map.get("orderNumber") + "成功";
  570. }
  571. /**
  572. * 处理零星订单多拼方法
  573. * @Author TXF
  574. * @Date 2022/3/15 18:37
  575. * @param map
  576. * @param stringObjectMap
  577. * @return
  578. **/
  579. public void dealWithLxOrder(Map<String, Object> map, Map<String, Object> stringObjectMap){
  580. if(map.get("resultNetWeight") != null){
  581. String resultNetWeight = String.valueOf(map.get("resultNetWeight"));
  582. if(! ("".equals(resultNetWeight) || "null".equals(resultNetWeight))){
  583. //查询是否还有物资如果为空则为已经计量完成
  584. Integer materialId = utilsMapper.getNextMaterialId(DataChange.dataToBigDecimal(stringObjectMap.get("orderId")));
  585. if(materialId != null){
  586. stringObjectMap.put("materialId", materialId);
  587. stringObjectMap.put("asd", 1);
  588. Map<String, Object> returnMap = null;
  589. try {
  590. returnMap = tmstruckFeign.sendMeasureCommission(stringObjectMap);
  591. String code = (String) returnMap.get("code");
  592. if(!"200".equals(code)){
  593. System.out.println(returnMap.get("data"));
  594. }
  595. } catch (Exception e) {
  596. System.out.println(e.getMessage());
  597. }
  598. }
  599. }
  600. }
  601. }
  602. /**
  603. * 修改拼装钢材物资
  604. * @param map
  605. * @param steelMap
  606. */
  607. public void updateSteelAssemble(Map<String, Object> map, Map<String, Object> steelMap) throws Exception{
  608. //更新实绩
  609. TmstruckWeightResult steelWightModel = new TmstruckWeightResult();
  610. steelWightModel.setId(DataChange.dataToBigDecimal(steelMap.get("weightTaskResultId"))); //查询出来的主键
  611. steelMap.put("resultTareCalculateNumber", map.get("resultCrossCalculateNumber")); //皮重汽车衡即为毛重汽车衡
  612. steelMap.put("resultTareWeight", map.get("resultCrossWeight"));//皮重即为毛重
  613. steelMap.put("resultTareWeightTime", map.get("resultCrossWeightTime"));//皮重时间即为毛重时间
  614. addWeightResult(steelWightModel, steelMap);
  615. tmstruckWeightResultMapper.updateByPrimaryKeySelective(steelWightModel);
  616. }
  617. //修改拼装退货物资
  618. /**
  619. * 修改拼装钢材物资
  620. * @param map
  621. * @param steelMap
  622. */
  623. public void updateSaleReturnAssemble(Map<String, Object> map, Map<String, Object> steelMap) throws Exception{
  624. //更新实绩
  625. TmstruckWeightResult SaleReturn = new TmstruckWeightResult();
  626. SaleReturn.setId(DataChange.dataToBigDecimal(steelMap.get("weightTaskResultId"))); //查询出来的主键
  627. steelMap.put("resultCrossCalculateNumber", map.get("resultTareCalculateNumber")); //皮重汽车衡即为毛重汽车衡
  628. steelMap.put("resultCrossWeight", map.get("resultTareWeight"));//毛重即皮重
  629. steelMap.put("resultCrossWeightTime", map.get("resultTareWeightTime"));//毛重时间即皮重时间
  630. addWeightResult(SaleReturn, steelMap);
  631. tmstruckWeightResultMapper.updateByPrimaryKeySelective(SaleReturn);
  632. }
  633. /**
  634. * 回传数据给金蝶方法
  635. * @Author TXF
  636. * @Date 2022/2/9 15:46
  637. * @param
  638. * @return
  639. **/
  640. public void sendMesToKD(Map<String, Object> map, Integer orderType){
  641. String resultTareCalculateNumber = String.valueOf(map.get("resultTareCalculateNumber"));
  642. if(! resultTareCalculateNumber.contains("精煤")){ //如果不是精煤称的则不回传金蝶 或者没有皮重称
  643. return;
  644. }
  645. String orderNumber = (String) map.get("orderNumber");
  646. Map<String, Object> mesMap = new HashMap<>();
  647. switch (orderType){
  648. case 6:
  649. //查询订单信息
  650. mesMap = tmstruckWeightResultMapper.getPurOrderMesToKD(orderNumber);
  651. break;
  652. case 20:
  653. case 23:
  654. mesMap = tmstruckWeightResultMapper.get20PurOrderMesToKD(orderNumber);
  655. }
  656. //将map数据全放进mesMap中
  657. map.putAll(mesMap);
  658. //访问金蝶接口
  659. KDWebServiceServiceImpl.sendMesToKD(map);
  660. }
  661. /**
  662. * 计量联动删除方法
  663. * @param mapList
  664. * @return
  665. */
  666. public String linkageDeleteTransportOrder(List<Map<String, Object>> mapList) {
  667. //联动删除
  668. for (Map<String, Object> map : mapList) {
  669. String orderNumber = (String) map.get("orderNumber");
  670. tmstruckWeightResultMapper.linkageDeleteTransportOrder(orderNumber);
  671. }
  672. return "success";
  673. }
  674. /**
  675. * 计量联动修改方法(修改关联的采购订单,以及同步修改运输订单物资子表的物资)
  676. * @param map
  677. * @param orderType
  678. * @return
  679. */
  680. public String linkUpdateAPO(Map<String, Object> map, Integer orderType){
  681. //如果等于1 则代表是需要变更采购订单号的订单
  682. Map<String, Object> mesMap = tmstruckWeightResultMapper.getAPOMes(String.valueOf(map.get("ArrivalBillNo")));
  683. if (mesMap == null){
  684. return map.get("ArrivalBillNo") + "系统没有此订单号!失败";
  685. }
  686. mesMap.put("orderNumber", map.get("orderNumber"));
  687. if(orderType == 200){
  688. //20订单修改的表不一样呀
  689. tmstruckWeightResultMapper.updatePurchaseInwordAPOId(mesMap);
  690. tmstruckWeightResultMapper.updateOmsTruckMaterialId(mesMap);
  691. }else{
  692. //修改订单管理采购订单ID 以及物资子表 物资ID
  693. tmstruckWeightResultMapper.updateOmsTruckPlanId(mesMap);
  694. tmstruckWeightResultMapper.updateOmsTruckMaterialId(mesMap);
  695. }
  696. return mesMap.get("orderNumber") + "数据修改成功";
  697. }
  698. @Override
  699. public Boolean checkOrder(Map<String, Object> map) {
  700. //获取三个参数
  701. try {
  702. if (map != null) {
  703. JSONObject jsonObject = new JSONObject(map);
  704. FastDateFormat format = FastDateFormat.getInstance("yyyy-MM-dd HH:mm:ss");
  705. logger.info("=========" + "计量检查" + format.format(new Date()));
  706. logger.info(jsonObject.toString());
  707. logger.info("=========" + "计量检查" + format.format(new Date()));
  708. try{
  709. new Thread( new Runnable() {
  710. public void run(){
  711. try {
  712. newFileTool.newFile(jsonObject.toString(),"计量物流金蝶核对");
  713. } catch (IOException e) {
  714. e.printStackTrace();
  715. }
  716. }
  717. }).start();
  718. }catch (Exception e) {
  719. e.printStackTrace();
  720. }
  721. //判断该车的运输订单号是否是钢材且是否是正在作业中的,如果不是就返回true
  722. int i = tmstruckWeightResultMapper.checkOrderIsSteel(map);
  723. if (i == 0) {
  724. return true;
  725. }
  726. //判断该分录是不是在物流系统,如果不在返回true
  727. int j = tmstruckWeightResultMapper.checkOrder(map);
  728. if (j == 0) {
  729. //如果对不上,那么就将运输订单里面的状态变一下
  730. tmstruckWeightResultMapper.updateOmsRedQrCode(map);
  731. //推送数据
  732. utilsService.pushMesToWebsocket((String) map.get("carNo"), "计量");
  733. return false;
  734. }else{
  735. return true;
  736. }
  737. }
  738. } catch (Exception e) {
  739. return true;
  740. }
  741. return true;
  742. }
  743. }