From 2e97a0b58cc60cb076843b3a860732f71762cff7 Mon Sep 17 00:00:00 2001 From: xuhy <3313886187@qq.com> Date: 星期四, 16 一月 2025 19:08:15 +0800 Subject: [PATCH] 修改 --- DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java | 87 +++++++++++++++++++++++++++++-------------- 1 files changed, 59 insertions(+), 28 deletions(-) diff --git a/DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java b/DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java index 9ab6a9c..fd3556f 100644 --- a/DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java +++ b/DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java @@ -46,7 +46,8 @@ @Autowired private GDMapElectricFenceUtil gdMapElectricFenceUtil; - + @Autowired + private ITransactionDetailsService transactionDetailsService; @Autowired private GDFalconUtil gdFalconUtil; @@ -208,7 +209,22 @@ Company company = companyService.selectById(driver.getCompanyId()); orderTaxi.setState(9); driver.setState(2); - driver.setBalance(driver.getBalance() - company.getFixedDeduction()); +// driver.setBalance(driver.getBalance() - company.getFixedDeduction()); + + if(Objects.isNull(company)){ + company = companyService.selectById(driver.getCompanyId()); + } + // 平台收入 + double money; + if(orderTaxi.getOrderSource() == 2 || orderTaxi.getOrderSource() == 3){ + double v = company.getPercentageDeduction() / 100; + money = v * orderTaxi.getOrderMoney(); + }else { + money = company.getFixedDeduction(); + } + driver.setBalance(driver.getBalance() - money); + // 新增扣除使用费记录 + transactionDetailsService.saveData(driver.getId(), "软件使用费", money, 2, 1, 2, 6, orderTaxi.getId(),company.getId()); driverService.updateById(driver); Car car = carService.selectById(driver.getCarId()); @@ -438,33 +454,37 @@ orderTaxi.setGetoffLat(lat); orderTaxi.setGetoffAddress(address); orderTaxi.setGetoffTime(new Date()); - orderTaxi.setState(6); + if(orderTaxi.getPayManner()==3){ + orderTaxi.setState(9); + }else { + orderTaxi.setState(6); + } orderTaxi.setEndServiceTime(new Date()); // List<TUseMoney> money = useMoneyMapper.selectList(null); - Driver driver = driverService.selectById(orderTaxi.getDriverId()); - Company company = companyService.selectById(driver.getCompanyId()); - TransactionDetails transactionDetails = new TransactionDetails(); - if(orderTaxi.getOrderSource() == 2 || orderTaxi.getOrderSource() == 3){ - double v = company.getPercentageDeduction() / 100; - v = v * orderTaxi.getOrderMoney(); - driver.setBalance(driver.getBalance() - v); - transactionDetails.setMoney(v); - }else { - driver.setBalance(driver.getBalance() - company.getFixedDeduction()); - transactionDetails.setMoney(company.getFixedDeduction()); - } - // 新增扣除使用费记录 - transactionDetails.setUserId(driver.getId()); - transactionDetails.setInsertTime(new Date()); - transactionDetails.setRemark("软件使用费"); - transactionDetails.setState(2); - transactionDetails.setType(1); - transactionDetails.setUserType(2); - transactionDetails.setOrderType(6); - transactionDetails.setOrderId(orderTaxi.getId()); - transactionDetailsMapper.insert(transactionDetails); - driverService.updateById(driver); +// Driver driver = driverService.selectById(orderTaxi.getDriverId()); +// Company company = companyService.selectById(driver.getCompanyId()); +// TransactionDetails transactionDetails = new TransactionDetails(); +// if(orderTaxi.getOrderSource() == 2 || orderTaxi.getOrderSource() == 3){ +// double v = company.getPercentageDeduction() / 100; +// v = v * orderTaxi.getOrderMoney(); +// driver.setBalance(driver.getBalance() - v); +// transactionDetails.setMoney(v); +// }else { +// driver.setBalance(driver.getBalance() - company.getFixedDeduction()); +// transactionDetails.setMoney(company.getFixedDeduction()); +// } +// // 新增扣除使用费记录 +// transactionDetails.setUserId(driver.getId()); +// transactionDetails.setInsertTime(new Date()); +// transactionDetails.setRemark("软件使用费"); +// transactionDetails.setState(2); +// transactionDetails.setType(1); +// transactionDetails.setUserType(2); +// transactionDetails.setOrderType(6); +// transactionDetails.setOrderId(orderTaxi.getId()); +// transactionDetailsMapper.insert(transactionDetails); +// driverService.updateById(driver); pushUtil.removeTask(orderId, 2);//删除定时任务,结束推送数据 systemNoticeService.addSystemNotice(1, "司机已结束本次行程,谢谢使用", orderTaxi.getUserId()); break; @@ -500,9 +520,11 @@ if(type == 2){//其他支付,不需要操作,直接完成订单 orderTaxi = this.setMoney1(orderTaxi, travelFee, parkingFee, crossingFee); orderTaxi.setState(7); - }else{ + }else if (type == 1){ orderTaxi = this.setMoney2(orderTaxi, parkingFee, crossingFee); orderTaxi.setState(7); + }else { + orderTaxi.setState(8); } this.updateById(orderTaxi); @@ -776,10 +798,18 @@ if(orderTaxi.getState() == 5 || orderTaxi.getState() == 6){//服务中的时候获取实时费用数据 if(orderTaxi.getPayManner() == 2){//其他支付,不需要操作,直接完成订单 orderTaxi = this.setMoney1(orderTaxi, 0D, 0D, 0D); - }else{ + }else if(orderTaxi.getPayManner() == 1){ orderTaxi = this.setMoney2(orderTaxi, 0D, 0D); + }else { + // 无 } } + + // 查询平台服务费 + TransactionDetails transactionDetails = transactionDetailsService.selectOne(new EntityWrapper<TransactionDetails>() + .eq("orderId", orderId) + .eq("orderType", 6) + .last("LIMIT 1")); Map<String, Object> map = new HashMap<>(); map.put("orderMoney", orderTaxi.getOrderMoney());//订单金额 @@ -799,6 +829,7 @@ map.put("couponMoney", orderTaxi.getCouponMoney());//优惠券抵扣金额 map.put("discountMoney", orderTaxi.getDiscountMoney());//折扣抵扣金额 map.put("discount", orderTaxi.getDiscount());//折扣 + map.put("platformFee", transactionDetails.getMoney());//折扣 return map; } -- Gitblit v1.7.1