TMSController.java 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709
  1. package com.steerinfo.dil.controller;
  2. import com.steerinfo.dil.annotaion.LogAround;
  3. import com.steerinfo.dil.annotaion.RequestLimit;
  4. import com.steerinfo.dil.feign.AmsFeign;
  5. import com.steerinfo.dil.feign.RmsFeign;
  6. import com.steerinfo.dil.feign.TmsFeign;
  7. import com.steerinfo.dil.mapper.UniversalMapper;
  8. import com.steerinfo.dil.util.BaseRESTfulController;
  9. import com.steerinfo.dil.util.ExcelToolUtils;
  10. import com.steerinfo.framework.controller.RESTfulResult;
  11. import io.swagger.annotations.ApiImplicitParam;
  12. import io.swagger.annotations.ApiImplicitParams;
  13. import io.swagger.annotations.ApiOperation;
  14. import org.springframework.beans.factory.annotation.Autowired;
  15. import org.springframework.web.bind.annotation.*;
  16. import org.springframework.web.multipart.MultipartFile;
  17. import java.io.File;
  18. import java.io.FileInputStream;
  19. import java.math.BigDecimal;
  20. import java.text.DateFormat;
  21. import java.text.ParseException;
  22. import java.text.SimpleDateFormat;
  23. import java.util.*;
  24. import java.util.stream.Collectors;
  25. import com.steerinfo.dil.util.DataChange;
  26. import org.springframework.web.multipart.MultipartRequest;
  27. /**
  28. * @author luobang
  29. * @create 2021-09-17 14:11
  30. */
  31. @RestController
  32. @RequestMapping("${api.version}/tms")
  33. public class TMSController extends BaseRESTfulController {
  34. @Autowired
  35. private TmsFeign tmsFeign;
  36. @Autowired
  37. private AmsFeign amsFeign;
  38. @Autowired
  39. private RmsFeign rmsFeign;
  40. @Autowired
  41. private UniversalMapper universalMapper;
  42. @ApiOperation(value = "车辆实绩")
  43. @ApiImplicitParams({
  44. @ApiImplicitParam(name = "map", value = "参数", required = false, dataType = "map"),
  45. @ApiImplicitParam(name = "apiId()", value = "动态表头", required = false, dataType = "Integer"),
  46. @ApiImplicitParam(name = "pageNum", value = "页码", required = false, dataType = "Integer"),
  47. @ApiImplicitParam(name = "pageSize", value = "页", required = false, dataType = "Integer"),
  48. })
  49. @PostMapping(value = "/getcomprehensiveresults")
  50. public Map<String, Object> getecomprehensiveresultslist(@RequestBody(required = false) Map<String, Object> map, Integer apiId,
  51. Integer pageNum,
  52. Integer pageSize) {
  53. return tmsFeign.getAmsSalaryContracList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  54. }
  55. @ApiOperation(value = "新增车辆实绩")
  56. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  57. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"计算公式"})
  58. @PostMapping("/addcomprehensiveresults")
  59. public Map<String, Object> insertcomprehensiveresults(@RequestBody(required = false) Map<String, Object> map) throws ParseException {
  60. if (!map.isEmpty()) {
  61. if (!map.get("resultTime").toString().isEmpty()) {
  62. SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
  63. Date resultTime = simpleDateFormat.parse(map.get("resultTime").toString());
  64. map.put("resultTime", resultTime);
  65. }
  66. }
  67. map.put("insertUsername", map.get("userName").toString());
  68. return tmsFeign.insertAmsSalaryContrac(map);
  69. }
  70. @ApiOperation(value = "车辆实绩删除")
  71. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  72. @PutMapping(value = "/comprehensiveresultslogicdelete")
  73. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"计算公式"})
  74. public Map<String, Object> comprehensiveresultsLogicDelete(@RequestBody(required = false) Map<String, Object> map) {
  75. return tmsFeign.logicdeleteAmsSaalryContrac(map);
  76. }
  77. @ApiOperation(value = "修改车辆实绩")
  78. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  79. @PutMapping(value = "/comprehensiveresultsupadete/{id}")
  80. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"计算公式"})
  81. public Map<String, Object> comprehensiveresultsUpdate(@PathVariable BigDecimal id, @RequestBody(required = false) Map<String, Object> map) {
  82. map.put("updateUsername", map.get("userName").toString());
  83. return tmsFeign.updateAmsSalaryContrac(id, map);
  84. }
  85. @ApiOperation(value = "派发运输订单")
  86. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  87. @PostMapping(value = "/dispatchOrder")
  88. @LogAround(foreignKeys = {"transOrderId"}, foreignKeyTypes = {"运输订单"})
  89. public Map<String, Object> dispatchOrder(@RequestBody(required = false) Map<String, Object> map) {
  90. return tmsFeign.dispatchOrder(map);
  91. }
  92. @ApiOperation(value = "批量派发运输订单")
  93. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  94. @PostMapping(value = "/batchDispatch")
  95. @LogAround(foreignKeys = {"transOrderId"}, foreignKeyTypes = {"运输订单"})
  96. public Map<String, Object> batchDispatch(@RequestBody(required = false) Map<String, Object> map) {
  97. return tmsFeign.batchDispatch(map);
  98. }
  99. @ApiOperation(value = "修改运输订单")
  100. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  101. @PostMapping(value = "/updateTransOrder")
  102. @LogAround(foreignKeys = {"transOrderId"}, foreignKeyTypes = {"运输订单"})
  103. public Map<String, Object> updateTransOrder(@RequestBody(required = false) Map<String, Object> map) {
  104. return tmsFeign.updateTransOrder(map);
  105. }
  106. @ApiOperation(value = "合并运输订单")
  107. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  108. @PostMapping(value = "/mergeTransOrder")
  109. @LogAround(foreignKeys = {"transOrderId"}, foreignKeyTypes = {"运输订单"})
  110. public Map<String, Object> mergeTransOrder(@RequestBody(required = false) Map<String, Object> map) {
  111. return tmsFeign.mergeTransOrder(map);
  112. }
  113. @ApiOperation(value = "更改运输订单状态")
  114. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  115. @PostMapping(value = "/changeTransOrder")
  116. @LogAround(foreignKeys = {"transOrderId"}, foreignKeyTypes = {"运输订单"})
  117. public Map<String, Object> changeTransOrder(@RequestBody(required = false) Map<String, Object> map) {
  118. return tmsFeign.changeTransOrder(map);
  119. }
  120. @ApiOperation(value = "司机接收运单")
  121. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  122. @PostMapping(value = "/receiptOrder")
  123. @LogAround(foreignKeys = {"transOrderId"}, foreignKeyTypes = {"运输订单"})
  124. public Map<String, Object> receiptOrder(@RequestBody(required = false) Map<String, Object> map) {
  125. return tmsFeign.receiptOrder(map);
  126. }
  127. @ApiOperation(value = "查询运输订单")
  128. @PostMapping("/getTransOrderList")
  129. public Map<String, Object> getTransOrderList(@RequestBody(required = false) Map<String, Object> map,
  130. Integer apiId,
  131. Integer pageNum,
  132. Integer pageSize) {
  133. return tmsFeign.getTransOrderList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  134. }
  135. @ApiOperation(value = "查询运输订单所有运输实绩")
  136. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  137. @PostMapping(value = "/getTransResult")
  138. public Map<String, Object> getTransResult(@RequestBody(required = false) Map<String, Object> map) {
  139. return tmsFeign.getTransResult(map);
  140. }
  141. @ApiOperation(value = "同步进厂")
  142. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  143. @PostMapping(value = "/syncEnfactoryResult")
  144. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"进厂实绩"})
  145. public Map<String, Object> syncEnfactoryResult(@RequestBody(required = false) Map<String, Object> map) {
  146. return tmsFeign.syncEnfactoryResult(map);
  147. }
  148. @ApiOperation(value = "同步出厂")
  149. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  150. @PostMapping(value = "/syncOutfactoryResult")
  151. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"出厂实绩"})
  152. public Map<String, Object> syncOutfactoryResult(@RequestBody(required = false) Map<String, Object> map) {
  153. return tmsFeign.syncOutfactoryResult(map);
  154. }
  155. @ApiOperation(value = "同步计量")
  156. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  157. @PostMapping(value = "/syncWeightResult")
  158. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"计量实绩"})
  159. public Map<String, Object> syncWeightResult(@RequestBody(required = false) Map<String, Object> map) {
  160. return tmsFeign.syncWeightResult(map);
  161. }
  162. @ApiOperation(value="计时")
  163. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  164. @PostMapping(value = "/startend")
  165. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"计时"})
  166. @RequestLimit
  167. public Map<String, Object> start(@RequestBody(required = false) Map<String, Object> map) {
  168. return tmsFeign.startend(map);
  169. }
  170. @ApiOperation(value = "查询计时")
  171. @PostMapping("/tmstimingresultsList")
  172. public Map<String, Object> tmstimingresultsList(@RequestBody(required = false) Map<String, Object> map,
  173. Integer apiId,
  174. Integer pageNum,
  175. Integer pageSize) {
  176. return tmsFeign.tmstimingresultsList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  177. }
  178. @ApiOperation(value = "修改计时")
  179. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  180. @PostMapping(value = "/tmstimingresultsUpdate")
  181. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"修改计时"})
  182. public Map<String, Object> tmstimingresultsUpdate(@RequestBody(required = false) Map<String, Object> map) {
  183. return tmsFeign.tmstimingresultsUpdate(map);
  184. }
  185. @ApiOperation(value = "销售派发运输订单")
  186. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  187. @PostMapping(value = "/saleDispatchOrder")
  188. @LogAround(foreignKeys = {"transOrderId"}, foreignKeyTypes = {"运输订单"})
  189. public Map<String, Object> saleDispatchOrder(@RequestBody(required = false) Map<String, Object> map) {
  190. return tmsFeign.saleDispatchOrder(map);
  191. }
  192. @ApiOperation(value = "查询销售运输订单")
  193. @PostMapping("/getSaleTransOrderList")
  194. public Map<String, Object> getSaleTransOrderList(@RequestBody(required = false) Map<String, Object> map,
  195. Integer apiId,
  196. Integer pageNum,
  197. Integer pageSize) {
  198. return tmsFeign.getSaleTransOrderList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  199. }
  200. @ApiOperation(value = "同步质检")
  201. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  202. @PostMapping(value = "/syncQualityResult")
  203. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"质检实绩"})
  204. public Map<String, Object> syncQualityResult(@RequestBody(required = false) Map<String, Object> map) {
  205. return tmsFeign.syncQualityResult(map);
  206. }
  207. @ApiOperation(value = "签到")
  208. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  209. @PostMapping(value = "/signIn")
  210. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"签到实绩"})
  211. public Map<String, Object> signIn(@RequestBody(required = false) Map<String, Object> map) {
  212. return tmsFeign.signIn(map);
  213. }
  214. @ApiOperation(value = "换车头")
  215. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  216. @PostMapping(value = "/replaceFront")
  217. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"换车头实绩"})
  218. public Map<String, Object> replaceFront(@RequestBody(required = false) Map<String, Object> map) {
  219. return tmsFeign.replaceFront(map);
  220. }
  221. @ApiOperation(value = "装货")
  222. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  223. @PostMapping(value = "/load")
  224. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"装货实绩"})
  225. public Map<String, Object> load(@RequestBody(required = false) Map<String, Object> map) {
  226. return tmsFeign.load(map);
  227. }
  228. @ApiOperation(value = "装货修改")
  229. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  230. @PostMapping(value = "/loadUpd")
  231. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"装货实绩"})
  232. public Map<String, Object> loadUpd(@RequestBody(required = false) Map<String, Object> map) {
  233. return tmsFeign.loadUpd(map);
  234. }
  235. @ApiOperation(value = "卸货")
  236. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  237. @PostMapping(value = "/unload")
  238. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"卸货实绩"})
  239. public Map<String, Object> unload(@RequestBody(required = false) Map<String, Object> map) {
  240. return tmsFeign.unload(map);
  241. }
  242. @ApiOperation(value = "卸货修改")
  243. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  244. @PostMapping(value = "/unloadUpd")
  245. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"卸货实绩"})
  246. public Map<String, Object> unloadUpd(@RequestBody(required = false) Map<String, Object> map) {
  247. return tmsFeign.unloadUpd(map);
  248. }
  249. @ApiOperation(value = "抵达")
  250. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  251. @PostMapping(value = "/arrival")
  252. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"抵达实绩"})
  253. public Map<String, Object> arrival(@RequestBody(required = false) Map<String, Object> map) {
  254. return tmsFeign.arrival(map);
  255. }
  256. @ApiOperation(value = "签收")
  257. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  258. @PostMapping(value = "/receipt")
  259. @LogAround(foreignKeys = {"resultId"}, foreignKeyTypes = {"签收实绩"})
  260. public Map<String, Object> receipt(@RequestBody(required = false) Map<String, Object> map) {
  261. return tmsFeign.receipt(map);
  262. }
  263. @ApiOperation(value = "查询厂内车辆数")
  264. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  265. @PostMapping(value = "/getCountEnfactory")
  266. public Map<String, Object> getCountEnfactory(@RequestBody(required = false) Map<String, Object> map) {
  267. return tmsFeign.getCountEnfactory(map == null ? new HashMap<>() : map);
  268. }
  269. @ApiOperation(value = "查询签到")
  270. @PostMapping("/getSignInResultList")
  271. public Map<String, Object> getSignInResultList(@RequestBody(required = false) Map<String, Object> map,
  272. Integer apiId,
  273. Integer pageNum,
  274. Integer pageSize) {
  275. return tmsFeign.getSignInResultList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  276. }
  277. @ApiOperation(value = "查询换车头")
  278. @PostMapping("/getReplaceFrontResultList")
  279. public Map<String, Object> getReplaceFrontResultList(@RequestBody(required = false) Map<String, Object> map,
  280. Integer apiId,
  281. Integer pageNum,
  282. Integer pageSize) {
  283. return tmsFeign.getReplaceFrontResultList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  284. }
  285. @ApiOperation(value = "查询进厂")
  286. @PostMapping("/getEnfactoryResultList")
  287. public Map<String, Object> getEnfactoryResultList(@RequestBody(required = false) Map<String, Object> map,
  288. Integer apiId,
  289. Integer pageNum,
  290. Integer pageSize) {
  291. return tmsFeign.getEnfactoryResultList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  292. }
  293. @ApiOperation(value = "查询出厂")
  294. @PostMapping("/getOutfactoryResultList")
  295. public Map<String, Object> getTmsOutfactoryResultList
  296. (@RequestBody(required = false) Map<String, Object> map,
  297. Integer apiId,
  298. Integer pageNum,
  299. Integer pageSize) {
  300. return tmsFeign.getOutfactoryResultList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  301. }
  302. @ApiOperation(value = "查询装货")
  303. @PostMapping("/getLoadResultList")
  304. public Map<String, Object> getLoadResultList(@RequestBody(required = false) Map<String, Object> map,
  305. Integer apiId,
  306. Integer pageNum,
  307. Integer pageSize) {
  308. return tmsFeign.getLoadResultList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  309. }
  310. @ApiOperation(value = "查询卸货")
  311. @PostMapping("/getUnloadResultList")
  312. public Map<String, Object> getUnloadResultList(@RequestBody(required = false) Map<String, Object> map,
  313. Integer apiId,
  314. Integer pageNum,
  315. Integer pageSize) {
  316. return tmsFeign.getUnloadResultList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  317. }
  318. @ApiOperation(value = "查询计量")
  319. @PostMapping("/getWeightResultList")
  320. public Map<String, Object> getWeightResultList(@RequestBody(required = false) Map<String, Object> map,
  321. Integer apiId,
  322. Integer pageNum,
  323. Integer pageSize) {
  324. return tmsFeign.getWeightResultList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  325. }
  326. @ApiOperation(value = "查询质检")
  327. @PostMapping("/getQualityResultList")
  328. public Map<String, Object> getQualityResult(@RequestBody(required = false) Map<String, Object> map,
  329. Integer apiId,
  330. Integer pageNum,
  331. Integer pageSize) {
  332. return tmsFeign.getQualityResultList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  333. }
  334. @ApiOperation(value = "查询抵达")
  335. @PostMapping("/getArrivalResultList")
  336. public Map<String, Object> getArrivalResultList(@RequestBody(required = false) Map<String, Object> map,
  337. Integer apiId,
  338. Integer pageNum,
  339. Integer pageSize) {
  340. return tmsFeign.getArrivalResultList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  341. }
  342. @ApiOperation(value = "查询签收")
  343. @PostMapping("/getReceiptResultList")
  344. public Map<String, Object> getReceiptResultList(@RequestBody(required = false) Map<String, Object> map,
  345. Integer apiId,
  346. Integer pageNum,
  347. Integer pageSize) {
  348. return tmsFeign.getReceiptResultList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  349. }
  350. @ApiOperation(value = "采购火运装货作业")
  351. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  352. @PostMapping(value = "/purchaseTrainLoad")
  353. // @LogAround(foreignKeys = {"resultId"},foreignKeyTypes = {"装货实绩"})
  354. public Map<String, Object> purchaseTrainLoad(@RequestBody MultipartFile file,
  355. String businessType,
  356. String userId,
  357. String userName) throws Exception {
  358. Map<String, Object> map = new HashMap<>();
  359. //获取Excel中包含的对象数组
  360. List<Map<String, Object>> list = ExcelToolUtils.getExcelList(file, 0);
  361. map.put("list", list);
  362. //统计通知单的重量车数和车牌号
  363. Set<String> capacitySet = new HashSet<>();//车牌号
  364. for (Map<String, Object> item : list) {
  365. //校验行
  366. if(item.get("通知单号")==null || item.get("通知单号").equals("")
  367. || item.get("车号")==null || item.get("车号").equals("")
  368. || item.get("装车日期")==null || item.get("装车日期").equals("")
  369. || item.get("净重")==null || item.get("净重").equals("")
  370. || item.get("皮重")==null || item.get("皮重").equals("")
  371. || item.get("毛重")==null || item.get("毛重").equals("")){
  372. throw new Exception("单元格数据异常(通知单号/车号/装车日期/净重/皮重/毛重),请检查模板或数据是否正确!");
  373. }
  374. //通知单统计
  375. String requirementNumber = item.get("通知单号").toString();
  376. if (map.get("requirementNumber") != null) {
  377. if (map.get("requirementNumber").equals(requirementNumber)) {
  378. //已存在,修改
  379. BigDecimal weight = DataChange.dataToBigDecimal(map.get("weight"));
  380. BigDecimal truckNumber = DataChange.dataToBigDecimal(map.get("truckNumber"));
  381. String loadTime = map.get("loadTime").toString();
  382. weight = weight.add(DataChange.dataToBigDecimal(item.get("净重")));
  383. truckNumber = truckNumber.add(new BigDecimal(1));
  384. map.put("weight", weight);
  385. map.put("truckNumber", truckNumber);
  386. if(!loadTime.equals(item.get("装车日期").toString())){
  387. throw new Exception("同一个Excel只允许一批车辆,请检查装车日期!");
  388. }
  389. } else {
  390. throw new Exception("同一个Excel文件中只允许有一个通知单号!");
  391. }
  392. } else {
  393. //不存在,新增
  394. BigDecimal weight = DataChange.dataToBigDecimal(item.get("净重"));
  395. BigDecimal truckNumber = new BigDecimal(1);
  396. String loadTime = item.get("装车日期").toString();
  397. map.put("requirementNumber", requirementNumber);
  398. map.put("weight", weight);
  399. map.put("truckNumber", truckNumber);
  400. map.put("loadTime",loadTime);
  401. }
  402. //车牌号去重
  403. capacitySet.add(item.get("车号").toString());
  404. }
  405. //校验当前excel是否已经导入过
  406. if (universalMapper.countTrainLoad(map) > 0) {
  407. throw new Exception("存在重复的装车信息!不允许重复导入!");
  408. }
  409. //新增火车运力资源
  410. String[] capacities = capacitySet.toArray(new String[0]);//车牌号
  411. if (capacities.length != list.size()) {
  412. throw new Exception("车号不允许重复!");
  413. } else {
  414. try{
  415. new Runnable() {
  416. @Override
  417. public void run() {
  418. Map<String, Object> capacityMap = new HashMap<>();
  419. capacityMap.put("capacities", capacities);
  420. capacityMap.put("userId", userId);
  421. capacityMap.put("userName", userName);
  422. rmsFeign.batchInsertCapacityTrain(capacityMap);
  423. }
  424. }.run();
  425. }catch (Exception e){e.printStackTrace();}
  426. }
  427. //新增AMS及TMS
  428. map.put("userId",userId);
  429. map.put("userName",userName);
  430. map.put("businessType",businessType);
  431. return tmsFeign.purchaseTrainLoad(map);
  432. }
  433. @ApiOperation(value = "查询采购火运装货")
  434. @PostMapping("/purchaseTrainLoadList")
  435. public Map<String, Object> purchaseTrainLoadList(@RequestBody(required = false) Map<String, Object> map,
  436. Integer apiId,
  437. Integer pageNum,
  438. Integer pageSize) {
  439. return tmsFeign.purchaseTrainLoadList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  440. }
  441. @ApiOperation(value = "采购火运计量作业")
  442. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  443. @PostMapping(value = "/purchaseTrainWeight")
  444. // @LogAround(foreignKeys = {"resultId"},foreignKeyTypes = {"计量实绩"})
  445. public Map<String, Object> purchaseTrainWeight(@RequestBody MultipartFile file,
  446. String businessType,
  447. String userId,
  448. String userName) throws Exception {
  449. Map<String, Object> map = new HashMap<>();
  450. //获取Excel中包含的对象数组
  451. List<Map<String, Object>> list = ExcelToolUtils.getExcelList(file, 0);
  452. map.put("list", list);
  453. Set<String> capacitySet = new HashSet<>();//车牌号
  454. for (Map<String, Object> item : list) {
  455. //校验行
  456. if(item.get("通知单号")==null || item.get("通知单号").equals("")
  457. || item.get("车号")==null || item.get("车号").equals("")
  458. || item.get("计量日期")==null || item.get("计量日期").equals("")
  459. || item.get("净重")==null || item.get("净重").equals("")
  460. || item.get("皮重")==null || item.get("皮重").equals("")
  461. || item.get("毛重")==null || item.get("毛重").equals("")){
  462. throw new Exception("单元格数据异常(通知单号/车号/计量日期/净重/皮重/毛重),请检查模板或数据是否正确!");
  463. }
  464. //校验数据
  465. String requirementNumber = item.get("通知单号").toString();
  466. if (map.get("requirementNumber") != null) {
  467. if (map.get("requirementNumber").equals(requirementNumber)) {
  468. String weightTime = map.get("weightTime").toString();
  469. if(!weightTime.equals(item.get("计量日期").toString())){
  470. throw new Exception("同一个Excel只允许一批车辆,请检查计量日期!");
  471. }
  472. } else {
  473. throw new Exception("同一个Excel文件中只允许有一个通知单号!");
  474. }
  475. } else {
  476. //不存在,新增
  477. map.put("requirementNumber", requirementNumber);
  478. map.put("weightTime",item.get("计量日期").toString());
  479. }
  480. //车牌号去重
  481. capacitySet.add(item.get("车号").toString());
  482. }
  483. String[] capacities = capacitySet.toArray(new String[0]);//车牌号
  484. if (capacities.length != list.size()) {
  485. throw new Exception("车号不允许重复!");
  486. }
  487. map.put("userId",userId);
  488. map.put("userName",userName);
  489. map.put("businessType",businessType);
  490. //获取火车运单及计量详情
  491. List<Map<String,Object>> orderList = universalMapper.findTrainWeight(map);
  492. if (orderList.size() <= 0) {
  493. throw new Exception("未查询到装车信息,请先上传装车作业!");
  494. }
  495. map.put("orderList",orderList);
  496. //新增TMS
  497. return tmsFeign.purchaseTrainWeight(map);
  498. }
  499. @ApiOperation(value = "查询采购火运计量")
  500. @PostMapping("/purchaseTrainWeightList")
  501. public Map<String, Object> purchaseTrainWeightList(@RequestBody(required = false) Map<String, Object> map,
  502. Integer apiId,
  503. Integer pageNum,
  504. Integer pageSize) {
  505. return tmsFeign.purchaseTrainWeightList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  506. }
  507. @ApiOperation(value = "采购火运卸车作业")
  508. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  509. @PostMapping(value = "/purchaseTrainUnload")
  510. // @LogAround(foreignKeys = {"resultId"},foreignKeyTypes = {"计量实绩"})
  511. public Map<String, Object> purchaseTrainUnload(@RequestBody MultipartFile file,
  512. String businessType,
  513. String userId,
  514. String userName) throws Exception {
  515. Map<String, Object> map = new HashMap<>();
  516. //获取Excel中包含的对象数组
  517. List<Map<String, Object>> list = ExcelToolUtils.getExcelList(file, 0);
  518. map.put("list", list);
  519. Set<String> capacitySet = new HashSet<>();//车牌号
  520. for (Map<String, Object> item : list) {
  521. //校验行
  522. if(item.get("通知单号")==null || item.get("通知单号").equals("")
  523. || item.get("车号")==null || item.get("车号").equals("")
  524. || item.get("卸车日期")==null || item.get("卸车日期").equals("")
  525. || item.get("净重")==null || item.get("净重").equals("")){
  526. throw new Exception("单元格数据异常(通知单号/车号/卸车日期/净重),请检查模板或数据是否正确!");
  527. }
  528. //校验数据
  529. String requirementNumber = item.get("通知单号").toString();
  530. BigDecimal weight = DataChange.dataToBigDecimal(item.get("净重"));
  531. if (map.get("requirementNumber") != null) {
  532. if (map.get("requirementNumber").equals(requirementNumber)) {
  533. String unloadTime = map.get("unloadTime").toString();
  534. if(!unloadTime.equals(item.get("卸车日期").toString())){
  535. throw new Exception("同一个Excel只允许一批车辆,请检查卸车日期!");
  536. }
  537. } else {
  538. throw new Exception("同一个Excel文件中只允许有一个通知单号!");
  539. }
  540. map.put("weight", weight.add(DataChange.dataToBigDecimal(map.get("weight"))));
  541. } else {
  542. //不存在,新增
  543. map.put("requirementNumber", requirementNumber);
  544. map.put("weight", weight);
  545. map.put("unloadTime",item.get("卸车日期").toString());
  546. }
  547. //车牌号去重
  548. capacitySet.add(item.get("车号").toString());
  549. }
  550. String[] capacities = capacitySet.toArray(new String[0]);//车牌号
  551. if (capacities.length != list.size()) {
  552. throw new Exception("车号不允许重复!");
  553. }
  554. map.put("userId",userId);
  555. map.put("userName",userName);
  556. map.put("businessType",businessType);
  557. //获取火车运单及计量详情
  558. List<Map<String,Object>> orderList = universalMapper.findTrainUnload(map);
  559. if (orderList.size() <= 0) {
  560. throw new Exception("未查询到装车信息,请先上传装车作业!");
  561. }
  562. map.put("orderList",orderList);
  563. //新增TMS
  564. return tmsFeign.purchaseTrainUnload(map);
  565. }
  566. @ApiOperation(value = "查询采购火运卸车")
  567. @PostMapping("/purchaseTrainUnloadList")
  568. public Map<String, Object> purchaseTrainUnloadList(@RequestBody(required = false) Map<String, Object> map,
  569. Integer apiId,
  570. Integer pageNum,
  571. Integer pageSize) {
  572. return tmsFeign.purchaseTrainUnloadList(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  573. }
  574. @ApiOperation(value = "更改销售运输订单状态")
  575. @ApiImplicitParam(name = "map", value = "JSON格式数据", required = true, dataType = "Map<String, Object>")
  576. @PostMapping(value = "/changeSaleTransOrder")
  577. @LogAround(foreignKeys = {"transOrderId"}, foreignKeyTypes = {"销售运输订单"})
  578. public Map<String, Object> changeSaleTransOrder(@RequestBody(required = false) Map<String, Object> map) {
  579. return tmsFeign.changeSaleTransOrder(map);
  580. }
  581. @ApiOperation(value = "查询司机运输汇总")
  582. @PostMapping("/getDriverTotalResult")
  583. public Map<String, Object> getDriverTotalResult(@RequestBody(required = false) Map<String, Object> map,
  584. Integer apiId,
  585. Integer pageNum,
  586. Integer pageSize) {
  587. return tmsFeign.getDriverTotalResult(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  588. }
  589. @ApiOperation(value = "查询车辆运输汇总")
  590. @PostMapping("/getCapacityTotalResult")
  591. public Map<String, Object> getCapacityTotalResult(@RequestBody(required = false) Map<String, Object> map,
  592. Integer apiId,
  593. Integer pageNum,
  594. Integer pageSize) {
  595. return tmsFeign.getDriverTotalResult(map == null ? new HashMap<>() : map, apiId, pageNum, pageSize);
  596. }
  597. @ApiOperation("生产物流-调度任务新增")
  598. @PostMapping("/dispatchTask")
  599. Map<String,Object> dispatchTask(@RequestBody Map<String,Object> map) {
  600. return tmsFeign.dispatchTask(map);
  601. }
  602. @ApiOperation("获取销售派车单信息")
  603. @PostMapping("/getDlivDirnoSeqList/{id}")
  604. public RESTfulResult getDlivDirnoSeqList(@PathVariable("id") String id) {
  605. return tmsFeign.getDlivDirnoSeqList(id);
  606. }
  607. @ApiOperation("修改销售派车单信息")
  608. @PostMapping("/updateDlivDirnoSeq")
  609. @LogAround(foreignKeys = {"planChildId"}, foreignKeyTypes = {"修改销售运单"})
  610. public RESTfulResult updateDlivDirnoSeq(@RequestBody Map<String,Object> map) {
  611. return tmsFeign.updateDlivDirnoSeq(map);
  612. }
  613. @ApiOperation("查询销售派车单装车信息")
  614. @PostMapping("/selectDlivDirnoSeqDetails")
  615. public RESTfulResult selectDlivDirnoSeqDetails(@RequestBody Map<String,Object> map) {
  616. return tmsFeign.selectDlivDirnoSeqDetails(map);
  617. }
  618. @ApiOperation("查询订单厂内轨迹")
  619. @PostMapping("/getPathByOrder")
  620. public RESTfulResult getPathByOrder(@RequestBody Map<String,Object> map) {
  621. return tmsFeign.getPathByOrder(map);
  622. }
  623. @ApiOperation("上传定位,更新路径")
  624. @PostMapping("/uploadLocation")
  625. public RESTfulResult uploadLocation(@RequestBody Map<String,Object> map) {
  626. return tmsFeign.uploadLocation(map);
  627. }
  628. @ApiOperation("实收吨数")
  629. @PostMapping("/updateWeight")
  630. public RESTfulResult updateWeight(@RequestBody Map<String,Object> map) {
  631. return tmsFeign.updateWeight(map);
  632. }
  633. }