NoCarController.java 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702
  1. package com.jkcredit.invoice.controller.business;
  2. import cn.afterturn.easypoi.excel.ExcelImportUtil;
  3. import cn.afterturn.easypoi.excel.entity.ImportParams;
  4. import com.alibaba.fastjson.JSON;
  5. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  6. import com.jkcredit.invoice.annotation.LoginRequired;
  7. import com.jkcredit.invoice.mapper.waybill.NoCarWaybillMapper;
  8. import com.jkcredit.invoice.model.entity.calculate.NoCarCalculateInfor;
  9. import com.jkcredit.invoice.model.entity.customer.CustomerCarRec;
  10. import com.jkcredit.invoice.model.entity.customer.CustomerOper;
  11. import com.jkcredit.invoice.model.entity.invoice.BillInvoice;
  12. import com.jkcredit.invoice.model.entity.waybill.NoCarWayBill;
  13. import com.jkcredit.invoice.model.vo.CodeAndNumVo;
  14. import com.jkcredit.invoice.service.calculateinfor.NoCarCalculateInfoService;
  15. import com.jkcredit.invoice.service.customer.CustomerOperService;
  16. import com.jkcredit.invoice.service.lowerservice.NoCarService;
  17. import com.jkcredit.invoice.service.nocar.NoCarBillWayImportService;
  18. import com.jkcredit.invoice.service.nocar.NoCarBillWayService;
  19. import com.jkcredit.invoice.service.nocar.NoCarRecService;
  20. import com.jkcredit.invoice.service.nocar.NocarInvoiceService;
  21. import com.jkcredit.invoice.util.RespR;
  22. import io.swagger.annotations.Api;
  23. import io.swagger.annotations.ApiOperation;
  24. import lombok.extern.slf4j.Slf4j;
  25. import org.apache.poi.util.IOUtils;
  26. import org.springframework.beans.factory.annotation.Autowired;
  27. import org.springframework.util.StringUtils;
  28. import org.springframework.web.bind.annotation.*;
  29. import org.springframework.web.multipart.MultipartFile;
  30. import javax.servlet.http.HttpServletResponse;
  31. import java.io.*;
  32. import java.net.URLEncoder;
  33. import java.text.DateFormat;
  34. import java.text.SimpleDateFormat;
  35. import java.util.ArrayList;
  36. import java.util.Arrays;
  37. import java.util.List;
  38. @Api(tags = "无车操作")
  39. @RestController
  40. @RequestMapping(value = {"/noCar"})
  41. @Slf4j
  42. /**
  43. * @Description 无车操作
  44. * @Author mashengyi
  45. * @Date 2022/2/8 18:15
  46. * @Param
  47. * @Return
  48. * @Exception
  49. *
  50. */
  51. public class NoCarController {
  52. @Autowired
  53. NoCarRecService noCarRecService;
  54. @Autowired
  55. NoCarBillWayService noCarBillWayService;
  56. @Autowired
  57. NoCarBillWayImportService noCarBillWayImportService;
  58. @Autowired
  59. NocarInvoiceService nocarInvoiceService;
  60. @Autowired
  61. NoCarCalculateInfoService noCarCalculateInfoService;
  62. @Autowired
  63. NoCarWaybillMapper noCarWaybillMapper;
  64. @Autowired
  65. NoCarService noCarService;
  66. @Autowired
  67. CustomerOperService customerOperService;
  68. /**
  69. * 分页查询无车备案信息
  70. *
  71. * @param page 参数集
  72. * @return 用户集合
  73. */
  74. @PostMapping("/findCarRec")
  75. @ApiOperation(value="分页查询无车/自有车备案信息", notes="分页查询无车/自有车备案信息")
  76. @LoginRequired
  77. public RespR getCustomersByPage(Page page, CustomerCarRec customerCarRec) {
  78. try {
  79. if(!StringUtils.isEmpty(customerCarRec.getStartTime()) && !"null".equals(customerCarRec.getStartTime())){
  80. String [] res = customerCarRec.getStartTime().split(",");
  81. customerCarRec.setStartTime(res[0]);
  82. customerCarRec.setEndTime(res[1].replace("00:00:00","23:59:59"));
  83. }else{
  84. customerCarRec.setStartTime(null);
  85. }
  86. RespR respR = new RespR(noCarRecService.findByPageAndCarRec(page, customerCarRec));
  87. return respR;
  88. }catch (Exception e){
  89. e.printStackTrace();
  90. return new RespR(false,e.getMessage());
  91. }
  92. }
  93. public void setTimeDue(NoCarWayBill noCarWayBill){
  94. if(!StringUtils.isEmpty(noCarWayBill.getStartBegin()) && !"null".equals(noCarWayBill.getStartBegin())){
  95. String [] res = noCarWayBill.getStartBegin().split(",");
  96. noCarWayBill.setStartBegin(res[0]);
  97. noCarWayBill.setStartEnd(res[1].replace("00:00:00","23:59:59"));
  98. }else{
  99. noCarWayBill.setStartBegin(null);
  100. }
  101. if(!StringUtils.isEmpty(noCarWayBill.getEndBegin()) && !"null".equals(noCarWayBill.getEndBegin())){
  102. String [] res = noCarWayBill.getEndBegin().split(",");
  103. noCarWayBill.setEndBegin(res[0]);
  104. noCarWayBill.setEndEnd(res[1].replace("00:00:00","23:59:59"));
  105. }else{
  106. noCarWayBill.setEndBegin(null);
  107. }
  108. }
  109. public void setTimeDue2(NoCarWayBill noCarWayBill){
  110. if("null".equals(noCarWayBill.getStartBegin())){
  111. noCarWayBill.setStartBegin(null);
  112. }
  113. if("null".equals(noCarWayBill.getStartEnd())){
  114. noCarWayBill.setStartEnd(null);
  115. }
  116. if("null".equals(noCarWayBill.getEndBegin())){
  117. noCarWayBill.setEndBegin(null);
  118. }
  119. if("null".equals(noCarWayBill.getEndEnd())){
  120. noCarWayBill.setEndEnd(null);
  121. }
  122. }
  123. /**
  124. * 分页查询运单信息
  125. *
  126. * @param page 参数集
  127. * @return 用户集合
  128. */
  129. @PostMapping("/findBillWay")
  130. @ApiOperation(value="分页查询无车运单信息", notes="分页查询无车运单信息")
  131. @LoginRequired
  132. public RespR findBillWay(Page page, NoCarWayBill noCarWayBill) {
  133. try {
  134. setTimeDue(noCarWayBill);
  135. setBillNums(noCarWayBill);
  136. RespR respR = new RespR(noCarBillWayService.findByPageAndWayBill(page, noCarWayBill));
  137. return respR;
  138. }catch (Exception e){
  139. e.printStackTrace();
  140. return new RespR(false,e.getMessage());
  141. }
  142. }
  143. public void setBillNums(NoCarWayBill noCarWayBill){
  144. String billNums = noCarWayBill.getBillNum();
  145. if(!StringUtils.isEmpty(billNums)){
  146. String [] billNumArr = billNums.split(",");
  147. noCarWayBill.setBillNums(Arrays.asList(billNumArr));
  148. }
  149. }
  150. /**
  151. * 分页查询客户运单信息
  152. *
  153. * @param page 参数集
  154. * @return 用户集合
  155. */
  156. @PostMapping("/findBillWayCust")
  157. @ApiOperation(value="分页查询无车运单信息", notes="分页查询无车运单信息")
  158. @LoginRequired
  159. public RespR findBillWayCust(Page page, NoCarWayBill noCarWayBill) {
  160. try {
  161. setTimeDue2(noCarWayBill);
  162. setBillNums(noCarWayBill);
  163. noCarWayBill.setBatchNum("1");
  164. RespR respR = new RespR(noCarBillWayService.findByPageAndWayBill(page, noCarWayBill));
  165. return respR;
  166. }catch (Exception e){
  167. e.printStackTrace();
  168. return new RespR(false,e.getMessage());
  169. }
  170. }
  171. /**
  172. * 分页查询运单信息
  173. *
  174. * @param page 参数集
  175. * @return 用户集合
  176. */
  177. @PostMapping("/findImportBillWay")
  178. @ApiOperation(value="分页查询无车运单信息", notes="分页查询无车运单信息")
  179. @LoginRequired
  180. public RespR findImportBillWay(Page page, NoCarWayBill noCarWayBill) {
  181. try {
  182. setTimeDue(noCarWayBill);
  183. RespR respR = new RespR(noCarBillWayImportService.findByPageAndWayBill(page, noCarWayBill));
  184. return respR;
  185. }catch (Exception e){
  186. e.printStackTrace();
  187. return new RespR(false,e.getMessage());
  188. }
  189. }
  190. /**
  191. * 重新获取发票并更新状态
  192. *
  193. * @return 用户集合
  194. */
  195. @PostMapping("/updateStatus")
  196. @ApiOperation(value="重新获取发票并更新状态", notes="重新获取发票并更新状态")
  197. @LoginRequired
  198. public RespR updateStatus(String noCarWayBillStr) {
  199. List<NoCarWayBill> noCarWayBills = JSON.parseArray(noCarWayBillStr,NoCarWayBill.class);
  200. if(noCarWayBills!=null && noCarWayBills.size()>0){
  201. noCarWayBills.stream().forEach(noCarWayBill -> {
  202. try {
  203. noCarWayBill.setBillwayStatus(-5);
  204. noCarService.getInvoiceByWayBillNumReal(noCarWayBill,false);
  205. }catch (Exception e){
  206. log.info("1111111111222222"+e.getMessage());
  207. }
  208. });
  209. }
  210. return new RespR("更新成功");
  211. }
  212. /**
  213. * 分页查询异常运单信息
  214. *
  215. * @param page 参数集
  216. * @return 用户集合
  217. */
  218. @PostMapping("/findBillWayException")
  219. @ApiOperation(value="分页查询异常运单信息", notes="分页查询异常运单信息")
  220. @LoginRequired
  221. public RespR findBillWayException(Page page, NoCarWayBill noCarWayBill) {
  222. try {
  223. setTimeDue(noCarWayBill);
  224. RespR respR = new RespR(noCarBillWayService.findByPageAndWayBillException(page, noCarWayBill));
  225. return respR;
  226. }catch (Exception e){
  227. e.printStackTrace();
  228. return new RespR(false,e.getMessage());
  229. }
  230. }
  231. /**
  232. * 分页查询无车运单信息
  233. *
  234. * @param page 参数集
  235. * @return 用户集合
  236. */
  237. @PostMapping("/findNocarInvoices")
  238. @ApiOperation(value="分页查询无车发票信息", notes="分页查询无车发票信息")
  239. @LoginRequired
  240. public RespR findNocarInvoices(Page page, BillInvoice billInvoice) {
  241. try {
  242. setParams(billInvoice);
  243. RespR respR = new RespR(nocarInvoiceService.findByPageAndInvoice(page, billInvoice));
  244. return respR;
  245. }catch (Exception e){
  246. e.printStackTrace();
  247. return new RespR(false,e.getMessage());
  248. }
  249. }
  250. private void setParams(BillInvoice billInvoice){
  251. if(!StringUtils.isEmpty(billInvoice.getInvoiceMakeTime()) && !"null".equals(billInvoice.getInvoiceMakeTime())){
  252. String [] res =billInvoice.getInvoiceMakeTime().split(",");
  253. billInvoice.setInvoiceMakeStart(res[0]);
  254. billInvoice.setInvoiceMakeEnd(res[1].replace("00:00:00","23:59:59"));
  255. }
  256. if(!StringUtils.isEmpty(billInvoice.getCalculateTime()) && !"null".equals(billInvoice.getCalculateTime())){
  257. String [] res =billInvoice.getCalculateTime().split(",");
  258. billInvoice.setCalculateTimeStart(res[0]);
  259. billInvoice.setCalculateTimeEnd(res[1].replace("00:00:00","23:59:59"));
  260. }
  261. if(!StringUtils.isEmpty(billInvoice.getWaybillNum())){
  262. String [] billNumArr = billInvoice.getWaybillNum().split(",");
  263. billInvoice.setWaybillNums(Arrays.asList(billNumArr));
  264. }
  265. if(!StringUtils.isEmpty(billInvoice.getInvoiceCode()) && billInvoice.getInvoiceCode().indexOf(',')>0){
  266. String [] invoiceCodeArr = billInvoice.getInvoiceCode().split(",");
  267. String [] invoiceNumArr=null;
  268. if( billInvoice.getInvoiceNum()!=null){
  269. invoiceNumArr = billInvoice.getInvoiceNum().split(",");
  270. }
  271. List<CodeAndNumVo> codeAndNumVos = new ArrayList<>();
  272. for (int i=0;i<invoiceCodeArr.length;i++){
  273. CodeAndNumVo codeAndNumVo = new CodeAndNumVo();
  274. codeAndNumVo.setCode(invoiceCodeArr[i]);
  275. if(invoiceNumArr!=null && invoiceNumArr.length>=i+1){
  276. codeAndNumVo.setNum(invoiceNumArr[i]);
  277. }else{
  278. codeAndNumVo.setNum("");
  279. }
  280. codeAndNumVos.add(codeAndNumVo);
  281. }
  282. billInvoice.setCodeAndNumVos(codeAndNumVos);
  283. }
  284. }
  285. /**
  286. * 批量查询无车发票信息
  287. *
  288. * @param file 参数集
  289. * @return
  290. */
  291. @PostMapping("/batchImportNocarInvoices")
  292. @ApiOperation(value="批量查询无车发票信息", notes="批量查询无车发票信息")
  293. @LoginRequired
  294. public RespR batchImportNocarInvoices(@RequestParam("file") MultipartFile file) {
  295. try {
  296. ImportParams params = new ImportParams();
  297. params.setTitleRows(1);
  298. params.setHeadRows(1);
  299. List<BillInvoice> list = ExcelImportUtil.importExcel(file.getInputStream(), BillInvoice.class,params) ;
  300. RespR respR = nocarInvoiceService.findImportNocarInvoices(list);
  301. return respR;
  302. }catch (Exception e){
  303. e.printStackTrace();
  304. return new RespR(false,e.getMessage());
  305. }
  306. }
  307. /**
  308. * 批量查询无车运单信息
  309. *
  310. * @param file 参数集
  311. * @return
  312. */
  313. @PostMapping("/batchImportNocarBillWay")
  314. @ApiOperation(value="批量查询无车运单信息", notes="批量查询无车运单信息")
  315. @LoginRequired
  316. public RespR batchImportNocarBillWay(@RequestParam("file") MultipartFile file) {
  317. try {
  318. ImportParams params = new ImportParams();
  319. params.setTitleRows(1);
  320. params.setHeadRows(1);
  321. List<NoCarWayBill> list = ExcelImportUtil.importExcel(file.getInputStream(), NoCarWayBill.class,params) ;
  322. RespR respR = noCarBillWayService.findImportNocarBillWay(list);
  323. return respR;
  324. }catch (Exception e){
  325. e.printStackTrace();
  326. return new RespR(false,e.getMessage());
  327. }
  328. }
  329. /**
  330. * 分页查询无车运单统计信息
  331. *
  332. * @param billInvoice
  333. * @return 用户集合
  334. */
  335. @PostMapping("/findNocarInvoicesStatic")
  336. @ApiOperation(value="分页查询无车发票统计信息", notes="分页查询无车发票统计信息")
  337. @LoginRequired
  338. public RespR findNocarInvoicesStatic(BillInvoice billInvoice) {
  339. try {
  340. if(!StringUtils.isEmpty(billInvoice.getInvoiceMakeTime()) && !"null".equals(billInvoice.getInvoiceMakeTime())){
  341. String [] res =billInvoice.getInvoiceMakeTime().split(",");
  342. billInvoice.setInvoiceMakeStart(res[0]);
  343. billInvoice.setInvoiceMakeEnd(res[1].replace("00:00:00","23:59:59"));
  344. }
  345. if(!StringUtils.isEmpty(billInvoice.getCalculateTime()) && !"null".equals(billInvoice.getCalculateTime())){
  346. String [] res =billInvoice.getCalculateTime().split(",");
  347. billInvoice.setCalculateTimeStart(res[0]);
  348. billInvoice.setCalculateTimeEnd(res[1].replace("00:00:00","23:59:59"));
  349. }
  350. RespR respR = new RespR(nocarInvoiceService.findInvoiceStatics(billInvoice));
  351. return respR;
  352. }catch (Exception e){
  353. e.printStackTrace();
  354. return new RespR(false,e.getMessage());
  355. }
  356. }
  357. /**
  358. * 批量运单导入
  359. *
  360. * @param file 参数集
  361. * @return
  362. */
  363. @PostMapping("/batchImprotBillWay")
  364. @ApiOperation(value="批量运单导入", notes="批量运单导入")
  365. @LoginRequired
  366. public RespR batchImprotBillWay(@RequestParam("file") MultipartFile file,String customerName) {
  367. try {
  368. ImportParams params = new ImportParams();
  369. params.setTitleRows(1);
  370. params.setHeadRows(1);
  371. params.setKeyIndex(2);
  372. List<NoCarWayBill> list = ExcelImportUtil.importExcel(file.getInputStream(), NoCarWayBill.class,params) ;
  373. buildDate(list);
  374. RespR respR = noCarBillWayService.batchBillWayStart(list,customerName);
  375. return respR;
  376. }catch (Exception e){
  377. e.printStackTrace();
  378. return new RespR(false,e.getMessage());
  379. }
  380. }
  381. /**
  382. * 批量运单导入
  383. *
  384. * @param file 参数集
  385. * @return
  386. */
  387. @PostMapping("/batchImprotHistoryBillWay")
  388. @ApiOperation(value="批量历史运单导入", notes="批量历史运单导入")
  389. @LoginRequired
  390. public RespR batchImprotHistoryBillWay(@RequestParam("file") MultipartFile file,String customerName) {
  391. try {
  392. ImportParams params = new ImportParams();
  393. params.setTitleRows(1);
  394. params.setHeadRows(1);
  395. params.setKeyIndex(2);
  396. List<NoCarWayBill> list = ExcelImportUtil.importExcel(file.getInputStream(), NoCarWayBill.class,params);
  397. log.info("batchImprotHistoryBillWay数量"+list.size());
  398. buildDate(list);
  399. RespR respR = noCarBillWayService.batchHsitoryBillWay(list,customerName);
  400. return respR;
  401. }catch (Exception e){
  402. e.printStackTrace();
  403. return new RespR(false,e.getMessage());
  404. }
  405. }
  406. /**
  407. * 批量运单导入
  408. *
  409. * @param file 参数集
  410. * @return
  411. */
  412. @PostMapping("/batchImprotEndBillWay")
  413. @ApiOperation(value="批量运单结束", notes="批量运单结束")
  414. @LoginRequired
  415. public RespR batchImprotEndBillWay(@RequestParam("file") MultipartFile file,String customerName) {
  416. try {
  417. ImportParams params = new ImportParams();
  418. params.setTitleRows(1);
  419. params.setHeadRows(1);
  420. params.setKeyIndex(2);
  421. List<NoCarWayBill> list = ExcelImportUtil.importExcel(file.getInputStream(), NoCarWayBill.class,params);
  422. buildDateEnd(list);
  423. log.info("batchImprotEndBillWay数量"+list.size());
  424. RespR respR = noCarBillWayService.batchBillWayEnd(list,customerName);
  425. return respR;
  426. }catch (Exception e){
  427. e.printStackTrace();
  428. return new RespR(false,e.getMessage());
  429. }
  430. }
  431. public void buildDate(List<NoCarWayBill> list){
  432. StringBuffer sb = new StringBuffer();
  433. DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  434. int i = 0;
  435. String strError = "";
  436. for(int j = 0 ;j<list.size();j++){
  437. NoCarWayBill noCarWayBill = list.get(j);
  438. try {
  439. if(null == noCarWayBill){
  440. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查数据是否未传递");
  441. strError = "第"+(j+1)+"行数据存在错误,请检查数据是否未传递";
  442. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查数据是否未传递");
  443. }
  444. if(org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getBillNum())){
  445. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查运单编号是否未输入或者输入是否正确");
  446. strError = "第"+(j+1)+"行数据存在错误,请检查运单编号是否未输入或者输入是否正确";
  447. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查运单编号是否未输入或者输入是否正确");
  448. }
  449. if(org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getPlateNum())){
  450. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查车牌号码是否未输入或者输入是否正确");
  451. strError = "第"+(j+1)+"行数据存在错误,请检查车牌号码是否未输入或者输入是否正确";
  452. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查车牌号码是否未输入或者输入是否正确");
  453. }
  454. if(org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getPlateColor())){
  455. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查车牌颜色是否未输入或者输入是否正确");
  456. strError = "第"+(j+1)+"行数据存在错误,请检查车牌颜色是否未输入或者输入是否正确";
  457. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查车牌颜色是否未输入或者输入是否正确");
  458. }
  459. if( null == noCarWayBill.getStartTimeDate()){
  460. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查运单开始时间是否未输入或者输入是否正确");
  461. strError = "第"+(j+1)+"行数据存在错误,请检查运单开始时间是否未输入或者输入是否正确";
  462. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查运单开始时间是否未输入或者输入是否正确");
  463. }
  464. if(org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getSourceAddr())){
  465. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查运单开始地址是否未输入或者输入是否正确");
  466. strError = "第"+(j+1)+"行数据存在错误,请检查运单开始地址是否未输入或者输入是否正确";
  467. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查运单开始地址是否未输入或者输入是否正确");
  468. }
  469. if(org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getDestAddr())){
  470. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确");
  471. strError = "第"+(j+1)+"行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确";
  472. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确");
  473. }
  474. if(null == noCarWayBill.getPredictEndTimeDate()){
  475. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查运单预计完成时间是否未输入或者输入是否正确");
  476. strError = "第"+(j+1)+"行数据存在错误,请检查运单预计完成时间是否未输入或者输入是否正确";
  477. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查运单预计完成时间是否未输入或者输入是否正确");
  478. }
  479. if(null == noCarWayBill.getFeeD()){
  480. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查运单费用是否未输入或者输入是否正确");
  481. strError = "第"+(j+1)+"行数据存在错误,请检查运单费用是否未输入或者输入是否正确";
  482. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查运单费用是否未输入或者输入是否正确");
  483. }
  484. if(org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getTaxplayerCode())){
  485. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查税号是否未输入或者输入是否正确");
  486. strError = "第"+(j+1)+"行数据存在错误,请检查税号是否未输入或者输入是否正确";
  487. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查税号是否未输入或者输入是否正确");
  488. }
  489. noCarWayBill.setStartTime(format.format(noCarWayBill.getStartTimeDate()));
  490. noCarWayBill.setPredictEndTime(format.format(noCarWayBill.getPredictEndTimeDate()));
  491. if(noCarWayBill.getFeeD() !=null){
  492. noCarWayBill.setFee(Math.round(noCarWayBill.getFeeD()*100));
  493. }
  494. noCarWayBill.setTaxplayerCode(noCarWayBill.getTaxplayerCode().trim());
  495. noCarWayBill.setBillNum(noCarWayBill.getBillNum().trim());
  496. }catch (Exception e){
  497. sb.append(noCarWayBill.getBillNum()+"#");
  498. log.error(noCarWayBill.getBillNum());
  499. i++;
  500. }
  501. }
  502. if(i>0){
  503. log.error(org.apache.commons.lang3.StringUtils.isBlank(strError)?"buildDateError"+sb.toString()+"第"+i+"行数据存在错误,请检查文件中数据,金额是否有空的,时间是否全是时间格式":"buildDateError"+sb.toString()+strError);
  504. throw new RuntimeException(org.apache.commons.lang3.StringUtils.isBlank(strError)?"第"+i+"行数据存在错误,请检查文件中数据,金额是否有空的,时间是否全是时间格式":strError);
  505. }
  506. }
  507. public void buildDateEnd(List<NoCarWayBill> list){
  508. DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  509. int i = 0;
  510. StringBuffer sb = new StringBuffer();
  511. String strError = "";
  512. for(int j = 0 ;j<list.size();j++){
  513. NoCarWayBill noCarWayBill = list.get(j);
  514. try{
  515. if(null == noCarWayBill){
  516. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查数据是否未传递");
  517. strError = "第"+(j+1)+"行数据存在错误,请检查数据是否未传递";
  518. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查数据是否未传递");
  519. }
  520. if(org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getBillNum())){
  521. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查运单编号是否未输入或者输入是否正确");
  522. strError = "第"+(j+1)+"行数据存在错误,请检查运单编号是否未输入或者输入是否正确";
  523. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查运单编号是否未输入或者输入是否正确");
  524. }
  525. if(null == noCarWayBill.getActEndTimeDate()){
  526. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查运单实际结束时间是否未输入或者输入是否正确");
  527. strError = "第"+(j+1)+"行数据存在错误,请检查运单实际结束时间是否未输入或者输入是否正确";
  528. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查运单实际结束时间是否未输入或者输入是否正确");
  529. }
  530. if(org.apache.commons.lang3.StringUtils.isBlank(noCarWayBill.getDestAddr())){
  531. log.error("buildDateError"+sb.toString()+"第"+(j+1)+"行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确");
  532. strError = "第"+(j+1)+"行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确";
  533. throw new RuntimeException("第"+(j+1)+"行数据存在错误,请检查运单目的地址是否未输入或者输入是否正确");
  534. }
  535. noCarWayBill.setPredictEndTime(format.format(noCarWayBill.getActEndTimeDate()));
  536. }catch (Exception e){
  537. sb.append(noCarWayBill.getBillNum()+"#");
  538. log.error(noCarWayBill.getBillNum());
  539. i++;
  540. }
  541. }
  542. if(i>0){
  543. log.error(org.apache.commons.lang3.StringUtils.isBlank(strError)?"buildDateError"+sb.toString()+"第"+i+"行数据存在错误,请检查文件中数据,时间是否全是时间格式":"buildDateError"+sb.toString()+strError);
  544. throw new RuntimeException(org.apache.commons.lang3.StringUtils.isBlank(strError)?"第"+i+"行数据存在错误,请检查文件中数据,时间是否全是时间格式":strError);
  545. }
  546. }
  547. /**
  548. * 分页查询无车计费信息
  549. *
  550. * @param page 参数集
  551. * @return 用户集合
  552. */
  553. @PostMapping("/findBatchList")
  554. @ApiOperation(value="运单批次号查询", notes="运单批次号查询")
  555. @LoginRequired
  556. public RespR findBatchList(Page page, CustomerOper customerOper) {
  557. try {
  558. RespR respR = new RespR(customerOperService.findAllCustomerOper(page, customerOper));
  559. return respR;
  560. }catch (Exception e){
  561. e.printStackTrace();
  562. return new RespR(false,e.getMessage());
  563. }
  564. }
  565. /**
  566. * 分页查询无车计费信息
  567. *
  568. * @param page 参数集
  569. * @return 用户集合
  570. */
  571. @PostMapping("/findNocarCalculateInfo")
  572. @ApiOperation(value="分页查询无车计费信息", notes="分页查询无车计费信息")
  573. @LoginRequired
  574. public RespR findNocarCalculateInfo(Page page, NoCarCalculateInfor carCalculateInfor) {
  575. try {
  576. setTimeDue1(carCalculateInfor);
  577. RespR respR = new RespR(noCarCalculateInfoService.findByPageAndCalculateInfor(page, carCalculateInfor));
  578. return respR;
  579. }catch (Exception e){
  580. e.printStackTrace();
  581. return new RespR(false,e.getMessage());
  582. }
  583. }
  584. /**
  585. * 分页查询无车计费统计信息
  586. *
  587. * @param carCalculateInfor 参数集
  588. * @return 用户集合
  589. */
  590. @PostMapping("/findNocarCalculateInfoStatis")
  591. @ApiOperation(value="分页查询无车计费统计信息", notes="分页查询无车计费统计信息")
  592. @LoginRequired
  593. public RespR findNocarCalculateInfoStatis(NoCarCalculateInfor carCalculateInfor) {
  594. try {
  595. setTimeDue1(carCalculateInfor);
  596. RespR respR = new RespR(noCarCalculateInfoService.findNocarCalculateInfoStatis(carCalculateInfor));
  597. return respR;
  598. }catch (Exception e){
  599. e.printStackTrace();
  600. return new RespR(false,e.getMessage());
  601. }
  602. }
  603. @GetMapping("/templateDownload")
  604. @ApiOperation(value="模板下载", notes="模板下载")
  605. public RespR contractDownload(String fileName,HttpServletResponse response){
  606. if("1".equals(fileName)){
  607. fileName = "运单模板.xlsx";
  608. }else if("2".equals(fileName)){
  609. fileName = "运单结束模板.xlsx";
  610. }else if("3".equals(fileName)){
  611. fileName = "历史运单模板.xlsx";
  612. }else if("4".equals(fileName)){
  613. fileName = "无车发票查询模板.xlsx";
  614. }else if("5".equals(fileName)){
  615. fileName = "无车运单查询模板.xlsx";
  616. }else if("6".equals(fileName)){
  617. fileName = "自有车交易查询模板.xlsx";
  618. }else if("7".equals(fileName)){
  619. fileName = "自有车发票查询模板.xlsx";
  620. }
  621. OutputStream outputStream = null;
  622. InputStream inputStream = null;
  623. try {
  624. File file = new File("/home/app/excel/"+fileName);
  625. inputStream = new FileInputStream(file);
  626. response.setHeader("Content-Disposition", "attachment;filename="+ URLEncoder.encode(fileName, "UTF-8"));
  627. outputStream = response.getOutputStream();
  628. IOUtils.copy(inputStream, outputStream);
  629. response.flushBuffer();
  630. return new RespR(true);
  631. } catch (IOException e) {
  632. } finally {
  633. IOUtils.closeQuietly(inputStream);
  634. IOUtils.closeQuietly(outputStream);
  635. }
  636. return new RespR(false);
  637. }
  638. public void setTimeDue1(NoCarCalculateInfor carCalculateInfor){
  639. if(!StringUtils.isEmpty(carCalculateInfor.getInvoiceMakeTime()) && !"null".equals(carCalculateInfor.getInvoiceMakeTime())){
  640. String [] res = carCalculateInfor.getInvoiceMakeTime().split(",");
  641. carCalculateInfor.setInvoiceMakeStart(res[0]);
  642. carCalculateInfor.setInvoiceMakeEnd(res[1].replace("00:00:00","23:59:59"));
  643. }else{
  644. carCalculateInfor.setInvoiceMakeTime(null);
  645. }
  646. if(!StringUtils.isEmpty(carCalculateInfor.getCalculateTime()) && !"null".equals(carCalculateInfor.getCalculateTime())){
  647. String [] res = carCalculateInfor.getCalculateTime().split(",");
  648. carCalculateInfor.setCalculateStart(res[0]);
  649. carCalculateInfor.setCalculateEnd(res[1].replace("00:00:00","23:59:59"));
  650. }else{
  651. carCalculateInfor.setCalculateTime(null);
  652. }
  653. }
  654. }