From 6f208a47d331e9356313ba3eae55a07deb083ecd Mon Sep 17 00:00:00 2001 From: Pu Zhibing <393733352@qq.com> Date: 星期一, 28 四月 2025 17:44:08 +0800 Subject: [PATCH] 新增加功能 --- DriverOKTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/taxi/service/impl/OrderTaxiServiceImpl.java | 135 ++++++++++++++++++++++----------------------- 1 files changed, 66 insertions(+), 69 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 2731db8..5212f96 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 @@ -455,63 +455,7 @@ orderTaxi.setGetoffAddress(address); orderTaxi.setGetoffTime(new Date()); orderTaxi.setEndServiceTime(new Date()); - if(orderTaxi.getPayManner()==3){ - orderTaxi.setState(9); - Driver driver = driverService.selectById(orderTaxi.getDriverId()); - - Company company = companyService.selectById(driver.getFranchiseeId()); - if(Objects.isNull(company)){ - company = companyService.selectById(driver.getCompanyId()); - } - TransactionDetails transactionDetails = new TransactionDetails(); - 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); - } - //打表计费,直接订单完成支付, - if(orderTaxi.getPayManner()==2){ - orderTaxi = this.setMoney2(orderTaxi, 0D, 0D); - //在线上计费的基础上随机加0.01-1的金额 - Double orderMoney = orderTaxi.getOrderMoney() + (new BigDecimal(Math.random()).setScale(2, BigDecimal.ROUND_DOWN).doubleValue()); - orderTaxi.setState(8); - orderTaxi.setOrderMoney(orderMoney); - orderTaxi.setPayMoney(orderMoney); - Driver driver = driverService.selectById(orderTaxi.getDriverId()); - - Company company = companyService.selectById(driver.getFranchiseeId()); - if(Objects.isNull(company)){ - company = companyService.selectById(driver.getCompanyId()); - } - TransactionDetails transactionDetails = new TransactionDetails(); - 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); - } - //线上计费,计算费用后修改为待支付 - if(orderTaxi.getPayManner()==1){ - orderTaxi = this.setMoney2(orderTaxi, 0D, 0D); - orderTaxi.setState(7); - } + orderTaxi.setState(6); //回滚司机状态为空闲 Driver driver = driverService.selectById(orderTaxi.getDriverId()); driver.setState(2); @@ -549,22 +493,72 @@ @Override public ResultUtil confirmFees(Integer orderId, Integer type, Double travelFee, Double parkingFee, Double crossingFee) throws Exception { OrderTaxi orderTaxi = this.selectById(orderId); - orderTaxi.setPayManner(type); - if(type == 2){//其他支付,不需要操作,直接完成订单 - orderTaxi = this.setMoney1(orderTaxi, travelFee, parkingFee, crossingFee); - orderTaxi.setState(7); - }else if (type == 1){ + if(2 == type && orderTaxi.getPayManner()==3){ + orderTaxi.setState(9); + Driver driver = driverService.selectById(orderTaxi.getDriverId()); + + Company company = companyService.selectById(driver.getFranchiseeId()); + if(Objects.isNull(company)){ + company = companyService.selectById(driver.getCompanyId()); + } + TransactionDetails transactionDetails = new TransactionDetails(); + 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); + } + //打表计费,直接订单完成支付, + if(2 == type && orderTaxi.getPayManner()==2){ orderTaxi = this.setMoney2(orderTaxi, parkingFee, crossingFee); - orderTaxi.setState(7); - }else { + //在线上计费的基础上随机加0.01-1的金额 + Double orderMoney = orderTaxi.getOrderMoney() + (new BigDecimal(Math.random()).setScale(2, BigDecimal.ROUND_DOWN).doubleValue()); orderTaxi.setState(8); + orderTaxi.setOrderMoney(orderMoney); + orderTaxi.setPayMoney(orderMoney); + Driver driver = driverService.selectById(orderTaxi.getDriverId()); + + Company company = companyService.selectById(driver.getFranchiseeId()); + if(Objects.isNull(company)){ + company = companyService.selectById(driver.getCompanyId()); + } + TransactionDetails transactionDetails = new TransactionDetails(); + Double meterPrintingFee = company.getMeterPrintingFee(); + Double laveBusinessMoney = driver.getLaveBusinessMoney(); + Double laveActivityMoney = driver.getLaveActivityMoney(); + if(null != laveBusinessMoney && laveBusinessMoney.compareTo(meterPrintingFee) >= 0){ + driver.setLaveBusinessMoney(new BigDecimal(laveBusinessMoney).subtract(new BigDecimal(meterPrintingFee)).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue()); + }else if(null != laveActivityMoney && laveActivityMoney.compareTo(meterPrintingFee) >= 0){ + driver.setLaveActivityMoney(new BigDecimal(laveActivityMoney).subtract(new BigDecimal(meterPrintingFee)).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue()); + } + driver.setBalance(driver.getBalance() - meterPrintingFee); + transactionDetails.setMoney(meterPrintingFee); + // 新增扣除使用费记录 + 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); + } + //线上计费,计算费用后修改为待支付 + if(1 == type && orderTaxi.getPayManner()==1){ + orderTaxi = this.setMoney2(orderTaxi, crossingFee, crossingFee); + orderTaxi.setState(7); } this.updateById(orderTaxi); - - //回滚司机状态为空闲 - Driver driver = driverService.selectById(orderTaxi.getDriverId()); - driver.setState(2); - driverService.updateById(driver); OrderTaxi finalOrderTaxi = orderTaxi; new Thread(new Runnable() { @@ -777,6 +771,9 @@ System.err.println("订单数据异常:" + orderId); return false; } + if(orderTaxi.getState() != 5){ + return false; + } OrderPosition orderPosition = orderPositionService.queryNew(orderId, 2); String now = lon + "," + lat; String old = null; -- Gitblit v1.7.1