From b997fbe016ace57406e8938ebba3f8c176fbabf9 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期五, 04 八月 2023 10:34:30 +0800
Subject: [PATCH] 新增加国外短信

---
 UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/smallLogistics/server/impl/OrderLogisticsServiceImpl.java |  340 ++++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 219 insertions(+), 121 deletions(-)

diff --git a/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/smallLogistics/server/impl/OrderLogisticsServiceImpl.java b/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/smallLogistics/server/impl/OrderLogisticsServiceImpl.java
index 6bd7e2b..8e24eca 100644
--- a/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/smallLogistics/server/impl/OrderLogisticsServiceImpl.java
+++ b/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/smallLogistics/server/impl/OrderLogisticsServiceImpl.java
@@ -17,7 +17,11 @@
 import com.stylefeng.guns.modular.system.util.*;
 import com.stylefeng.guns.modular.system.util.GoogleMap.*;
 import com.stylefeng.guns.modular.system.util.Tingg.TinggPayUtil;
+import com.stylefeng.guns.modular.system.util.Tingg.TinggPayoutUtil;
+import com.stylefeng.guns.modular.system.util.Tingg.model.AuthStatus;
 import com.stylefeng.guns.modular.system.util.Tingg.model.CheckoutRequest;
+import com.stylefeng.guns.modular.system.util.Tingg.model.PayoutResponse;
+import com.stylefeng.guns.modular.system.util.Tingg.model.Results;
 import com.stylefeng.guns.modular.system.warpper.BaseWarpper;
 import com.stylefeng.guns.modular.taxi.model.PaymentRecord;
 import com.stylefeng.guns.modular.taxi.service.IPaymentRecordService;
@@ -25,6 +29,8 @@
 import org.jsoup.Jsoup;
 import org.jsoup.nodes.Document;
 import org.jsoup.nodes.Element;
+import org.jsoup.nodes.FormElement;
+import org.jsoup.select.Elements;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Service;
@@ -77,9 +83,6 @@
     @Autowired
     private IPaymentRecordService paymentRecordService;
 
-   /* @Autowired
-    private ICBCPayUtil icbcPayUtil;*/
-
     @Autowired
     private PayMoneyUtil payMoneyUtil;
 
@@ -113,11 +116,11 @@
     @Autowired
     private IUserCouponRecordService userCouponRecordService;
 
-    @Resource
-    private CarMapper carMapper;
+    @Autowired
+    private IBankCardService bankCardService;
 
     @Autowired
-    private IOrderEvaluateService orderEvaluateService;
+    private TinggPayoutUtil tinggPayoutUtil;
 
     @Value("${callbackPath}")
     private String callbackPath;
@@ -293,8 +296,9 @@
         this.insert(orderLogistics);
 
         //添加消息
-        systemNoticeService.addSystemNotice(1, language == 1 ? "您的市内小件物流订单已下单成功,我们正在为您指派司机,请稍后!" :
-                                            language == 2 ? "Your local small parts logistics order has been successfully placed, we are assigning you a driver, please wait!" : "Votre commande de city small pieces logistics a été passée avec succès. Nous vous assignons un chauffeur. Plus tard!", orderLogistics.getUserId(), 1);
+        systemNoticeService.addSystemNotice(1, language == 1 ? "您的市内包裹订单已下单成功,我们正在为您指派司机,请稍后!" :
+                                            language == 2 ? "Your parcel order has been successfully placed, we are assigning a driver for you, please wait!"
+                                                    : "Votre commande de colis a bien été passée, nous vous assignons un chauffeur, veuillez patienter!", orderLogistics.getUserId(), 1);
 
         BaseWarpper baseWarpper = new BaseWarpper();
         baseWarpper.setId(orderLogistics.getId());
@@ -472,10 +476,10 @@
      * @throws Exception
      */
     @Override
-    public ResultUtil payLogisticsOrder(Integer payType, String accountNumber, Integer orderId, Integer type, Integer language) throws Exception {
+    public ResultUtil payLogisticsOrder(Integer payType, Integer bankCardId, Integer orderId, Integer type, Integer language) throws Exception {
         OrderLogistics orderLogistics = this.selectById(orderId);
         if(orderLogistics.getState() != 7){
-            return ResultUtil.error("订单已完成支付,不允许重复支付");
+            return ResultUtil.error(language == 1 ? "订单已完成支付,不允许重复支付" : language == 2 ? "The order has been paid, no double payment is allowed" : "La commande a été payée, aucun paiement en double n’est autorisé", "");
         }
         Integer uid = orderLogistics.getUserId();
         Double orderMoney = orderLogistics.getOrderMoney();
@@ -483,7 +487,7 @@
             orderMoney += null != orderLogistics.getTipMoney() ? orderLogistics.getTipMoney() : 0;
         }
         UserInfo userInfo = userInfoService.selectById(uid);
-        ResultUtil resultUtil = ResultUtil.success();
+        ResultUtil resultUtil = ResultUtil.success("");
 
         if(payType == 1) {//手机支付
             SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
@@ -499,14 +503,47 @@
             checkoutRequest.setRequestDescription("Travel completion payment");
             checkoutRequest.setCallbackUrl(callbackPath + "/base/wxPayOrderTaxi");
             checkoutRequest.setPendingRedirectUrl("");
-            checkoutRequest.setSuccessRedirectUrl("https://10pz685243.zicp.fun");
-            checkoutRequest.setFailRedirectUrl("https://www.baidu.com");
-            return TinggPayUtil.checkoutRequest(checkoutRequest);
+            checkoutRequest.setSuccessRedirectUrl("http://182.160.16.251:81/payMoney/pages/success.html");
+            checkoutRequest.setFailRedirectUrl("http://182.160.16.251:81/payMoney/pages/fail.html");
+            resultUtil = TinggPayUtil.checkoutRequest(checkoutRequest);
+            if(resultUtil.getCode()==200){
+                paymentRecordService.saveData(1, null, null, orderId, 4, 1, orderMoney, null, 1);//添加预支付数据
+            }else{
+                resultUtil = ResultUtil.error(language == 1 ? "支付失败" : language == 2 ? "Payment failure" : "Paiement échoué", "");
+            }
+            return resultUtil;
+        }
+
+        if(payType == 2) {//银行卡支付
+            BankCard bankCard = bankCardService.selectById(bankCardId);
+            SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
+            String merchantTransactionId = sdf.format(new Date()) + "4" + language + orderId;
+            CheckoutRequest checkoutRequest = new CheckoutRequest();
+            checkoutRequest.setMsisdn(Long.valueOf(bankCard.getCode()));
+            checkoutRequest.setCustomerEmail(userInfo.getEmail());
+            checkoutRequest.setAccountNumber(bankCard.getCode());
+            checkoutRequest.setCustomerFirstName(bankCard.getFirstName());
+            checkoutRequest.setCustomerLastName(bankCard.getLastName());
+            checkoutRequest.setRequestAmount(orderMoney);
+            checkoutRequest.setMerchantTransactionId(merchantTransactionId);
+            checkoutRequest.setRequestDescription("Travel completion payment");
+            checkoutRequest.setCallbackUrl(callbackPath + "/base/wxPayOrderTaxi");
+            checkoutRequest.setPendingRedirectUrl("");
+            checkoutRequest.setSuccessRedirectUrl("http://182.160.16.251:81/payMoney/pages/success.html");
+            checkoutRequest.setFailRedirectUrl("http://182.160.16.251:81/payMoney/pages/fail.html");
+            resultUtil = TinggPayUtil.checkoutRequest(checkoutRequest);
+
+            if(resultUtil.getCode()==200){
+                paymentRecordService.saveData(1, null, null, orderId, 4, 2, orderMoney, null, 1);//添加预支付数据
+            }else{
+                resultUtil = ResultUtil.error(language == 1 ? "支付失败" : language == 2 ? "Payment failure" : "Paiement échoué", "");
+            }
+            return resultUtil;
         }
 
         if(payType == 3){//余额支付
             if(userInfo.getBalance() == null || userInfo.getBalance() < orderMoney){
-                return ResultUtil.error(language == 1 ? "账户余额不足" : language == 2 ? "Insufficient account balance" : "Solde de compte insuffisant");
+                return ResultUtil.error(language == 1 ? "账户余额不足" : language == 2 ? "Insufficient account balance" : "Solde de compte insuffisant", "");
             }
 
             userInfo.setBalance(new BigDecimal(userInfo.getBalance()).subtract(new BigDecimal(orderMoney)).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue());
@@ -515,7 +552,7 @@
             userInfo.setIntegral(userInfo.getIntegral() + (orderMoney.intValue() * query1.getIntegral()));//积分
 
             //添加交易明细
-            transactionDetailsService.saveData(uid, "小件物流下单支付", orderMoney, 2, 1, 1, 4, orderId);
+            transactionDetailsService.saveData(uid, "包裹下单支付", orderMoney, 2, 1, 1, 4, orderId);
             userInfoService.updateById(userInfo);
 
             orderLogistics.setState(1);//小件物流先支付后司机抢单
@@ -529,9 +566,10 @@
                 Document document = Jsoup.parse(new File(path), "UTF-8");
                 SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy年MM月dd日");
                 SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy/MM/dd HH:mm");
+                Driver driver = driverService.selectById(orderLogistics.getDriverId());
                 if(1 == language){
-                    document.getElementById("english").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("english").remove();
+                    document.getElementById("french").remove();
                     Element title_chinese = document.getElementById("title_chinese");
                     title_chinese.text(sdf2.format(orderLogistics.getTravelTime()) + ",您在I-GO1个订单消费GHS " + orderLogistics.getPayMoney());
                     Element xcf_chinese = document.getElementById("xcf_chinese");
@@ -544,14 +582,19 @@
                     pay_money_chinese.text("GHS " + orderLogistics.getPayMoney());
                     Element pay_time_chinese = document.getElementById("pay_time_chinese");
                     pay_time_chinese.text(sdf1.format(orderLogistics.getTravelTime()));
+                    Elements driver_chinese = document.getElementsByClass("driver_chinese");
+                    for (int i = 0; i < driver_chinese.size(); i++) {
+                        Element element = driver_chinese.get(i);
+                        element.text(driver.getFirstName() + "." + driver.getLastName());
+                    }
                     Element start_address_chinese = document.getElementById("start_address_chinese");
                     start_address_chinese.text(orderLogistics.getStartAddress());
                     Element end_address_chinese = document.getElementById("end_address_chinese");
                     end_address_chinese.text(orderLogistics.getEndAddress());
                 }
                 if(2 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("french").remove();
                     Element title_english = document.getElementById("title_english");
                     title_english.text(sdf2.format(orderLogistics.getTravelTime()) + ",You spent GHS " + orderLogistics.getPayMoney() + " on the trip ");
                     Element xcf_english = document.getElementById("xcf_english");
@@ -564,14 +607,19 @@
                     pay_money_english.text("GHS " + orderLogistics.getPayMoney());
                     Element pay_time_english = document.getElementById("pay_time_english");
                     pay_time_english.text(sdf1.format(orderLogistics.getTravelTime()));
+                    Elements driver_english = document.getElementsByClass("driver_english");
+                    for (int i = 0; i < driver_english.size(); i++) {
+                        Element element = driver_english.get(i);
+                        element.text(driver.getFirstName() + "." + driver.getLastName());
+                    }
                     Element start_address_english = document.getElementById("start_address_english");
                     start_address_english.text(orderLogistics.getStartAddress());
                     Element end_address_english = document.getElementById("end_address_english");
                     end_address_english.text(orderLogistics.getEndAddress());
                 }
                 if(3 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("english").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("english").remove();
                     Element title_french = document.getElementById("title_french");
                     title_french.text(sdf2.format(orderLogistics.getTravelTime()) + ",Vous consommez GHS " + orderLogistics.getPayMoney() + " sur votre commande i-go1 le ");
                     Element xcf_french = document.getElementById("xcf_french");
@@ -584,13 +632,18 @@
                     pay_money_french.text("GHS " + orderLogistics.getPayMoney());
                     Element pay_time_french = document.getElementById("pay_time_french");
                     pay_time_french.text(sdf1.format(orderLogistics.getTravelTime()));
+                    Elements driver_french = document.getElementsByClass("driver_french");
+                    for (int i = 0; i < driver_french.size(); i++) {
+                        Element element = driver_french.get(i);
+                        element.text(driver.getFirstName() + "." + driver.getLastName());
+                    }
                     Element start_address_french = document.getElementById("start_address_french");
                     start_address_french.text(orderLogistics.getStartAddress());
                     Element end_address_french = document.getElementById("end_address_french");
                     end_address_french.text(orderLogistics.getEndAddress());
                 }
 
-                EmailUtil.send(userInfo.getEmail(), language == 1 ? "市内小件物流收据" : language == 2 ? "Reset password" : "Réinitialiser le mot de passe",  document.html());
+                EmailUtil.send(userInfo.getEmail(), language == 1 ? "包裹收据" : language == 2 ? "Parcel receipt" : "Réception de colis",  document.html());
             }
 
             // TODO: 2020/5/24 这里需要给司机和用户推送订单状态
@@ -600,9 +653,9 @@
                     pushUtil.pushOrderState(1, orderLogistics.getUserId(), orderLogistics.getId(), orderLogistics.getType(), orderLogistics.getState(), 0);
                 }
             }).start();
-            systemNoticeService.addSystemNotice(1, language == 1 ? "您已使用余额成功完成小件物流订单支付,谢谢使用!" : language == 2
-                    ? "You have successfully used the balance to complete the small logistics order payment, thank you for using!"
-                    : "Vous avez utilisé le solde pour compléter avec succès le paiement de la commande logistique de petites pièces. Merci d’utiliser!", uid, 1);
+            systemNoticeService.addSystemNotice(1, language == 1 ? "您已成功完成包裹订单支付,谢谢使用!" : language == 2
+                    ? "You have successfully completed the parcel order payment, thank you for using!" :
+                    "Vous avez terminé avec succès le paiement de la commande de colis, merci de l’utiliser!", uid, 1);
             this.pushOrder(orderLogistics);//推单
         }
 
@@ -611,7 +664,7 @@
             userInfo.setIntegral(userInfo.getIntegral() + (orderMoney.intValue() * query1.getIntegral()));//积分
 
             //添加交易明细
-            transactionDetailsService.saveData(uid, "小件物流下单支付", orderMoney, 2, 1, 1, 4, orderId);
+            transactionDetailsService.saveData(uid, "包裹下单支付", orderMoney, 2, 1, 1, 4, orderId);
             userInfoService.updateById(userInfo);
 
             orderLogistics.setState(1);//小件物流先支付后司机抢单
@@ -624,9 +677,10 @@
                 Document document = Jsoup.parse(new File(path), "UTF-8");
                 SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy年MM月dd日");
                 SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy/MM/dd HH:mm");
+                Driver driver = driverService.selectById(orderLogistics.getDriverId());
                 if(1 == language){
-                    document.getElementById("english").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("english").remove();
+                    document.getElementById("french").remove();
                     Element title_chinese = document.getElementById("title_chinese");
                     title_chinese.text(sdf2.format(orderLogistics.getTravelTime()) + ",您在I-GO1个订单消费GHS " + orderLogistics.getPayMoney());
                     Element xcf_chinese = document.getElementById("xcf_chinese");
@@ -639,14 +693,19 @@
                     pay_money_chinese.text("GHS " + orderLogistics.getPayMoney());
                     Element pay_time_chinese = document.getElementById("pay_time_chinese");
                     pay_time_chinese.text(sdf1.format(orderLogistics.getTravelTime()));
+                    Elements driver_chinese = document.getElementsByClass("driver_chinese");
+                    for (int i = 0; i < driver_chinese.size(); i++) {
+                        Element element = driver_chinese.get(i);
+                        element.text(driver.getFirstName() + "." + driver.getLastName());
+                    }
                     Element start_address_chinese = document.getElementById("start_address_chinese");
                     start_address_chinese.text(orderLogistics.getStartAddress());
                     Element end_address_chinese = document.getElementById("end_address_chinese");
                     end_address_chinese.text(orderLogistics.getEndAddress());
                 }
                 if(2 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("french").remove();
                     Element title_english = document.getElementById("title_english");
                     title_english.text(sdf2.format(orderLogistics.getTravelTime()) + ",You spent GHS " + orderLogistics.getPayMoney() + " on the trip ");
                     Element xcf_english = document.getElementById("xcf_english");
@@ -659,14 +718,19 @@
                     pay_money_english.text("GHS " + orderLogistics.getPayMoney());
                     Element pay_time_english = document.getElementById("pay_time_english");
                     pay_time_english.text(sdf1.format(orderLogistics.getTravelTime()));
+                    Elements driver_english = document.getElementsByClass("driver_english");
+                    for (int i = 0; i < driver_english.size(); i++) {
+                        Element element = driver_english.get(i);
+                        element.text(driver.getFirstName() + "." + driver.getLastName());
+                    }
                     Element start_address_english = document.getElementById("start_address_english");
                     start_address_english.text(orderLogistics.getStartAddress());
                     Element end_address_english = document.getElementById("end_address_english");
                     end_address_english.text(orderLogistics.getEndAddress());
                 }
                 if(3 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("english").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("english").remove();
                     Element title_french = document.getElementById("title_french");
                     title_french.text(sdf2.format(orderLogistics.getTravelTime()) + ",Vous consommez GHS " + orderLogistics.getPayMoney() + " sur votre commande i-go1 le ");
                     Element xcf_french = document.getElementById("xcf_french");
@@ -679,13 +743,18 @@
                     pay_money_french.text("GHS " + orderLogistics.getPayMoney());
                     Element pay_time_french = document.getElementById("pay_time_french");
                     pay_time_french.text(sdf1.format(orderLogistics.getTravelTime()));
+                    Elements driver_french = document.getElementsByClass("driver_french");
+                    for (int i = 0; i < driver_french.size(); i++) {
+                        Element element = driver_french.get(i);
+                        element.text(driver.getFirstName() + "." + driver.getLastName());
+                    }
                     Element start_address_french = document.getElementById("start_address_french");
                     start_address_french.text(orderLogistics.getStartAddress());
                     Element end_address_french = document.getElementById("end_address_french");
                     end_address_french.text(orderLogistics.getEndAddress());
                 }
 
-                EmailUtil.send(userInfo.getEmail(), language == 1 ? "市内小件物流收据" : language == 2 ? "Reset password" : "Réinitialiser le mot de passe",  document.html());
+                EmailUtil.send(userInfo.getEmail(), language == 1 ? "包裹收据" : language == 2 ? "Parcel receipt" : "Réception de colis",  document.html());
             }
 
 
@@ -698,9 +767,9 @@
                 }
             }).start();
 
-            systemNoticeService.addSystemNotice(1, language == 1 ? "您已使用现金成功完成小件物流订单支付,谢谢使用!" : language == 2
-                    ? "You have successfully completed the payment of small logistics order with cash, thank you for using!" :
-                    "Vous avez utilisé de l’argent pour compléter avec succès le paiement de la commande small pieces logistics. Merci d’utiliser!", uid, 1);
+            systemNoticeService.addSystemNotice(1, language == 1 ? "您已成功完成包裹订单支付,谢谢使用!" : language == 2
+                    ? "You have successfully completed the parcel order payment, thank you for using!" :
+                    "Vous avez terminé avec succès le paiement de la commande de colis, merci de l’utiliser!", uid, 1);
 
             this.pushOrder(orderLogistics);//推单
         }
@@ -721,33 +790,51 @@
      * @throws Exception
      */
     @Override
-    public ResultUtil payLogisticsOrder_(Integer payType, String accountNumber, Integer orderId, Integer type, Integer language) throws Exception {
+    public ResultUtil payLogisticsOrder_(Integer payType, Integer bankCardId, Integer orderId, Integer type, Integer language) throws Exception {
         OrderLogistics orderLogistics = this.selectById(orderId);
         Integer uid = orderLogistics.getUserId();
         OrderLogisticsSpread orderLogisticsSpread = orderLogisticsSpreadService.selectOne(new EntityWrapper<OrderLogisticsSpread>().eq("orderLogisticsId", orderId));
         Double orderMoney = orderLogisticsSpread.getPrice();
         UserInfo userInfo = userInfoService.selectById(uid);
         ResultUtil resultUtil = ResultUtil.success("");
-        if(payType == 1){//线上支付
+        if(payType == 1){//手机支付
             SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
             String merchantTransactionId = sdf.format(new Date()) + "4" + language + orderId;
             CheckoutRequest checkoutRequest = new CheckoutRequest();
             checkoutRequest.setMsisdn(Long.valueOf(userInfo.getPhone()));
             checkoutRequest.setCustomerEmail(userInfo.getEmail());
-            checkoutRequest.setAccountNumber(accountNumber);
+            checkoutRequest.setAccountNumber(userInfo.getPhone());
             checkoutRequest.setCustomerFirstName(userInfo.getFirstName());
             checkoutRequest.setCustomerLastName(userInfo.getLastName());
             checkoutRequest.setRequestAmount(orderMoney);
             checkoutRequest.setMerchantTransactionId(merchantTransactionId);
             checkoutRequest.setRequestDescription("Travel completion payment");
-            checkoutRequest.setCallbackUrl(callbackPath + "/base/wxPayOrderTaxi");
+            checkoutRequest.setCallbackUrl(callbackPath + "/base/wxPayOrderLogisticsSpread");
             checkoutRequest.setPendingRedirectUrl("");
-            checkoutRequest.setSuccessRedirectUrl("https://10pz685243.zicp.fun");
-            checkoutRequest.setFailRedirectUrl("https://www.baidu.com");
+            checkoutRequest.setSuccessRedirectUrl("http://182.160.16.251:81/payMoney/pages/success.html");
+            checkoutRequest.setFailRedirectUrl("http://182.160.16.251:81/payMoney/pages/fail.html");
             return TinggPayUtil.checkoutRequest(checkoutRequest);
-
-
         }
+        if(payType == 2){//银行卡支付
+            BankCard bankCard = bankCardService.selectById(bankCardId);
+            SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
+            String merchantTransactionId = sdf.format(new Date()) + "4" + language + orderId;
+            CheckoutRequest checkoutRequest = new CheckoutRequest();
+            checkoutRequest.setMsisdn(Long.valueOf(bankCard.getCode()));
+            checkoutRequest.setCustomerEmail(userInfo.getEmail());
+            checkoutRequest.setAccountNumber(bankCard.getCode());
+            checkoutRequest.setCustomerFirstName(bankCard.getFirstName());
+            checkoutRequest.setCustomerLastName(bankCard.getLastName());
+            checkoutRequest.setRequestAmount(orderMoney);
+            checkoutRequest.setMerchantTransactionId(merchantTransactionId);
+            checkoutRequest.setRequestDescription("Travel completion payment");
+            checkoutRequest.setCallbackUrl(callbackPath + "/base/wxPayOrderLogisticsSpread");
+            checkoutRequest.setPendingRedirectUrl("");
+            checkoutRequest.setSuccessRedirectUrl("http://182.160.16.251:81/payMoney/pages/success.html");
+            checkoutRequest.setFailRedirectUrl("http://182.160.16.251:81/payMoney/pages/fail.html");
+            return TinggPayUtil.checkoutRequest(checkoutRequest);
+        }
+
         if(payType == 3){//余额支付
             if(userInfo.getBalance() == null || userInfo.getBalance() < orderMoney){
                 return ResultUtil.error(language == 1 ? "账户余额不足" : language == 2 ? "Insufficient account balance" : "Solde de compte insuffisant");
@@ -759,7 +846,7 @@
             userInfo.setIntegral(userInfo.getIntegral() + (orderMoney.intValue() * query1.getIntegral()));//积分
 
             //添加交易明细
-            transactionDetailsService.saveData(uid, "小件物流补差价", orderMoney, 2, 1, 1, 4, orderId);
+            transactionDetailsService.saveData(uid, "包裹补差价", orderMoney, 2, 1, 1, 4, orderId);
             userInfoService.updateById(userInfo);
 
             orderLogistics.setState(12);//已支付差价
@@ -805,9 +892,9 @@
                 }
             }).start();
 
-            systemNoticeService.addSystemNotice(1, language == 1 ? "您已使用余额成功完成小件物流订单差价支付,谢谢使用!" : language == 2
-                    ? "You have successfully completed the price difference payment of small logistics order with the balance, thank you for using!"
-                    : "Vous avez utilisé le solde pour compléter avec succès le paiement de la différence de prix de la commande de petites pièces logistiques. Merci d’utiliser!", uid, 1);
+            systemNoticeService.addSystemNotice(1, language == 1 ? "您已成功完成包裹订单差价支付,谢谢使用!" : language == 2
+                    ? "You have successfully completed the difference payment of parcel order, thank you for using!"
+                    : "Vous avez complété avec succès le paiement de la différence de commande de colis, merci de l’utiliser!", uid, 1);
         }
 
         if(payType == 4){//现金支付
@@ -815,7 +902,7 @@
             userInfo.setIntegral(userInfo.getIntegral() + (orderMoney.intValue() * query1.getIntegral()));//积分
 
             //添加交易明细
-            transactionDetailsService.saveData(uid, "小件物流补差价", orderMoney, 2, 1, 1, 4, orderId);
+            transactionDetailsService.saveData(uid, "包裹补差价", orderMoney, 2, 1, 1, 4, orderId);
             userInfoService.updateById(userInfo);
 
             orderLogistics.setState(12);//已支付差价
@@ -862,9 +949,9 @@
                 }
             }).start();
 
-            systemNoticeService.addSystemNotice(1, language == 1 ? "您已使用现金成功完成小件物流订单差价支付,谢谢使用!" : language == 2
-                    ? "You have successfully completed the price difference payment of small logistics order with cash, thank you for using!"
-                    : "Vous avez utilisé de l’argent pour compléter avec succès le paiement de la différence de prix de la commande de petites pièces logistiques. Merci d’utiliser!", uid, 1);
+            systemNoticeService.addSystemNotice(1, language == 1 ? "您已成功完成包裹订单差价支付,谢谢使用!" : language == 2
+                    ? "You have successfully completed the difference payment of parcel order, thank you for using!"
+                    : "Vous avez complété avec succès le paiement de la différence de commande de colis, merci de l’utiliser!", uid, 1);
         }
 
 
@@ -875,14 +962,14 @@
 
 
     @Override
-    public void payOrderLogisticsCallback(Integer id, String order_id, Integer type, Integer language) throws Exception {
+    public void payOrderLogisticsCallback(Integer id, String order_id, Integer language) throws Exception {
         OrderLogistics orderLogistics = this.selectById(id);
-        PaymentRecord query = paymentRecordService.query(1, null, null, Integer.valueOf(id), orderLogistics.getType(), type, 1);
+        PaymentRecord query = paymentRecordService.query(1, null, null, Integer.valueOf(id), orderLogistics.getType(), null, 1);
         if(null != query){
             //添加交易明细
             transactionDetailsService.saveData(orderLogistics.getUserId(), "完成订单", query.getAmount(), 2, 1, 1, orderLogistics.getType(), query.getOrderId());
             orderLogistics.setState(1);//先支付后抢单
-            orderLogistics.setPayType(type);
+            orderLogistics.setPayType(query.getPayType());
             orderLogistics.setPayMoney(query.getAmount());
             this.updateById(orderLogistics);
 
@@ -900,9 +987,10 @@
                 Document document = Jsoup.parse(new File(path), "UTF-8");
                 SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日");
                 SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy/MM/dd HH:mm");
+                Driver driver = driverService.selectById(orderLogistics.getDriverId());
                 if(1 == language){
-                    document.getElementById("english").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("english").remove();
+                    document.getElementById("french").remove();
                     Element title_chinese = document.getElementById("title_chinese");
                     title_chinese.text(sdf.format(orderLogistics.getTravelTime()) + ",您在I-GO1个订单消费GHS " + orderLogistics.getPayMoney());
                     Element xcf_chinese = document.getElementById("xcf_chinese");
@@ -915,14 +1003,19 @@
                     pay_money_chinese.text("GHS " + orderLogistics.getPayMoney());
                     Element pay_time_chinese = document.getElementById("pay_time_chinese");
                     pay_time_chinese.text(sdf1.format(orderLogistics.getTravelTime()));
+                    Elements driver_chinese = document.getElementsByClass("driver_chinese");
+                    for (int i = 0; i < driver_chinese.size(); i++) {
+                        Element element = driver_chinese.get(i);
+                        element.text(driver.getFirstName() + "." + driver.getLastName());
+                    }
                     Element start_address_chinese = document.getElementById("start_address_chinese");
                     start_address_chinese.text(orderLogistics.getStartAddress());
                     Element end_address_chinese = document.getElementById("end_address_chinese");
                     end_address_chinese.text(orderLogistics.getEndAddress());
                 }
                 if(2 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("french").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("french").remove();
                     Element title_english = document.getElementById("title_english");
                     title_english.text(sdf.format(orderLogistics.getTravelTime()) + ",You spent GHS " + orderLogistics.getPayMoney() + " on the trip ");
                     Element xcf_english = document.getElementById("xcf_english");
@@ -935,14 +1028,19 @@
                     pay_money_english.text("GHS " + orderLogistics.getPayMoney());
                     Element pay_time_english = document.getElementById("pay_time_english");
                     pay_time_english.text(sdf1.format(orderLogistics.getTravelTime()));
+                    Elements driver_english = document.getElementsByClass("driver_english");
+                    for (int i = 0; i < driver_english.size(); i++) {
+                        Element element = driver_english.get(i);
+                        element.text(driver.getFirstName() + "." + driver.getLastName());
+                    }
                     Element start_address_english = document.getElementById("start_address_english");
                     start_address_english.text(orderLogistics.getStartAddress());
                     Element end_address_english = document.getElementById("end_address_english");
                     end_address_english.text(orderLogistics.getEndAddress());
                 }
                 if(3 == language){
-                    document.getElementById("chinese").attr("style", "display: none;");
-                    document.getElementById("english").attr("style", "display: none;");
+                    document.getElementById("chinese").remove();
+                    document.getElementById("english").remove();
                     Element title_french = document.getElementById("title_french");
                     title_french.text(sdf.format(orderLogistics.getTravelTime()) + ",Vous consommez GHS " + orderLogistics.getPayMoney() + " sur votre commande i-go1 le ");
                     Element xcf_french = document.getElementById("xcf_french");
@@ -955,13 +1053,18 @@
                     pay_money_french.text("GHS " + orderLogistics.getPayMoney());
                     Element pay_time_french = document.getElementById("pay_time_french");
                     pay_time_french.text(sdf1.format(orderLogistics.getTravelTime()));
+                    Elements driver_french = document.getElementsByClass("driver_french");
+                    for (int i = 0; i < driver_french.size(); i++) {
+                        Element element = driver_french.get(i);
+                        element.text(driver.getFirstName() + "." + driver.getLastName());
+                    }
                     Element start_address_french = document.getElementById("start_address_french");
                     start_address_french.text(orderLogistics.getStartAddress());
                     Element end_address_french = document.getElementById("end_address_french");
                     end_address_french.text(orderLogistics.getEndAddress());
                 }
 
-                EmailUtil.send(userInfo.getEmail(), language == 1 ? "市内小件物流收据" : language == 2 ? "Reset password" : "Réinitialiser le mot de passe",  document.html());
+                EmailUtil.send(userInfo.getEmail(), language == 1 ? "包裹收据" : language == 2 ? "Parcel receipt" : "Réception de colis",  document.html());
             }
 
 
@@ -975,7 +1078,9 @@
             }).start();
 
 
-            systemNoticeService.addSystemNotice(1, "您已使用" + (type == 1 ? "微信" : "支付宝") + "成功完成小件物流订单支付,谢谢使用!", orderLogistics.getUserId(), 1);
+            systemNoticeService.addSystemNotice(1, language == 1 ? "您已成功完成包裹订单支付,谢谢使用!" : language == 2
+                    ? "You have successfully completed the parcel order payment, thank you for using!" :
+                    "Vous avez terminé avec succès le paiement de la commande de colis, merci de l’utiliser!", orderLogistics.getUserId(), 1);
 
             this.pushOrder(orderLogistics);//推单
         }else{
@@ -986,29 +1091,32 @@
 
 
     @Override
-    public void payOrderLogisticsSpreadCallback(Integer id, String order_id, Integer type) throws Exception {
+    public void payOrderLogisticsSpreadCallback(Integer id, String order_id, Integer language) throws Exception {
         OrderLogistics orderLogistics = this.selectById(id);
         OrderLogisticsSpread orderLogisticsSpread = orderLogisticsSpreadService.selectOne(new EntityWrapper<OrderLogisticsSpread>().eq("orderLogisticsId", id));
-        PaymentRecord query = paymentRecordService.query(1, null, null, Integer.valueOf(id), orderLogistics.getType(), type, 1);
+        PaymentRecord query = paymentRecordService.query(1, null, null, Integer.valueOf(id), orderLogistics.getType(), null, 1);
         if(null != query){
-            //添加交易明细
-            transactionDetailsService.saveData(orderLogistics.getUserId(), "小件物流补差价", query.getAmount(), 2, 1, 1, 4, query.getOrderId());
-            orderLogistics.setState(4);//待取货
-            this.updateById(orderLogistics);
+            Double orderMoney = query.getAmount();
+            query.setState(2);
+            query.setCode(order_id);
+            paymentRecordService.updateById(query);
 
             orderLogisticsSpread.setPayMoney(query.getAmount());
             orderLogisticsSpread.setPayTime(new Date());
-            orderLogisticsSpread.setPayType(3);
+            orderLogisticsSpread.setPayType(query.getPayType());
+            orderLogisticsSpread.setDriverPay(1);
             orderLogisticsSpreadService.updateById(orderLogisticsSpread);
 
             UserInfo userInfo = userInfoService.selectById(orderLogistics.getUserId());
             SysIntegral query1 = sysIntegralMapper.query(orderLogistics.getCompanyId());
-            userInfo.setIntegral(userInfo.getIntegral() + (query.getAmount().intValue() * query1.getIntegral()));//积分
+            userInfo.setIntegral(userInfo.getIntegral() + (orderMoney.intValue() * query1.getIntegral()));//积分
+
+            //添加交易明细
+            transactionDetailsService.saveData(orderLogistics.getUserId(), "包裹补差价", orderMoney, 2, 1, 1, 4, id);
             userInfoService.updateById(userInfo);
 
-            query.setState(2);
-            query.setCode(order_id);
-            paymentRecordService.updateById(query);
+            orderLogistics.setState(12);//已支付差价
+            this.updateById(orderLogistics);
 
             //添加已收入明细
             Company company = companyService.selectById(orderLogistics.getCompanyId());
@@ -1017,12 +1125,13 @@
             BigDecimal c = null;
             if(company.getIsSpeFixedOrProportional() == 2){//固定
                 d = new BigDecimal(speMoney);
-                c = new BigDecimal(query.getAmount()).subtract(d).setScale(2, BigDecimal.ROUND_HALF_EVEN);
+                c = new BigDecimal(orderMoney).subtract(d);
             }
             if(company.getIsSpeFixedOrProportional() == 1){//比例
-                d = new BigDecimal(query.getAmount()).multiply(new BigDecimal(speMoney).divide(new BigDecimal(100), new MathContext(2, RoundingMode.HALF_EVEN)));
-                c = new BigDecimal(query.getAmount()).subtract(d).setScale(2, BigDecimal.ROUND_HALF_EVEN);
+                d = new BigDecimal(orderMoney).multiply(new BigDecimal(speMoney).divide(new BigDecimal(100), new MathContext(2, RoundingMode.HALF_EVEN)));
+                c = new BigDecimal(orderMoney).subtract(d).setScale(2, BigDecimal.ROUND_HALF_EVEN);
             }
+
             Income income = incomeService.selectOne(new EntityWrapper<Income>().eq("userType", 1).eq("objectId", orderLogistics.getCompanyId()).eq("type", 2).eq("incomeId", orderLogistics.getId()).eq("orderType", orderLogistics.getType()));
             income.setMoney(income.getMoney() + d.doubleValue());
             incomeService.updateById(income);
@@ -1044,8 +1153,9 @@
                 }
             }).start();
 
-
-            systemNoticeService.addSystemNotice(1, "您已使用" + (type == 1 ? "微信" : "支付宝") + "成功完成小件物流订单差价支付,谢谢使用!", orderLogistics.getUserId(), 1);
+            systemNoticeService.addSystemNotice(1, language == 1 ? "您已成功完成包裹订单差价支付,谢谢使用!" : language == 2
+                    ? "You have successfully completed the difference payment of parcel order, thank you for using!"
+                    : "Vous avez complété avec succès le paiement de la différence de commande de colis, merci de l’utiliser!", orderLogistics.getUserId(), 1);
         }else{
             System.err.println("预支付数据异常(orderId = "  + id + ")");
         }
@@ -1076,9 +1186,9 @@
      * @throws Exception
      */
     @Override
-    public List<Map<String, Object>> queryMyOrderList(Integer uid, Integer pageNum, Integer size) throws Exception {
+    public List<Map<String, Object>> queryMyOrderList(Integer uid, Integer pageNum, Integer size, Integer language) throws Exception {
         pageNum = (pageNum - 1) * size;
-        List<Map<String, Object>> maps = orderLogisticsMapper.queryMyOrderList(uid, pageNum, size);
+        List<Map<String, Object>> maps = orderLogisticsMapper.queryMyOrderList(uid, pageNum, size, language);
         return maps;
     }
 
@@ -1153,24 +1263,21 @@
             orderCancelService.insert(orderCancel);
             orderLogistics.setState(10);
             this.updateById(orderLogistics);
-            integer = orderCancel.getId();
             //调用回退接口
             PaymentRecord query = paymentRecordService.query(1, orderLogistics.getUserId(), 1, orderLogistics.getId(), orderLogistics.getType(), 1, 2);
-            Map<String, String>  merrefund = payMoneyUtil.wxRefund(query.getCode(),orderLogistics.getId() + "," + orderLogistics.getType(),query.getAmount()+"",query.getAmount()+"","");
-            //Map<String, Object> merrefund = icbcPayUtil.merrefund(query.getCode(), "", query.getAmount(), orderLogistics.getId() + "_" + orderLogistics.getType(), orderLogistics.getOrderNum());
-            if ("SUCCESS".equals(merrefund.get("return_code"))) {//成功
-                //添加交易明细
-                transactionDetailsService.saveData(orderLogistics.getUserId(), "小件物流取消退款", query.getAmount(), 1, 1, 1, 4, orderLogistics.getId());
-            }else{
-                return ResultUtil.error("退款返回未知异常");
+            UserInfo userInfo = userInfoService.selectById(orderLogistics.getUserId());
+            SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
+            String payerTransactionID = sdf.format(new Date()) + orderCancel.getId();
+            PayoutResponse payoutResponse = tinggPayoutUtil.sendPayout(userInfo.getPhoneOperator(), "+" + userInfo.getPhone(), payerTransactionID, query.getAmount().doubleValue(), callbackPath + "/base/orderCancelRefundCallback", "取消订单退款");
+            AuthStatus authStatus = payoutResponse.getAuthStatus();
+            Results results = payoutResponse.getResults().get(0);
+            String statusCode = results.getStatusCode();
+            if(!"131".equals(authStatus.getAuthStatusCode())){
+                return ResultUtil.error(authStatus.getAuthStatusDescription());
             }
-            /*if (Integer.valueOf(refundqry.get("code").toString()) == 0 && Integer.valueOf(refundqry.get("pay_status").toString()) == 1) {//失败
-                return ResultUtil.error("订单取消失败(退款不成功)");
+            if(!"139".equals(statusCode)){
+                return ResultUtil.error(results.getStatusDescription());
             }
-            if (Integer.valueOf(refundqry.get("code").toString()) == 0 && Integer.valueOf(refundqry.get("pay_status").toString()) == 2) {//未知
-
-
-            }*/
         }
         if(null != orderLogistics.getPayType() && orderLogistics.getPayType() == 2){//支付宝
             OrderCancel orderCancel = new OrderCancel();
@@ -1186,29 +1293,19 @@
             this.updateById(orderLogistics);
             integer = orderCancel.getId();
             //调用回退接口
-            PaymentRecord query = paymentRecordService.query(1, orderLogistics.getUserId(), 1, orderLogistics.getId(), orderLogistics.getType(), 2, 2);
-            /*Map<String, Object> merrefund = icbcPayUtil.merrefund(query.getCode(), "", query.getAmount(), orderLogistics.getId() + "_" + orderLogistics.getType(), orderLogistics.getOrderNum());
-            if (Integer.valueOf(merrefund.get("code").toString()) == 0) {
-                Map<String, Object> refundqry = icbcPayUtil.refundqry("", query.getCode(), orderLogistics.getOrderNum());
-                if (Integer.valueOf(refundqry.get("code").toString()) == 0 && Integer.valueOf(refundqry.get("pay_status").toString()) == 0) {//成功
-                    //添加交易明细
-                    transactionDetailsService.saveData(orderLogistics.getUserId(), "小件物流取消退款", query.getAmount(), 1, 1, 1, 4, orderLogistics.getId());
-                }
-                if (Integer.valueOf(refundqry.get("code").toString()) == 0 && Integer.valueOf(refundqry.get("pay_status").toString()) == 1) {//失败
-                    return ResultUtil.error("订单取消失败(退款不成功)");
-                }
-                if (Integer.valueOf(refundqry.get("code").toString()) == 0 && Integer.valueOf(refundqry.get("pay_status").toString()) == 2) {//未知
-                    return ResultUtil.error("退款返回未知异常");
-
-                }
-            }*/
-            Map<String, String>  merrefund = payMoneyUtil.aliRefund(query.getCode(),query.getAmount()+"");
-            //Map<String, Object> merrefund = icbcPayUtil.merrefund(query.getCode(), "", query.getAmount(), orderLogistics.getId() + "_" + orderLogistics.getType(), orderLogistics.getOrderNum());
-            if ("SUCCESS".equals(merrefund.get("return_code"))) {//成功
-                //添加交易明细
-                transactionDetailsService.saveData(orderLogistics.getUserId(), "小件物流取消退款", query.getAmount(), 1, 1, 1, 4, orderLogistics.getId());
-            }else{
-                return ResultUtil.error("退款返回未知异常");
+            PaymentRecord query = paymentRecordService.query(1, orderLogistics.getUserId(), 1, orderLogistics.getId(), orderLogistics.getType(), 1, 2);
+            UserInfo userInfo = userInfoService.selectById(orderLogistics.getUserId());
+            SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
+            String payerTransactionID = sdf.format(new Date()) + orderCancel.getId();
+            PayoutResponse payoutResponse = tinggPayoutUtil.sendPayout(userInfo.getPhoneOperator(), "+" + userInfo.getPhone(), payerTransactionID, query.getAmount().doubleValue(), callbackPath + "/base/orderCancelRefundCallback", "取消订单退款");
+            AuthStatus authStatus = payoutResponse.getAuthStatus();
+            Results results = payoutResponse.getResults().get(0);
+            String statusCode = results.getStatusCode();
+            if(!"131".equals(authStatus.getAuthStatusCode())){
+                return ResultUtil.error(authStatus.getAuthStatusDescription());
+            }
+            if(!"139".equals(statusCode)){
+                return ResultUtil.error(results.getStatusDescription());
             }
         }
         if(null != orderLogistics.getPayType() && orderLogistics.getPayType() == 3){//余额
@@ -1230,7 +1327,7 @@
             integer = orderCancel.getId();
 
             //添加交易明细
-            transactionDetailsService.saveData(orderLogistics.getUserId(), "小件物流取消退款", orderLogistics.getPayMoney(), 1, 1, 1, 4, orderLogistics.getId());
+            transactionDetailsService.saveData(orderLogistics.getUserId(), "包裹取消退款", orderLogistics.getPayMoney(), 1, 1, 1, 4, orderLogistics.getId());
         }
 
         if(null != orderLogistics.getDriverId()){
@@ -1243,7 +1340,8 @@
         }
 
         //添加消息
-        systemNoticeService.addSystemNotice(1, language == 1 ? "您已成功取消小件物流订单,谢谢使用!" : language == 2 ? "You have successfully cancelled the small logistics order, thank you for using" : "Vous avez annulé avec succès la petite commande logistique, merci d'utiliser", orderLogistics.getUserId(), 1);
+        systemNoticeService.addSystemNotice(1, language == 1 ? "您已成功取消包裹订单,谢谢使用!" : language == 2 ? "You have successfully cancelled your parcel order, thank you for using!"
+                : "Vous avez annulé avec succès votre commande de colis, merci de l’utiliser!", orderLogistics.getUserId(), 1);
         Map<String, Object> map = new HashMap<>();
         map.put("id", integer);
         return ResultUtil.success(map);

--
Gitblit v1.7.1