From 00caef45a8833dc58919e23eb88a3484cfacdaa4 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期二, 22 八月 2023 17:53:25 +0800
Subject: [PATCH] 更新

---
 UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java |  230 ++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 210 insertions(+), 20 deletions(-)

diff --git a/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java b/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java
index 547000e..e19ea4b 100644
--- a/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java
+++ b/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/specialTrain/server/impl/OrderPrivateCarServiceImpl.java
@@ -24,6 +24,7 @@
 import com.stylefeng.guns.modular.system.util.GoogleMap.ReverseGeocodeVo;
 import com.stylefeng.guns.modular.system.util.Tingg.TinggPayUtil;
 import com.stylefeng.guns.modular.system.util.Tingg.model.CheckoutRequest;
+import com.stylefeng.guns.modular.system.util.itextpdf.HtmlToPdfUtils;
 import com.stylefeng.guns.modular.system.warpper.BaseWarpper;
 import com.stylefeng.guns.modular.system.warpper.EndPushWarpper;
 import com.stylefeng.guns.modular.system.warpper.OrderInfoWarpper;
@@ -50,10 +51,7 @@
 import org.springframework.web.client.RestTemplate;
 
 import javax.annotation.Resource;
-import java.io.BufferedReader;
-import java.io.File;
-import java.io.FileInputStream;
-import java.io.InputStreamReader;
+import java.io.*;
 import java.math.BigDecimal;
 import java.math.MathContext;
 import java.math.RoundingMode;
@@ -183,6 +181,15 @@
 
     @Value("${spring.mail.template-path}")
     private String templatePath;
+
+    @Autowired
+    private ISettlementDetailService settlementDetailService;
+
+    @Autowired
+    private ISettlementRecordService settlementRecordService;
+
+    @Autowired
+    private ISettlementAllocationService settlementAllocationService;
 
 
 
@@ -828,6 +835,9 @@
         return list;
     }
 
+
+
+
     @Override
     public ResultUtil payPrivateCarOrder(Integer payType, Integer bankCardId, Integer orderId, Integer couponId, Integer type, Integer language) throws Exception {
         OrderPrivateCar orderPrivateCar = this.selectById(orderId);
@@ -1000,7 +1010,7 @@
             if(ToolUtil.isNotEmpty(userInfo.getEmail())){
                 String path = templatePath +  "user/receipt.html";
                 Document document = Jsoup.parse(new File(path), "UTF-8");
-                SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日");
+                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
                 SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy/MM/dd HH:mm");
                 SimpleDateFormat sdf2 = new SimpleDateFormat("HH:mm");
                 Car car = carMapper.selectById(orderPrivateCar.getCarId());
@@ -1023,6 +1033,12 @@
                     pay_type_chinese.text("余额");
                     Element pay_money_chinese = document.getElementById("pay_money_chinese");
                     pay_money_chinese.text("GHS " + orderPrivateCar.getPayMoney());
+                    Element pdf_chinese = document.getElementById("pdf_chinese");
+                    pdf_chinese.attr("href", "http://182.160.16.251:80/user/base/order/uploadReceiptPdf?orderId=" + orderId + "&orderType=1");
+                    Element lost_item_chinese = document.getElementById("lost_item_chinese");
+                    lost_item_chinese.attr("href", "http://182.160.16.251:81/mailbox/user/lossGoods.html?language=" + language + "&orderId=" + orderId + "&orderType=1");
+                    Element track_chinese = document.getElementById("track_chinese");
+                    track_chinese.attr("href", "http://182.160.16.251:81/mailbox/user/location.html?orderId=" + orderId);
                     Element pay_time_chinese = document.getElementById("pay_time_chinese");
                     pay_time_chinese.text(sdf1.format(orderPrivateCar.getEndServiceTime()));
                     Elements driver_chinese = document.getElementsByClass("driver_chinese");
@@ -1058,6 +1074,12 @@
                     pay_type_english.text("balance");
                     Element pay_money_english = document.getElementById("pay_money_english");
                     pay_money_english.text("GHS " + orderPrivateCar.getPayMoney());
+                    Element pdf_english = document.getElementById("pdf_english");
+                    pdf_english.attr("href", "http://182.160.16.251:80/user/base/order/uploadReceiptPdf?orderId=" + orderId + "&orderType=1");
+                    Element lost_item_english = document.getElementById("lost_item_english");
+                    lost_item_english.attr("href", "http://182.160.16.251:81/mailbox/user/lossGoods.html?language=" + language + "&orderId=" + orderId + "&orderType=1");
+                    Element track_english = document.getElementById("track_english");
+                    track_english.attr("href", "http://182.160.16.251:81/mailbox/user/location.html?orderId=" + orderId);
                     Element pay_time_english = document.getElementById("pay_time_english");
                     pay_time_english.text(sdf1.format(orderPrivateCar.getEndServiceTime()));
                     Elements driver_english = document.getElementsByClass("driver_english");
@@ -1093,6 +1115,12 @@
                     pay_type_french.text("Le solde");
                     Element pay_money_french = document.getElementById("pay_money_french");
                     pay_money_french.text("GHS " + orderPrivateCar.getPayMoney());
+                    Element pdf_french = document.getElementById("pdf_french");
+                    pdf_french.attr("href", "http://182.160.16.251:80/user/base/order/uploadReceiptPdf?orderId=" + orderId + "&orderType=1");
+                    Element lost_item_french = document.getElementById("lost_item_french");
+                    lost_item_french.attr("href", "http://182.160.16.251:81/mailbox/user/lossGoods.html?language=" + language + "&orderId=" + orderId + "&orderType=1");
+                    Element track_french = document.getElementById("track_french");
+                    track_french.attr("href", "http://182.160.16.251:81/mailbox/user/location.html?orderId=" + orderId);
                     Element pay_time_french = document.getElementById("pay_time_french");
                     pay_time_french.text(sdf1.format(orderPrivateCar.getEndServiceTime()));
                     Elements driver_french = document.getElementsByClass("driver_french");
@@ -1115,8 +1143,32 @@
                     Element end_address_french = document.getElementById("end_address_french");
                     end_address_french.text(orderPrivateCar.getEndAddress());
                 }
-
                 EmailUtil.send(userInfo.getEmail(), language == 1 ? "打车收据" : language == 2 ? "Ride receipt" : "Reçu de Ride",  document.html());
+
+                //开始生成pdf收据和html收据
+                File file = new File("/usr/local/nginx/html/files/html/");
+                if(!file.exists()){
+                    file.mkdirs();
+                }
+                file = new File("/usr/local/nginx/html/files/html/ride_receipt_" + orderId + ".html");
+                if(!file.exists()){
+                    file.createNewFile();
+                }
+                FileWriter fileWriter = new FileWriter(file);
+                fileWriter.write(document.html());
+                fileWriter.flush();
+                fileWriter.close();
+                FileInputStream fileInputStream = new FileInputStream(file);
+                File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                if(!file1.exists()){
+                    file1.mkdirs();
+                }
+                file1 = new File("/usr/local/nginx/html/files/pdf/ride_receipt_" + orderId + ".pdf");
+                if(!file1.exists()){
+                    file1.createNewFile();
+                }
+                FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
             }
 
 
@@ -1146,7 +1198,7 @@
 
             orderPrivateCar.setState(8);
             orderPrivateCar.setPayType(4);
-            orderPrivateCar.setDriverPay(1);
+            orderPrivateCar.setDriverPay(2);
             orderPrivateCar.setPayMoney(orderMoney);
             orderPrivateCar.setOrderMoney(orderPrivateCar.getOrderMoney()+orderPrivateCar.getFreeMoney().doubleValue());
 
@@ -1176,19 +1228,58 @@
                     d = new BigDecimal(price).multiply(new BigDecimal(speMoney).divide(new BigDecimal(100), new MathContext(2, RoundingMode.HALF_EVEN)));
                     c = new BigDecimal(orderPrivateCar.getOrderMoney()).subtract(d).setScale(2, BigDecimal.ROUND_HALF_EVEN);
                 }
-                incomeService.saveData(1, orderPrivateCar.getCompanyId(), 2, orderPrivateCar.getId(), 1, d.doubleValue());
-                incomeService.saveData(2, orderPrivateCar.getDriverId(), 2, orderPrivateCar.getId(), 1, c.doubleValue());
+//                incomeService.saveData(1, orderPrivateCar.getCompanyId(), 2, orderPrivateCar.getId(), 1, d.doubleValue());
+//                incomeService.saveData(2, orderPrivateCar.getDriverId(), 2, orderPrivateCar.getId(), 1, c.doubleValue());
                 Driver driver = driverService.selectById(orderPrivateCar.getDriverId());
-                driver.setBusinessMoney(new BigDecimal(null != driver.getBusinessMoney() ? driver.getBusinessMoney() : 0).add(c).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                driver.setLaveBusinessMoney(new BigDecimal(null != driver.getLaveBusinessMoney() ? driver.getLaveBusinessMoney() : 0).add(c).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                driver.setBalance(new BigDecimal(null != driver.getBalance() ? driver.getBalance() : 0).add(c).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
-                driverService.updateById(driver);
+//                driver.setBusinessMoney(new BigDecimal(null != driver.getBusinessMoney() ? driver.getBusinessMoney() : 0).add(c).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+//                driver.setLaveBusinessMoney(new BigDecimal(null != driver.getLaveBusinessMoney() ? driver.getLaveBusinessMoney() : 0).add(c).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+//                driver.setBalance(new BigDecimal(null != driver.getBalance() ? driver.getBalance() : 0).add(c).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
+//                driverService.updateById(driver);
+
+
+                //记录司机待结算金额
+                if(d.compareTo(new BigDecimal(0)) > 0){
+                    SettlementDetail settlementDetail = new SettlementDetail();
+                    settlementDetail.setOrderId(orderId);
+                    settlementDetail.setOrderType(1);
+                    settlementDetail.setDriverId(driver.getId());
+                    settlementDetail.setOrderMoney(orderPrivateCar.getOrderMoney());
+                    settlementDetail.setPrice(d.doubleValue());
+                    settlementDetail.setCreateTime(new Date());
+                    settlementDetailService.insert(settlementDetail);
+
+                    SettlementAllocation settlementAllocation = settlementAllocationService.selectOne(null);
+                    if(null != settlementAllocation){
+                        JSONObject jsonObject = JSON.parseObject(settlementAllocation.getContent());
+                        Double maxPrice = jsonObject.getDouble("maxPrice");
+                        List<SettlementDetail> settlementDetailList = settlementDetailService.selectList(new EntityWrapper<SettlementDetail>().eq("driverId", driver.getId()).isNull("settlementRecordId").last(" and DATE_FORMAT(now(), '%Y-%m-%d') = DATE_FORMAT(createTime, '%Y-%m-%d')"));
+                        BigDecimal total = new BigDecimal(0);
+                        for (SettlementDetail detail : settlementDetailList) {
+                            total = total.add(new BigDecimal(detail.getPrice()));
+                        }
+                        if(maxPrice.compareTo(total.doubleValue()) <= 0){
+                            SettlementRecord settlementRecord = new SettlementRecord();
+                            settlementRecord.setDay(new Date());
+                            settlementRecord.setDriverId(driver.getId());
+                            settlementRecord.setType(1);
+                            settlementRecord.setPaymentStatus(1);
+                            settlementRecord.setPayMoney(total.doubleValue());
+                            settlementRecord.setInsertTime(new Date());
+                            settlementRecordService.insert(settlementRecord);
+
+                            for (SettlementDetail detail : settlementDetailList) {
+                                detail.setSettlementRecordId(settlementRecord.getId());
+                                settlementDetailService.updateById(detail);
+                            }
+                        }
+                    }
+                }
             }
 
             if(ToolUtil.isNotEmpty(userInfo.getEmail())){
                 String path = templatePath +  "user/receipt.html";
                 Document document = Jsoup.parse(new File(path), "UTF-8");
-                SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日");
+                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
                 SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy/MM/dd HH:mm");
                 SimpleDateFormat sdf2 = new SimpleDateFormat("HH:mm");
                 Car car = carMapper.selectById(orderPrivateCar.getCarId());
@@ -1211,6 +1302,12 @@
                     pay_type_chinese.text("现金");
                     Element pay_money_chinese = document.getElementById("pay_money_chinese");
                     pay_money_chinese.text("GHS " + orderPrivateCar.getPayMoney());
+                    Element pdf_chinese = document.getElementById("pdf_chinese");
+                    pdf_chinese.attr("href", "http://182.160.16.251:80/user/base/order/uploadReceiptPdf?orderId=" + orderId + "&orderType=1");
+                    Element lost_item_chinese = document.getElementById("lost_item_chinese");
+                    lost_item_chinese.attr("href", "http://182.160.16.251:81/mailbox/user/lossGoods.html?language=" + language + "&orderId=" + orderId + "&orderType=1");
+                    Element track_chinese = document.getElementById("track_chinese");
+                    track_chinese.attr("href", "http://182.160.16.251:81/mailbox/user/location.html?orderId=" + orderId);
                     Element pay_time_chinese = document.getElementById("pay_time_chinese");
                     pay_time_chinese.text(sdf1.format(orderPrivateCar.getEndServiceTime()));
                     Elements driver_chinese = document.getElementsByClass("driver_chinese");
@@ -1246,6 +1343,12 @@
                     pay_type_english.text("Cash");
                     Element pay_money_english = document.getElementById("pay_money_english");
                     pay_money_english.text("GHS " + orderPrivateCar.getPayMoney());
+                    Element pdf_english = document.getElementById("pdf_english");
+                    pdf_english.attr("href", "http://182.160.16.251:80/user/base/order/uploadReceiptPdf?orderId=" + orderId + "&orderType=1");
+                    Element lost_item_english = document.getElementById("lost_item_english");
+                    lost_item_english.attr("href", "http://182.160.16.251:81/mailbox/user/lossGoods.html?language=" + language + "&orderId=" + orderId + "&orderType=1");
+                    Element track_english = document.getElementById("track_english");
+                    track_english.attr("href", "http://182.160.16.251:81/mailbox/user/location.html?orderId=" + orderId);
                     Element pay_time_english = document.getElementById("pay_time_english");
                     pay_time_english.text(sdf1.format(orderPrivateCar.getEndServiceTime()));
                     Elements driver_english = document.getElementsByClass("driver_english");
@@ -1281,6 +1384,12 @@
                     pay_type_french.text("espèces");
                     Element pay_money_french = document.getElementById("pay_money_french");
                     pay_money_french.text("GHS " + orderPrivateCar.getPayMoney());
+                    Element pdf_french = document.getElementById("pdf_french");
+                    pdf_french.attr("href", "http://182.160.16.251:80/user/base/order/uploadReceiptPdf?orderId=" + orderId + "&orderType=1");
+                    Element lost_item_french = document.getElementById("lost_item_french");
+                    lost_item_french.attr("href", "http://182.160.16.251:81/mailbox/user/lossGoods.html?language=" + language + "&orderId=" + orderId + "&orderType=1");
+                    Element track_french = document.getElementById("track_french");
+                    track_french.attr("href", "http://182.160.16.251:81/mailbox/user/location.html?orderId=" + orderId);
                     Element pay_time_french = document.getElementById("pay_time_french");
                     pay_time_french.text(sdf1.format(orderPrivateCar.getEndServiceTime()));
                     Elements driver_french = document.getElementsByClass("driver_french");
@@ -1305,6 +1414,31 @@
                 }
 
                 EmailUtil.send(userInfo.getEmail(), language == 1 ? "打车收据" : language == 2 ? "Ride receipt" : "Reçu de Ride",  document.html());
+
+                //开始生成pdf收据和html收据
+                File file = new File("/usr/local/nginx/html/files/html/");
+                if(!file.exists()){
+                    file.mkdirs();
+                }
+                file = new File("/usr/local/nginx/html/files/html/ride_receipt_" + orderId + ".html");
+                if(!file.exists()){
+                    file.createNewFile();
+                }
+                FileWriter fileWriter = new FileWriter(file);
+                fileWriter.write(document.html());
+                fileWriter.flush();
+                fileWriter.close();
+                FileInputStream fileInputStream = new FileInputStream(file);
+                File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                if(!file1.exists()){
+                    file1.mkdirs();
+                }
+                file1 = new File("/usr/local/nginx/html/files/pdf/ride_receipt_" + orderId + ".pdf");
+                if(!file1.exists()){
+                    file1.createNewFile();
+                }
+                FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
             }
 
 
@@ -1568,7 +1702,7 @@
             if(ToolUtil.isNotEmpty(userInfo.getEmail())){
                 String path = templatePath +  "user/receipt.html";
                 Document document = Jsoup.parse(new File(path), "UTF-8");
-                SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日");
+                SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
                 SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy/MM/dd HH:mm");
                 SimpleDateFormat sdf2 = new SimpleDateFormat("HH:mm");
                 Car car = carMapper.selectById(orderPrivateCar.getCarId());
@@ -1588,9 +1722,15 @@
                     Element xj_chinese = document.getElementById("xj_chinese");
                     xj_chinese.text("GHS " + orderPrivateCar.getOrderMoney());
                     Element pay_type_chinese = document.getElementById("pay_type_chinese");
-                    pay_type_chinese.text("现金");
+                    pay_type_chinese.text(orderPrivateCar.getPayType() == 1 ? "手机" : "银行卡");
                     Element pay_money_chinese = document.getElementById("pay_money_chinese");
                     pay_money_chinese.text("GHS " + orderPrivateCar.getPayMoney());
+                    Element pdf_chinese = document.getElementById("pdf_chinese");
+                    pdf_chinese.attr("href", "http://182.160.16.251:80/user/base/order/uploadReceiptPdf?orderId=" + id + "&orderType=1");
+                    Element lost_item_chinese = document.getElementById("lost_item_chinese");
+                    lost_item_chinese.attr("href", "http://182.160.16.251:81/mailbox/user/lossGoods.html?language=" + language + "&orderId=" + id + "&orderType=1");
+                    Element track_chinese = document.getElementById("track_chinese");
+                    track_chinese.attr("href", "http://182.160.16.251:81/mailbox/user/location.html?orderId=" + id);
                     Element pay_time_chinese = document.getElementById("pay_time_chinese");
                     pay_time_chinese.text(sdf1.format(orderPrivateCar.getEndServiceTime()));
                     Elements driver_chinese = document.getElementsByClass("driver_chinese");
@@ -1623,9 +1763,15 @@
                     Element xj_english = document.getElementById("xj_english");
                     xj_english.text("GHS " + orderPrivateCar.getOrderMoney());
                     Element pay_type_english = document.getElementById("pay_type_english");
-                    pay_type_english.text("Cash");
+                    pay_type_english.text(orderPrivateCar.getPayType() == 1 ? "Mobile" : "Bank card");
                     Element pay_money_english = document.getElementById("pay_money_english");
                     pay_money_english.text("GHS " + orderPrivateCar.getPayMoney());
+                    Element pdf_english = document.getElementById("pdf_english");
+                    pdf_english.attr("href", "http://182.160.16.251:80/user/base/order/uploadReceiptPdf?orderId=" + id + "&orderType=1");
+                    Element lost_item_english = document.getElementById("lost_item_english");
+                    lost_item_english.attr("href", "http://182.160.16.251:81/mailbox/user/lossGoods.html?language=" + language + "&orderId=" + id + "&orderType=1");
+                    Element track_english = document.getElementById("track_english");
+                    track_english.attr("href", "http://182.160.16.251:81/mailbox/user/location.html?orderId=" + id);
                     Element pay_time_english = document.getElementById("pay_time_english");
                     pay_time_english.text(sdf1.format(orderPrivateCar.getEndServiceTime()));
                     Elements driver_english = document.getElementsByClass("driver_english");
@@ -1658,9 +1804,15 @@
                     Element xj_french = document.getElementById("xj_french");
                     xj_french.text("GHS " + orderPrivateCar.getOrderMoney());
                     Element pay_type_french = document.getElementById("pay_type_french");
-                    pay_type_french.text("espèces");
+                    pay_type_french.text(orderPrivateCar.getPayType() == 1 ? "Mobile" : "Carte bancaire");
                     Element pay_money_french = document.getElementById("pay_money_french");
                     pay_money_french.text("GHS " + orderPrivateCar.getPayMoney());
+                    Element pdf_french = document.getElementById("pdf_french");
+                    pdf_french.attr("href", "http://182.160.16.251:80/user/base/order/uploadReceiptPdf?orderId=" + id + "&orderType=1");
+                    Element lost_item_french = document.getElementById("lost_item_french");
+                    lost_item_french.attr("href", "http://182.160.16.251:81/mailbox/user/lossGoods.html?language=" + language + "&orderId=" + id + "&orderType=1");
+                    Element track_french = document.getElementById("track_french");
+                    track_french.attr("href", "http://182.160.16.251:81/mailbox/user/location.html?orderId=" + id);
                     Element pay_time_french = document.getElementById("pay_time_french");
                     pay_time_french.text(sdf1.format(orderPrivateCar.getEndServiceTime()));
                     Elements driver_french = document.getElementsByClass("driver_french");
@@ -1685,6 +1837,31 @@
                 }
 
                 EmailUtil.send(userInfo.getEmail(), language == 1 ? "打车收据" : language == 2 ? "Ride receipt" : "Reçu de Ride",  document.html());
+
+                //开始生成pdf收据和html收据
+                File file = new File("/usr/local/nginx/html/files/html/");
+                if(!file.exists()){
+                    file.mkdirs();
+                }
+                file = new File("/usr/local/nginx/html/files/html/ride_receipt_" + id + ".html");
+                if(!file.exists()){
+                    file.createNewFile();
+                }
+                FileWriter fileWriter = new FileWriter(file);
+                fileWriter.write(document.html());
+                fileWriter.flush();
+                fileWriter.close();
+                FileInputStream fileInputStream = new FileInputStream(file);
+                File file1 = new File("/usr/local/nginx/html/files/pdf/");
+                if(!file1.exists()){
+                    file1.mkdirs();
+                }
+                file1 = new File("/usr/local/nginx/html/files/pdf/ride_receipt_" + id + ".pdf");
+                if(!file1.exists()){
+                    file1.createNewFile();
+                }
+                FileOutputStream fileOutputStream = new FileOutputStream(file1);
+                HtmlToPdfUtils.convertToPdf(fileInputStream, "IGO", fileOutputStream);
             }
 
 
@@ -1715,8 +1892,15 @@
         pageNum = (pageNum - 1) * size;
         List<Map<String, Object>> maps = orderPrivateCarMapper.queryMyOrderList(uid, pageNum, size);
         for(Map<String, Object> map : maps){
-            if(Integer.valueOf(String.valueOf(map.get("state"))) == 11){
+            Integer orderId = Integer.valueOf(String.valueOf(map.get("orderId")));
+            Integer state = Integer.valueOf(String.valueOf(map.get("state")));
+            if(state == 11){
                 map.put("state", map.get("oldState"));
+            }
+            if(state == 8 || state == 9){
+                map.put("receipt", "http://182.160.16.251:81/files/html/ride_receipt_" + orderId + ".html");
+            }else{
+                map.put("receipt", "");
             }
         }
         return maps;
@@ -1732,12 +1916,13 @@
     @Override
     public Map<String, Object> queryOrderInfo(Integer orderId) throws Exception {
         Map<String, Object> map = orderPrivateCarMapper.queryOrderInfo(orderId);
+        Integer state = Integer.valueOf(String.valueOf(map.get("state")));
         if(null != map.get("reassignNotice") && Integer.valueOf(String.valueOf(map.get("reassignNotice"))) == 2){//改派完成,重新获取了新的司机数据,开始修改数据防止继续调用
             OrderPrivateCar orderPrivateCar = this.selectById(orderId);
             orderPrivateCar.setReassignNotice(0);
             this.updateById(orderPrivateCar);
         }
-        if(Integer.valueOf(String.valueOf(map.get("state"))) == 11){
+        if(state == 11){
             map.put("state", map.get("oldState"));
         }
         if(Integer.valueOf(String.valueOf(map.get("state"))) != 8 && Integer.valueOf(String.valueOf(map.get("state"))) != 9){
@@ -1765,6 +1950,11 @@
         String driverId = redisUtil.getValue("DEVICE_" + map.get("driverId"));
         map.put("device", ToolUtil.isNotEmpty(driverId) ? 2 : 1);
         map.put("orderType", 1);
+        if(state == 8 || state == 9){
+            map.put("receipt", "http://182.160.16.251:81/files/html/ride_receipt_" + orderId + ".html");
+        }else{
+            map.put("receipt", "");
+        }
         return map;
     }
 

--
Gitblit v1.7.1