From cc788c86acd2983d791fbd3e50a9b30335b91953 Mon Sep 17 00:00:00 2001 From: zhibing.pu <393733352@qq.com> Date: 星期六, 24 八月 2024 15:35:19 +0800 Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/mx_charging_pile --- ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TChargingOrderServiceImpl.java | 71 +++++++++++++++++++++++++++++++++-- 1 files changed, 66 insertions(+), 5 deletions(-) diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TChargingOrderServiceImpl.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TChargingOrderServiceImpl.java index 51ec3ab..016a888 100644 --- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TChargingOrderServiceImpl.java +++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/TChargingOrderServiceImpl.java @@ -1,6 +1,7 @@ package com.ruoyi.order.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ruoyi.account.api.feignClient.AppUserCarClient; import com.ruoyi.account.api.feignClient.AppUserClient; @@ -33,14 +34,18 @@ import com.ruoyi.payment.api.feignClient.WxPaymentClient; import com.ruoyi.payment.api.vo.*; import io.seata.spring.annotation.GlobalTransactional; +import io.swagger.annotations.ApiModelProperty; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.StringUtils; import javax.annotation.Resource; import java.math.BigDecimal; import java.text.SimpleDateFormat; +import java.time.LocalDateTime; import java.time.ZoneOffset; import java.time.format.DateTimeFormatter; +import java.time.temporal.ChronoUnit; import java.util.*; /** @@ -86,10 +91,7 @@ @Resource private RedisService redisService; - - - - + /** * 获取小程序充电记录列表数据 * @param query @@ -426,6 +428,8 @@ @Override public TCharingOrderVO chargingOrder(ChargingOrderQuery dto) { TCharingOrderVO tCharingOrderVO = new TCharingOrderVO(); + + String startTime1 = null; String startTime2 = null; String endTime1 = null; @@ -450,7 +454,64 @@ } PageInfo<ChargingOrderVO> pageInfo = new PageInfo<>(dto.getPageCurr(),dto.getPageSize()); List<ChargingOrderVO> list = this.baseMapper.chargingOrder(pageInfo,dto,startTime1,startTime2,endTime1,endTime2); - + BigDecimal total = new BigDecimal("0"); + long time = 0L; + BigDecimal income = new BigDecimal("0"); + BigDecimal electronicMoney = new BigDecimal("0"); + BigDecimal serviceMoney = new BigDecimal("0"); + for (ChargingOrderVO chargingOrderVO : list) { + total = total.add(chargingOrderVO.getChargingCapacity()); + // 充电订单 明细记录 + List<TChargingOrderAccountingStrategy> chargingOrderId = chargingOrderAccountingStrategyService.list(new QueryWrapper<TChargingOrderAccountingStrategy>() + .eq("charging_order_id", chargingOrderVO.getId())); + // 单个订单累计电费 + BigDecimal electronicMoney1 = new BigDecimal("0"); + // 单个订单累计服务费 + BigDecimal serviceMoney1 = new BigDecimal("0"); + LocalDateTime startTime = chargingOrderVO.getStartTime(); + LocalDateTime endTime = chargingOrderVO.getEndTime(); + // 计算时间差 秒 充电时长 + long between = ChronoUnit.SECONDS.between(startTime, endTime); + chargingOrderVO.setChargingSecond(between); + time += between; + // 总收入 + if (chargingOrderVO.getRefundStatus() == 2){ + income = income.add(chargingOrderVO.getPaymentAmount().subtract(chargingOrderVO.getRefundAmount())); + }else{ + income = income.add(chargingOrderVO.getPaymentAmount()); + } + for (TChargingOrderAccountingStrategy tChargingOrderAccountingStrategy : chargingOrderId) { + // 累计电费 + electronicMoney1 = electronicMoney1.add(tChargingOrderAccountingStrategy.getElectrovalence() + .multiply(tChargingOrderAccountingStrategy.getChargingCapacity())); + electronicMoney = electronicMoney.add(electronicMoney1); + // 累计服务费 + serviceMoney1 = serviceMoney1.add(tChargingOrderAccountingStrategy.getServiceCharge()); + serviceMoney = serviceMoney.add(serviceMoney1); + } + chargingOrderVO.setServiceCharge(serviceMoney1); + chargingOrderVO.setElectrovalence(electronicMoney1); + // 充电时段数 + int size = chargingOrderId.size(); + chargingOrderVO.setCount(size); + // 用户手机号 + TAppUser data = appUserClient.getUserById(chargingOrderVO.getAppUserId()).getData(); + if (data!=null){ + // 车牌号 + chargingOrderVO.setPhone(data.getPhone()); + List<Long> longs = new ArrayList<>(); + longs.add(chargingOrderVO.getAppUserCarId()); + List<TAppUserCar> data1 = appUserCarClient.getCarByIds(longs).getData(); + if (!data1.isEmpty()){ + chargingOrderVO.setLicensePlate(data1.get(0).getLicensePlate()); + } + } + } + tCharingOrderVO.setTotal(total); + tCharingOrderVO.setTime(time); + tCharingOrderVO.setIncome(income); + tCharingOrderVO.setElectronicMoney(electronicMoney); + tCharingOrderVO.setServiceMoney(serviceMoney); pageInfo.setRecords(list); tCharingOrderVO.setList(pageInfo); return tCharingOrderVO; -- Gitblit v1.7.1