|  |  |  | 
|---|
|  |  |  | package com.ruoyi.order.service.impl; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import cn.hutool.core.date.DateUtil; | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSON; | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSONObject; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.annotation.TableField; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | 
|---|
|  |  |  | import com.ruoyi.account.api.feignClient.*; | 
|---|
|  |  |  | import com.ruoyi.account.api.model.*; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.ruoyi.common.core.dto.ChargingOrderGroup; | 
|---|
|  |  |  | import com.ruoyi.common.core.dto.ChargingPercentProvinceDto; | 
|---|
|  |  |  | import com.ruoyi.common.core.web.domain.AjaxResult; | 
|---|
|  |  |  | import com.ruoyi.common.core.web.page.BasePage; | 
|---|
|  |  |  | import com.ruoyi.common.core.web.page.PageInfo; | 
|---|
|  |  |  | import com.ruoyi.common.redis.service.RedisService; | 
|---|
|  |  |  | import com.ruoyi.common.security.service.TokenService; | 
|---|
|  |  |  | import com.ruoyi.common.security.utils.SecurityUtils; | 
|---|
|  |  |  | import com.ruoyi.integration.api.feignClient.ChargingHandshakeClient; | 
|---|
|  |  |  | import com.ruoyi.integration.api.feignClient.PlatformStartChargingReplyClient; | 
|---|
|  |  |  | import com.ruoyi.integration.api.feignClient.SendMessageClient; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.ruoyi.integration.api.feignClient.*; | 
|---|
|  |  |  | import com.ruoyi.integration.api.model.*; | 
|---|
|  |  |  | import com.ruoyi.integration.api.vo.GetPlatformStopChargingReply; | 
|---|
|  |  |  | import com.ruoyi.order.api.dto.SettlementConfirmAdd; | 
|---|
|  |  |  | import com.ruoyi.order.api.feignClient.AccountingStrategyDetailOrderClient; | 
|---|
|  |  |  | import com.ruoyi.order.api.feignClient.ChargingOrderAccountingStrategyClient; | 
|---|
|  |  |  | import com.ruoyi.order.api.model.*; | 
|---|
|  |  |  | import com.ruoyi.order.api.query.ChargingOrderQuery; | 
|---|
|  |  |  | import com.ruoyi.order.api.query.SettlementListQuery; | 
|---|
|  |  |  | import com.ruoyi.order.api.query.UploadRealTimeMonitoringDataQuery; | 
|---|
|  |  |  | import com.ruoyi.order.api.vo.ChargingOrderListVO; | 
|---|
|  |  |  | import com.ruoyi.order.api.vo.ChargingOrderTimeVO; | 
|---|
|  |  |  | import com.ruoyi.order.api.vo.ChargingOrderVO; | 
|---|
|  |  |  | import com.ruoyi.order.api.vo.TCharingOrderVO; | 
|---|
|  |  |  | import com.ruoyi.order.api.vo.*; | 
|---|
|  |  |  | import com.ruoyi.order.dto.*; | 
|---|
|  |  |  | import com.ruoyi.order.mapper.TChargingOrderMapper; | 
|---|
|  |  |  | import com.ruoyi.order.mapper.TSettlementConfirmMapper; | 
|---|
|  |  |  | import com.ruoyi.order.service.TChargingOrderAccountingStrategyService; | 
|---|
|  |  |  | import com.ruoyi.order.service.TChargingOrderRefundService; | 
|---|
|  |  |  | import com.ruoyi.order.service.TChargingOrderService; | 
|---|
|  |  |  | import com.ruoyi.order.service.TOrderEvaluateService; | 
|---|
|  |  |  | import com.ruoyi.order.service.*; | 
|---|
|  |  |  | import com.ruoyi.other.api.domain.TCoupon; | 
|---|
|  |  |  | import com.ruoyi.other.api.domain.TGoods; | 
|---|
|  |  |  | import com.ruoyi.order.vo.ChargingOrderListInfoVO; | 
|---|
|  |  |  | import com.ruoyi.other.api.domain.TIntegralRule; | 
|---|
|  |  |  | import com.ruoyi.other.api.feignClient.IntegralRuleClient; | 
|---|
|  |  |  | import com.ruoyi.other.api.feignClient.OtherClient; | 
|---|
|  |  |  | import com.ruoyi.other.api.feignClient.RoleSiteClient; | 
|---|
|  |  |  | import com.ruoyi.other.api.feignClient.UserSiteClient; | 
|---|
|  |  |  | import com.ruoyi.payment.api.feignClient.AliPaymentClient; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.ruoyi.payment.api.model.RefundResp; | 
|---|
|  |  |  | import com.ruoyi.payment.api.model.WxPaymentRefundModel; | 
|---|
|  |  |  | import com.ruoyi.payment.api.vo.*; | 
|---|
|  |  |  | import com.ruoyi.system.api.domain.SysUser; | 
|---|
|  |  |  | import com.ruoyi.system.api.feignClient.SysUserClient; | 
|---|
|  |  |  | import com.sun.org.apache.bcel.internal.generic.NEW; | 
|---|
|  |  |  | import io.seata.spring.annotation.GlobalTransactional; | 
|---|
|  |  |  | import io.swagger.annotations.ApiModelProperty; | 
|---|
|  |  |  | import org.slf4j.Logger; | 
|---|
|  |  |  | 
|---|
|  |  |  | import java.time.LocalDateTime; | 
|---|
|  |  |  | import java.time.ZoneOffset; | 
|---|
|  |  |  | import java.time.format.DateTimeFormatter; | 
|---|
|  |  |  | import java.time.temporal.ChronoUnit; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  | import java.util.concurrent.*; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private ChargingGunClient chargingGunClient; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private TSettlementConfirmMapper tSettlementConfirmMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private SiteClient siteClient; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private AppUserCarClient appUserCarClient; | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private ChargingPileClient chargingPileClient; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private TChargingOrderAccountingStrategyService chargingOrderAccountingStrategyService; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private AliPaymentClient aliPaymentClient; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private AppCouponClient appCouponClient; | 
|---|
|  |  |  | 
|---|
|  |  |  | //构建新的待支付订单 | 
|---|
|  |  |  | SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS"); | 
|---|
|  |  |  | TChargingOrder chargingOrder = new TChargingOrder(); | 
|---|
|  |  |  | String code = "CD" + Math.random() * 1000 + sdf.format(new Date()); | 
|---|
|  |  |  | String code = "CD" + Double.valueOf(Math.random() * 1000).intValue() + sdf.format(new Date()); | 
|---|
|  |  |  | chargingOrder.setCode(code); | 
|---|
|  |  |  | chargingOrder.setOrderType(1); | 
|---|
|  |  |  | chargingOrder.setOrderClassification(1); | 
|---|
|  |  |  | 
|---|
|  |  |  | chargingOrder.setVipDiscountAmount(discountAmount); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.save(chargingOrder); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //添加订单的计费策略 | 
|---|
|  |  |  | TAccountingStrategy accountingStrategy = accountingStrategyClient.getAccountingStrategyById(tChargingGun.getAccountingStrategyId()).getData(); | 
|---|
|  |  |  | List<TAccountingStrategyDetail> strategyDetailList = accountingStrategyDetailClient.getListByAccountingStrategyId(tChargingGun.getAccountingStrategyId()).getData(); | 
|---|
|  |  |  | Integer accountingStrategyId = tChargingGun.getAccountingStrategyId(); | 
|---|
|  |  |  | if(null == accountingStrategyId){ | 
|---|
|  |  |  | //查询站点上面的计费策略 | 
|---|
|  |  |  | Site site = siteClient.getSiteByIds(Arrays.asList(tChargingGun.getSiteId())).getData().get(0); | 
|---|
|  |  |  | accountingStrategyId = site.getAccountingStrategyId(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TAccountingStrategy accountingStrategy = accountingStrategyClient.getAccountingStrategyById(accountingStrategyId).getData(); | 
|---|
|  |  |  | List<TAccountingStrategyDetail> strategyDetailList = accountingStrategyDetailClient.getListByAccountingStrategyId(accountingStrategyId).getData(); | 
|---|
|  |  |  | AccountingStrategyOrder accountingStrategyOrder = new AccountingStrategyOrder(); | 
|---|
|  |  |  | BeanUtils.copyProperties(accountingStrategy, accountingStrategyOrder); | 
|---|
|  |  |  | accountingStrategyOrder.setChargingOrderId(chargingOrder.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | preChargeCheck1.setFailureCause(failure_cause); | 
|---|
|  |  |  | //启动失败后取消订单,退款操作 | 
|---|
|  |  |  | refund(code); | 
|---|
|  |  |  | order.setStatus(5); | 
|---|
|  |  |  | order.setStatus(-1); | 
|---|
|  |  |  | order.setEndMode(0); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | preChargeCheck1.setStartupSuccess(2); | 
|---|
|  |  |  | 
|---|
|  |  |  | TChargingOrderRefund chargingOrderRefund = new TChargingOrderRefund(); | 
|---|
|  |  |  | chargingOrderRefund.setChargingOrderId(chargingOrder.getId()); | 
|---|
|  |  |  | SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS"); | 
|---|
|  |  |  | chargingOrderRefund.setRefundCode("CDF" + sdf.format(new Date()) + (Math.random() * 1000)); | 
|---|
|  |  |  | chargingOrderRefund.setRefundCode("CDF" + sdf.format(new Date()) + Double.valueOf(Math.random() * 1000).intValue()); | 
|---|
|  |  |  | chargingOrderRefund.setRefundAmount(rechargeAmount); | 
|---|
|  |  |  | chargingOrderRefund.setRefundStatus(1); | 
|---|
|  |  |  | chargingOrderRefund.setPayType(rechargePaymentType); | 
|---|
|  |  |  | 
|---|
|  |  |  | model.setOut_trade_no(chargingOrder.getCode()); | 
|---|
|  |  |  | model.setOut_refund_no(chargingOrderRefund.getRefundCode()); | 
|---|
|  |  |  | model.setReason("充电失败,取消充电订单"); | 
|---|
|  |  |  | model.setNotify_url("http://127.0.0.1:9000/order/t-charging-order/chargingOrderStartupFailureWxRefund"); | 
|---|
|  |  |  | model.setNotify_url("http://221.182.45.100:9000/order/t-charging-order/chargingOrderStartupFailureWxRefund"); | 
|---|
|  |  |  | WxPaymentRefundModel.RefundAmount amount = new WxPaymentRefundModel.RefundAmount(); | 
|---|
|  |  |  | amount.setRefund(rechargeAmount.multiply(new BigDecimal(100)).intValue()); | 
|---|
|  |  |  | amount.setTotal(rechargeAmount.multiply(new BigDecimal(100)).intValue()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TAppUser appUser1 = appUserClient.getUserById(appUser.getInviteUserId()).getData(); | 
|---|
|  |  |  | TAppUserIntegralChange appUserIntegralChange = new TAppUserIntegralChange(); | 
|---|
|  |  |  | String code = Math.random() * 1000 + LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyyMMddHHmmssSSS")); | 
|---|
|  |  |  | String code = Double.valueOf(Math.random() * 1000).intValue() + LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyyMMddHHmmssSSS")); | 
|---|
|  |  |  | appUserIntegralChange.setCode(code); | 
|---|
|  |  |  | appUserIntegralChange.setAppUserId(appUser.getInviteUserId()); | 
|---|
|  |  |  | appUserIntegralChange.setChangeType(5); | 
|---|
|  |  |  | 
|---|
|  |  |  | TChargingOrderRefund chargingOrderRefund = new TChargingOrderRefund(); | 
|---|
|  |  |  | chargingOrderRefund.setChargingOrderId(chargingOrder.getId()); | 
|---|
|  |  |  | SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS"); | 
|---|
|  |  |  | chargingOrderRefund.setRefundCode("CDF" + sdf.format(new Date()) + (Math.random() * 1000)); | 
|---|
|  |  |  | chargingOrderRefund.setRefundCode("CDF" + sdf.format(new Date()) + (Double.valueOf(Math.random() * 1000).intValue())); | 
|---|
|  |  |  | chargingOrderRefund.setRefundAmount(refundAmount); | 
|---|
|  |  |  | chargingOrderRefund.setRefundStatus(1); | 
|---|
|  |  |  | chargingOrderRefund.setPayType(rechargePaymentType); | 
|---|
|  |  |  | 
|---|
|  |  |  | model.setOut_trade_no(chargingOrder.getCode()); | 
|---|
|  |  |  | model.setOut_refund_no(chargingOrderRefund.getRefundCode()); | 
|---|
|  |  |  | model.setReason("充电完成退款"); | 
|---|
|  |  |  | model.setNotify_url("http://127.0.0.1:9000/order/t-charging-order/chargingOrderStartupFailureWxRefund"); | 
|---|
|  |  |  | model.setNotify_url("http://221.182.45.100:9000/order/t-charging-order/chargingOrderStartupFailureWxRefund"); | 
|---|
|  |  |  | WxPaymentRefundModel.RefundAmount amount = new WxPaymentRefundModel.RefundAmount(); | 
|---|
|  |  |  | amount.setRefund(refundAmount.multiply(new BigDecimal(100)).intValue()); | 
|---|
|  |  |  | amount.setTotal(rechargeAmount.multiply(new BigDecimal(100)).intValue()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public Map<String, BigDecimal> countAll(LocalDate sixBefore) { | 
|---|
|  |  |  | public Map<String, Object> countAll(LocalDate sixBefore) { | 
|---|
|  |  |  | return this.baseMapper.countAll(sixBefore); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, BigDecimal>> getSumByType(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | public List<Map<String, Object>> getSumByType(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | return this.baseMapper.getSumByType(chargingOrderIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, BigDecimal>> getDateData(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | public List<Map<String, Object>> getDateData(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | return this.baseMapper.getDateData(chargingOrderIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, BigDecimal>> getWeekData(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | public List<Map<String, Object>> getWeekData(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | return this.baseMapper.getWeekData(chargingOrderIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, BigDecimal>> getMonthData(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | public List<Map<String, Object>> getMonthData(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | return this.baseMapper.getMonthData(chargingOrderIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, BigDecimal>> getYearData(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | public List<Map<String, Object>> getYearData(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | return this.baseMapper.getYearData(chargingOrderIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | 
|---|
|  |  |  | if (!data.isEmpty()) { | 
|---|
|  |  |  | chargingOrderListVO.setSiteName(data.get(0).getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TChargingGun data1 = chargingGunClient.getChargingGunById(chargingOrderListVO.getChargingGunId()).getData(); | 
|---|
|  |  |  | TChargingPile data2 = chargingPileClient.getChargingPileById(chargingOrderListVO.getChargingPileId()).getData(); | 
|---|
|  |  |  | if (data2 != null && data1 != null) { | 
|---|
|  |  |  | chargingOrderListVO.setTerminalName(data2.getName() + "-" + data1.getName()); | 
|---|
|  |  |  | if (chargingOrderListVO.getChargingGunId()!=null && chargingOrderListVO.getChargingPileId()!=null){ | 
|---|
|  |  |  | TChargingGun data1 = chargingGunClient.getChargingGunById(chargingOrderListVO.getChargingGunId()).getData(); | 
|---|
|  |  |  | TChargingPile data2 = chargingPileClient.getChargingPileById(chargingOrderListVO.getChargingPileId()).getData(); | 
|---|
|  |  |  | if (data2 != null && data1 != null) { | 
|---|
|  |  |  | chargingOrderListVO.setTerminalName(data2.getName() + "-" + data1.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 获取充电时间 | 
|---|
|  |  |  | UploadRealTimeMonitoringData data5 = uploadRealTimeMonitoringDataClient.chargingOrderInfo(chargingOrderListVO.getCode()).getData(); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 获取开始SOC 结束soc | 
|---|
|  |  |  | List<UploadRealTimeMonitoringData> data6 = uploadRealTimeMonitoringDataClient.getDataByOrderCode(chargingOrderListVO.getCode()).getData(); | 
|---|
|  |  |  | if (!data6.isEmpty()){ | 
|---|
|  |  |  | // 第一条数据soc为开始 最后一条数据soc为结束soc | 
|---|
|  |  |  | chargingOrderListVO.setStartSoc(data6.get(0).getSoc().toString()); | 
|---|
|  |  |  | chargingOrderListVO.setEndSoc(data6.get(data6.size()-1).getSoc().toString()); | 
|---|
|  |  |  | if (chargingOrderListVO.getCode()!=null){ | 
|---|
|  |  |  | List<UploadRealTimeMonitoringData> data6 = uploadRealTimeMonitoringDataClient.getDataByOrderCode(chargingOrderListVO.getCode()).getData(); | 
|---|
|  |  |  | if (!data6.isEmpty()){ | 
|---|
|  |  |  | // 第一条数据soc为开始 最后一条数据soc为结束soc | 
|---|
|  |  |  | chargingOrderListVO.setStartSoc(data6.get(0).getSoc().toString()); | 
|---|
|  |  |  | chargingOrderListVO.setEndSoc(data6.get(data6.size()-1).getSoc().toString()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TAppUser data3 = appUserClient.getUserById(chargingOrderListVO.getAppUserId()).getData(); | 
|---|
|  |  |  | List<Long> carId = new ArrayList<>(); | 
|---|
|  |  |  | if (chargingOrderListVO.getAppUserCarId() != null) { | 
|---|
|  |  |  | carId.add(chargingOrderListVO.getAppUserCarId()); | 
|---|
|  |  |  | List<TAppUserCar> data4 = appUserCarClient.getCarByIds(carId).getData(); | 
|---|
|  |  |  | if (!data4.isEmpty()) chargingOrderListVO.setLicensePlate(data4.get(0).getLicensePlate()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (chargingOrderListVO.getAppUserId()!=null){ | 
|---|
|  |  |  | TAppUser data3 = appUserClient.getUserById(chargingOrderListVO.getAppUserId()).getData(); | 
|---|
|  |  |  | List<Long> carId = new ArrayList<>(); | 
|---|
|  |  |  | if (data3!=null){ | 
|---|
|  |  |  | if (chargingOrderListVO.getAppUserCarId() != null) { | 
|---|
|  |  |  | carId.add(chargingOrderListVO.getAppUserCarId()); | 
|---|
|  |  |  | if (!carId.isEmpty()){ | 
|---|
|  |  |  | List<TAppUserCar> data4 = appUserCarClient.getCarByIds(carId).getData(); | 
|---|
|  |  |  | if (data4!=null && !data4.isEmpty()) chargingOrderListVO.setLicensePlate(data4.get(0).getLicensePlate()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (data3 != null) chargingOrderListVO.setPhone(data3.getPhone()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (data3 != null) chargingOrderListVO.setPhone(data3.getPhone()); | 
|---|
|  |  |  | List<TChargingOrderAccountingStrategy> list2 = chargingOrderAccountingStrategyService.lambdaQuery() | 
|---|
|  |  |  | .eq(TChargingOrderAccountingStrategy::getChargingOrderId, chargingOrderListVO.getId()).list(); | 
|---|
|  |  |  | // 尖峰平谷充电量 度数 | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | total = total.add(jian).add(feng).add(ping).add(gu); | 
|---|
|  |  |  | chargingOrderListVO.setElectronicProportion( | 
|---|
|  |  |  | jian.divide(total,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%(尖)/" | 
|---|
|  |  |  | +feng.divide(total,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%(峰)/" | 
|---|
|  |  |  | +ping.divide(total,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%(平)/" | 
|---|
|  |  |  | +gu.divide(total,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%(谷)"); | 
|---|
|  |  |  | if (total.compareTo(new BigDecimal("0")) != 0){ | 
|---|
|  |  |  | chargingOrderListVO.setElectronicProportion( | 
|---|
|  |  |  | jian.divide(total,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%(尖)/" | 
|---|
|  |  |  | +feng.divide(total,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%(峰)/" | 
|---|
|  |  |  | +ping.divide(total,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%(平)/" | 
|---|
|  |  |  | +gu.divide(total,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%(谷)"); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | chargingOrderListVO.setElectronicProportion( | 
|---|
|  |  |  | "0"+"%(尖)/"+ | 
|---|
|  |  |  | "0"+"%(峰)/"+ | 
|---|
|  |  |  | "0"+"%(平)/"+ | 
|---|
|  |  |  | "0"+"%(谷)"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 不分页 | 
|---|
|  |  |  | List<ChargingOrderListVO> list1 = this.baseMapper.chargingList1(dto,startTime1,startTime2,endTime1,endTime2); | 
|---|
|  |  |  | PageInfo<ChargingOrderListVO> pageInfo1 = new PageInfo<>(1,999999999); | 
|---|
|  |  |  | List<ChargingOrderListVO> list1 = this.baseMapper.chargingList(pageInfo1,dto,startTime1,startTime2,endTime1,endTime2); | 
|---|
|  |  |  | chargingOrderTimeVO.setExportList(list1); | 
|---|
|  |  |  | chargingOrderTimeVO.setOrderCount(list1.size()); | 
|---|
|  |  |  | // 计算充电总度数 | 
|---|
|  |  |  | BigDecimal electronic = new BigDecimal("0"); | 
|---|
|  |  |  | 
|---|
|  |  |  | BigDecimal ping = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal gu = new BigDecimal("0"); | 
|---|
|  |  |  | for (ChargingOrderListVO chargingOrderListVO : list1) { | 
|---|
|  |  |  | electronic = electronic.add(chargingOrderListVO.getChargingCapacity()); | 
|---|
|  |  |  | paymentAmount = paymentAmount.add(chargingOrderListVO.getPaymentAmount()); | 
|---|
|  |  |  | electrovalence = electrovalence.add(chargingOrderListVO.getElectrovalence()); | 
|---|
|  |  |  | serviceCharge = serviceCharge.add(chargingOrderListVO.getServiceCharge()); | 
|---|
|  |  |  | if (chargingOrderListVO.getChargingCapacity()!=null)electronic = electronic.add(chargingOrderListVO.getChargingCapacity()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (chargingOrderListVO.getPaymentAmount()!=null)paymentAmount = paymentAmount.add(chargingOrderListVO.getPaymentAmount()); | 
|---|
|  |  |  | if (chargingOrderListVO.getElectrovalence()!=null)electrovalence = electrovalence.add(chargingOrderListVO.getElectrovalence()); | 
|---|
|  |  |  | if (chargingOrderListVO.getServiceCharge()!=null)serviceCharge = serviceCharge.add(chargingOrderListVO.getServiceCharge()); | 
|---|
|  |  |  | List<TChargingOrderAccountingStrategy> list2 = chargingOrderAccountingStrategyService.lambdaQuery() | 
|---|
|  |  |  | .eq(TChargingOrderAccountingStrategy::getChargingOrderId, chargingOrderListVO.getId()).list(); | 
|---|
|  |  |  | for (TChargingOrderAccountingStrategy temp : list2) { | 
|---|
|  |  |  | switch (temp.getType()){ | 
|---|
|  |  |  | case 1: | 
|---|
|  |  |  | jian = jian.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | jianElectronic = jianElectronic.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | jianService = jianService.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)jian = jian.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)jianElectronic = jianElectronic.add(temp.getElectrovalence()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)jianService = jianService.add(temp.getServiceCharge()); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 2: | 
|---|
|  |  |  | feng = feng.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | fengElectronic = fengElectronic.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | fengService = fengService.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)feng = feng.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)fengElectronic = fengElectronic.add(temp.getElectrovalence()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)fengService = fengService.add(temp.getServiceCharge()); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 3: | 
|---|
|  |  |  | ping = ping.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | pingElectronic = pingElectronic.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | pingService = pingService.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)ping = ping.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)pingElectronic = pingElectronic.add(temp.getElectrovalence()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)pingService = pingService.add(temp.getServiceCharge()); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 4: | 
|---|
|  |  |  | gu = gu.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | guElectronic = guElectronic.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | guService = guService.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)gu = gu.add(temp.getChargingCapacity()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)guElectronic = guElectronic.add(temp.getElectrovalence()); | 
|---|
|  |  |  | if (temp.getChargingCapacity()!=null)guService = guService.add(temp.getServiceCharge()); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | BigDecimal add1 = jianService.add(fengService).add(pingService).add(guService); | 
|---|
|  |  |  | // 计算尖峰平谷充电到账占比 | 
|---|
|  |  |  | BigDecimal add2 = jian.add(feng).add(ping).add(gu); | 
|---|
|  |  |  | chargingOrderTimeVO.setCapacityProportion(jianElectronic+"度/"+fengElectronic+"度/"+pingElectronic+"度/"+guElectronic+"度-" | 
|---|
|  |  |  | +jianElectronic.divide(add,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +fengElectronic.divide(add,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +pingElectronic.divide(add,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +guElectronic.divide(add,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%"); | 
|---|
|  |  |  | chargingOrderTimeVO.setServiceProportion(jianService+"元/"+fengService+"元/"+pingService+"元/"+guService+"元-" | 
|---|
|  |  |  | +jianService.divide(add1,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +fengService.divide(add1,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +pingService.divide(add1,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +guService.divide(add1,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%"); | 
|---|
|  |  |  | chargingOrderTimeVO.setElectronicProportion(jian+"元/"+feng+"元/"+ping+"元/"+gu+"元-" | 
|---|
|  |  |  | +jian.divide(add2,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +feng.divide(add2,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +ping.divide(add2,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +gu.divide(add2,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%"); | 
|---|
|  |  |  | if (add.compareTo(new BigDecimal("0"))!=0){ | 
|---|
|  |  |  | chargingOrderTimeVO.setCapacityProportion(jianElectronic+"度/"+fengElectronic+"度/"+pingElectronic+"度/"+guElectronic+"度-" | 
|---|
|  |  |  | +jianElectronic.divide(add,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +fengElectronic.divide(add,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +pingElectronic.divide(add,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +guElectronic.divide(add,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%"); | 
|---|
|  |  |  | chargingOrderTimeVO.setServiceProportion(jianService+"元/"+fengService+"元/"+pingService+"元/"+guService+"元-" | 
|---|
|  |  |  | +jianService.divide(add1,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +fengService.divide(add1,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +pingService.divide(add1,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +guService.divide(add1,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%"); | 
|---|
|  |  |  | chargingOrderTimeVO.setElectronicProportion(jian+"元/"+feng+"元/"+ping+"元/"+gu+"元-" | 
|---|
|  |  |  | +jian.divide(add2,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +feng.divide(add2,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +ping.divide(add2,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%/" | 
|---|
|  |  |  | +gu.divide(add2,4,BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"))+"%"); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | chargingOrderTimeVO.setCapacityProportion(jianElectronic+"度/"+fengElectronic+"度/"+pingElectronic+"度/"+guElectronic+"度-" | 
|---|
|  |  |  | +"0"+"%/" | 
|---|
|  |  |  | +"0"+"%/" | 
|---|
|  |  |  | +"0"+"%/" | 
|---|
|  |  |  | +"0"+"%"); | 
|---|
|  |  |  | chargingOrderTimeVO.setServiceProportion(jianService+"元/"+fengService+"元/"+pingService+"元/"+guService+"元-" | 
|---|
|  |  |  | +"0"+"%/" | 
|---|
|  |  |  | +"0"+"%/" | 
|---|
|  |  |  | +"0"+"%/" | 
|---|
|  |  |  | +"0"+"%"); | 
|---|
|  |  |  | chargingOrderTimeVO.setElectronicProportion(jian+"元/"+feng+"元/"+ping+"元/"+gu+"元-" | 
|---|
|  |  |  | +"0"+"%/" | 
|---|
|  |  |  | +"0"+"%/" | 
|---|
|  |  |  | +"0"+"%/" | 
|---|
|  |  |  | +"0"+"%"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | pageInfo.setRecords(list); | 
|---|
|  |  |  | chargingOrderTimeVO.setList(pageInfo); | 
|---|
|  |  |  | return chargingOrderTimeVO; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public R payRefund(PayOrderRefundDto payOrderQueryDto) { | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //   @Override | 
|---|
|  |  |  | //   public R payRefund(PayOrderRefundDto payOrderQueryDto) { | 
|---|
|  |  |  | //      return null; | 
|---|
|  |  |  | //   } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public ChargingOrderListInfoVO chargingInfo(String uid) { | 
|---|
|  |  |  | TChargingOrder chargingOrder= this.getById(uid); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ChargingOrderListInfoVO chargingOrderListInfoVO = new ChargingOrderListInfoVO(); | 
|---|
|  |  |  | chargingOrderListInfoVO.setElectrovalence(chargingOrder.getElectrovalence()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setServiceCharge(chargingOrder.getServiceCharge()); | 
|---|
|  |  |  | if (chargingOrder.getElectrovalence()!=null && chargingOrder.getServiceCharge()!=null){ | 
|---|
|  |  |  | chargingOrderListInfoVO.setTotal(chargingOrder.getElectrovalence().add(chargingOrder.getServiceCharge())); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | chargingOrderListInfoVO.setTotal(new BigDecimal("0")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (chargingOrderListInfoVO.getTotal().compareTo(new BigDecimal("0"))>0){ | 
|---|
|  |  |  | if (chargingOrder.getCouponDiscountAmount()!=null&& chargingOrder.getVipDiscountAmount()!=null&& chargingOrder.getSharingAmount()!=null&& chargingOrder.getCommissionAmount()!=null){ | 
|---|
|  |  |  | chargingOrderListInfoVO.setRealTotal(chargingOrderListInfoVO.getTotal().subtract(chargingOrder.getCouponDiscountAmount()).subtract(chargingOrder.getVipDiscountAmount()).subtract(chargingOrder.getSharingAmount()).subtract(chargingOrder.getCommissionAmount())); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | chargingOrderListInfoVO.setRealTotal(chargingOrderListInfoVO.getTotal()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | chargingOrderListInfoVO.setRealTotal(new BigDecimal("0")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | chargingOrderListInfoVO.setCode(chargingOrder.getCode()); | 
|---|
|  |  |  | List<Site> data = siteClient.getSiteByIds(Arrays.asList(chargingOrder.getSiteId())).getData(); | 
|---|
|  |  |  | if (!data.isEmpty()){ | 
|---|
|  |  |  | chargingOrderListInfoVO.setSiteName(data.get(0).getName()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setSiteAddress(data.get(0).getAddress()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TChargingGun data1 = chargingGunClient.getChargingGunById(chargingOrder.getChargingGunId()).getData(); | 
|---|
|  |  |  | TChargingPile data2 = chargingPileClient.getChargingPileById(data1.getChargingPileId()).getData(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (data1!=null){ | 
|---|
|  |  |  | chargingOrderListInfoVO.setGunCode(data1.getCode()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setTerminalName(data2.getName()+data1.getName()); | 
|---|
|  |  |  | if (chargingOrder.getChargingGunId()!=null){ | 
|---|
|  |  |  | TChargingGun data1 = chargingGunClient.getChargingGunById(chargingOrder.getChargingGunId()).getData(); | 
|---|
|  |  |  | if (data1!=null){ | 
|---|
|  |  |  | TChargingPile data2 = chargingPileClient.getChargingPileById(data1.getChargingPileId()).getData(); | 
|---|
|  |  |  | if (data2!=null){ | 
|---|
|  |  |  | chargingOrderListInfoVO.setGunCode(data1.getCode()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setTerminalName(data2.getName()+data1.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | chargingOrderListInfoVO.setEndMode(chargingOrder.getEndMode()); | 
|---|
|  |  |  | // todo 周一完善 | 
|---|
|  |  |  | // 获取开始SOC 结束soc | 
|---|
|  |  |  | List<UploadRealTimeMonitoringData> data6 = uploadRealTimeMonitoringDataClient.getDataByOrderCode(chargingOrder.getCode()).getData(); | 
|---|
|  |  |  | if (!data6.isEmpty()){ | 
|---|
|  |  |  | // 第一条数据soc为开始 最后一条数据soc为结束soc | 
|---|
|  |  |  | chargingOrderListInfoVO.setStartSoc(data6.get(0).getSoc().toString()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setEndSoc(data6.get(data6.size()-1).getSoc().toString()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setChargingCapacity(data6.get(data6.size()-1).getCharging_degree()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setChargingSecond(data6.get(data6.size()-1).getCumulative_charging_time()*60+""); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取开始SOC 结束soc | 
|---|
|  |  |  | if (chargingOrder.getCode()!=null){ | 
|---|
|  |  |  | List<UploadRealTimeMonitoringData> data6 = uploadRealTimeMonitoringDataClient.getDataByOrderCode(chargingOrder.getCode()).getData(); | 
|---|
|  |  |  | if (data6!=null){ | 
|---|
|  |  |  | if (!data6.isEmpty()){ | 
|---|
|  |  |  | // 第一条数据soc为开始 最后一条数据soc为结束soc | 
|---|
|  |  |  | chargingOrderListInfoVO.setStartSoc(data6.get(0).getSoc().toString()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setEndSoc(data6.get(data6.size()-1).getSoc().toString()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setChargingCapacity(data6.get(data6.size()-1).getCharging_degree()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setChargingSecond(data6.get(data6.size()-1).getCumulative_charging_time()*60+""); | 
|---|
|  |  |  | SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); | 
|---|
|  |  |  | for (UploadRealTimeMonitoringData uploadRealTimeMonitoringData : data6) { | 
|---|
|  |  |  | uploadRealTimeMonitoringData.setCreateTime(simpleDateFormat.format(uploadRealTimeMonitoringData.getCreate_time())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | chargingOrderListInfoVO.setList(data6); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (chargingOrder.getAppUserCarId()!=null){ | 
|---|
|  |  |  | List<TAppUserCar> data3 = appUserCarClient.getCarByIds(Collections.singletonList(chargingOrder.getAppUserCarId())).getData(); | 
|---|
|  |  |  | if (!data3.isEmpty())chargingOrderListInfoVO.setLicensePlate(data3.get(0).getLicensePlate()); | 
|---|
|  |  |  | if (data3!=null && !data3.isEmpty())chargingOrderListInfoVO.setLicensePlate(data3.get(0).getLicensePlate()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | chargingOrderListInfoVO.setStartTime(chargingOrder.getStartTime()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setEndTime(chargingOrder.getEndTime()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setId(chargingOrder.getId()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setUid(chargingOrder.getId().toString()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setList(data6); | 
|---|
|  |  |  | chargingOrderListInfoVO.setCouponDiscountAmount(chargingOrder.getCouponDiscountAmount()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setVipDiscountAmount(chargingOrder.getVipDiscountAmount()); | 
|---|
|  |  |  | chargingOrderListInfoVO.setSharingAmount(chargingOrder.getSharingAmount()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TAppUser appUser1 = appUserClient.getUserById(appUser.getInviteUserId()).getData(); | 
|---|
|  |  |  | TAppUserIntegralChange appUserIntegralChange = new TAppUserIntegralChange(); | 
|---|
|  |  |  | String code = Math.random() * 1000 + LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyyMMddHHmmssSSS")); | 
|---|
|  |  |  | String code = Double.valueOf(Math.random() * 1000).intValue() + LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyyMMddHHmmssSSS")); | 
|---|
|  |  |  | appUserIntegralChange.setCode(code); | 
|---|
|  |  |  | appUserIntegralChange.setAppUserId(appUser.getInviteUserId()); | 
|---|
|  |  |  | appUserIntegralChange.setChangeType(5); | 
|---|
|  |  |  | 
|---|
|  |  |  | endCharge(orderCode, 0); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> getByDate(List<Long> chargingOrderIds) { | 
|---|
|  |  |  | return this.baseMapper.getByDate(chargingOrderIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> queryPower(List<Integer> siteIds) { | 
|---|
|  |  |  | return this.baseMapper.queryPower(siteIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public Map<String, Object> qureryPowerLevel(List<Integer> siteIds, ChargingStatisticsQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.queryPowerLevel(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> queryOrderCountAndMoneyBySiteIdDate(List<Integer> siteIds) { | 
|---|
|  |  |  | return this.baseMapper.queryOrderCountAndMoneyBySiteIdDate(siteIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> usersDay() { | 
|---|
|  |  |  | return this.baseMapper.usersDay(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> usersByQuery(ChargingStatisticsQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.usersByQuery(statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> getUserTagCount() { | 
|---|
|  |  |  | return this.baseMapper.getUserTagCount(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> getVipCount() { | 
|---|
|  |  |  | return this.baseMapper.getVipCount(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> unitConsumption(ChargingStatisticsQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.unitConsumption(statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> carUserMethod() { | 
|---|
|  |  |  | return this.baseMapper.carUserMethod(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> carUserBrand() { | 
|---|
|  |  |  | return this.baseMapper.carUserBrand(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public Map<String, Object> countLocalCar() { | 
|---|
|  |  |  | return this.baseMapper.countLocalCar(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public Long getAver(List<Integer> siteIds) { | 
|---|
|  |  |  | return this.baseMapper.getAver(siteIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> getLevelEvaluate(List<Integer> siteIds) { | 
|---|
|  |  |  | return this.baseMapper.getLevelEvaluate(siteIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  | chargingOrderRefund.setRefundTime(LocalDateTime.now()); | 
|---|
|  |  |  | chargingOrderRefund.setCode(tChargingOrder.getCode()); | 
|---|
|  |  |  | SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS"); | 
|---|
|  |  |  | chargingOrderRefund.setRefundCode("GDF" + sdf.format(new Date()) + (Math.random() * 1000)); | 
|---|
|  |  |  | chargingOrderRefund.setRefundCode("GDF" + sdf.format(new Date()) + (Double.valueOf(Math.random() * 1000).intValue())); | 
|---|
|  |  |  | chargingOrderRefund.setRefundTitle("后台退款"); | 
|---|
|  |  |  | chargingOrderRefund.setRefundContent("后台退款"); | 
|---|
|  |  |  | chargingOrderRefund.setRefundReason("后台退款"); | 
|---|
|  |  |  | 
|---|
|  |  |  | model.setOut_refund_no(chargingOrderRefund.getRefundCode()); | 
|---|
|  |  |  | model.setTransaction_id(tChargingOrder.getRechargeSerialNumber()); | 
|---|
|  |  |  | model.setReason("取消订单"); | 
|---|
|  |  |  | model.setNotify_url("http://127.0.0.1:9000/order/t-shopping-order/cancelShoppingOrderWxRefund"); | 
|---|
|  |  |  | model.setNotify_url("http://221.182.45.100:9000/order/t-shopping-order/cancelShoppingOrderWxRefund"); | 
|---|
|  |  |  | WxPaymentRefundModel.RefundAmount amount = new WxPaymentRefundModel.RefundAmount(); | 
|---|
|  |  |  | amount.setRefund(payOrderQueryDto.getRefundAmount().multiply(new BigDecimal(100)).intValue()); | 
|---|
|  |  |  | amount.setTotal(tChargingOrder.getPaymentAmount().multiply(new BigDecimal(100)).intValue()); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据车牌号和开始时间查询充电数据 | 
|---|
|  |  |  | * @param query | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public TChargingOrder getChargingOrderByLicensePlate(GetChargingOrderByLicensePlate query) { | 
|---|
|  |  |  | TAppUserCar appUserCar = appUserCarClient.getAppUserCarByLicensePlate(query.getLicensePlate()).getData(); | 
|---|
|  |  |  | if(null == appUserCar){ | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TChargingOrder one = this.getOne(new LambdaQueryWrapper<TChargingOrder>().eq(TChargingOrder::getAppUserCarId, appUserCar.getId()) | 
|---|
|  |  |  | .eq(TChargingOrder::getDelFlag, 0).gt(TChargingOrder::getStartTime, query.getStartTime()) | 
|---|
|  |  |  | .eq(TChargingOrder::getRechargePaymentStatus, 2).ne(TChargingOrder::getStatus, -1)); | 
|---|
|  |  |  | return one; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public TSettlementConfirm settlementAdd(SettlementConfirmAdd dto) { | 
|---|
|  |  |  | List<Site> data = siteClient.getSiteByIds(Arrays.asList(dto.getSiteId())).getData(); | 
|---|
|  |  |  | TSettlementConfirm tSettlementConfirm = new TSettlementConfirm(); | 
|---|
|  |  |  | if (!data.isEmpty()){ | 
|---|
|  |  |  | tSettlementConfirm.setSiteName(data.get(0).getName()); | 
|---|
|  |  |  | tSettlementConfirm.setPartnerId(data.get(0).getPartnerId()); | 
|---|
|  |  |  | if (data.get(0).getPartnerId()!=null){ | 
|---|
|  |  |  | Partner data1 = siteClient.getPartnerR(data.get(0).getPartnerId()).getData(); | 
|---|
|  |  |  | if (data1!=null){ | 
|---|
|  |  |  | tSettlementConfirm.setPartnerName(data1.getName()); | 
|---|
|  |  |  | tSettlementConfirm.setPartnerId(data1.getId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String startTime = dto.getStartTime(); | 
|---|
|  |  |  | String endTime = dto.getEndTime(); | 
|---|
|  |  |  | // 将这两个时间转化为localDateTime | 
|---|
|  |  |  | // 创建 DateTimeFormatter 对象,指定格式 | 
|---|
|  |  |  | DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy年MM月dd日 HH:mm:ss"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 将字符串解析为 LocalDateTime 对象 | 
|---|
|  |  |  | LocalDateTime localDateTime = LocalDateTime.parse(startTime, formatter); | 
|---|
|  |  |  | LocalDateTime localDateTime1 = LocalDateTime.parse(endTime, formatter); | 
|---|
|  |  |  | tSettlementConfirm.setEndTime(localDateTime1); | 
|---|
|  |  |  | tSettlementConfirm.setStartTime(localDateTime); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 根据站点id和开始时间和结束时间和归属日期 查询充电订单列表 | 
|---|
|  |  |  | QueryWrapper<TChargingOrder> eq = new QueryWrapper<TChargingOrder>() | 
|---|
|  |  |  | .eq("site_id", dto.getSiteId()) | 
|---|
|  |  |  | .eq("recharge_payment_status",2); | 
|---|
|  |  |  | switch (dto.getType()){ | 
|---|
|  |  |  | case 1: | 
|---|
|  |  |  | eq.between("start_time", localDateTime, localDateTime1); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 2: | 
|---|
|  |  |  | eq.between("end_time", localDateTime, localDateTime1); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<TChargingOrder> tChargingOrders = this.baseMapper.selectList(eq); | 
|---|
|  |  |  | // 充电电量 度 | 
|---|
|  |  |  | BigDecimal chargingElectronic = new BigDecimal("0"); | 
|---|
|  |  |  | // 三方收费 分佣 | 
|---|
|  |  |  | BigDecimal sharingAmount = new BigDecimal("0"); | 
|---|
|  |  |  | // 三方交易手续费 三方收费*0.6% | 
|---|
|  |  |  | BigDecimal commissionAmount = new BigDecimal("0"); | 
|---|
|  |  |  | // 累计电费 | 
|---|
|  |  |  | BigDecimal electrovalence = new BigDecimal("0"); | 
|---|
|  |  |  | // 累计服务费 | 
|---|
|  |  |  | BigDecimal serviceCharge = new BigDecimal("0"); | 
|---|
|  |  |  | // 订单手续费 订单支付金额*0.6% | 
|---|
|  |  |  | BigDecimal orderCommission = new BigDecimal("0"); | 
|---|
|  |  |  | // 会员抵扣 | 
|---|
|  |  |  | BigDecimal vipDiscount = new BigDecimal("0"); | 
|---|
|  |  |  | // 优惠券抵扣 | 
|---|
|  |  |  | BigDecimal couponDiscount = new BigDecimal("0"); | 
|---|
|  |  |  | // 支付订单金额 需要减去退款金额 | 
|---|
|  |  |  | BigDecimal paymentAmount = new BigDecimal("0"); | 
|---|
|  |  |  | for (TChargingOrder tChargingOrder : tChargingOrders) { | 
|---|
|  |  |  | // 累加充电总度数 | 
|---|
|  |  |  | if (tChargingOrder.getChargingCapacity()!=null){ | 
|---|
|  |  |  | chargingElectronic = chargingElectronic.add(tChargingOrder.getChargingCapacity()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 累加分佣 | 
|---|
|  |  |  | if (tChargingOrder.getSharingAmount()!=null) { | 
|---|
|  |  |  | sharingAmount = sharingAmount.add(tChargingOrder.getSharingAmount()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 累加电费 | 
|---|
|  |  |  | if (tChargingOrder.getElectrovalence()!=null) { | 
|---|
|  |  |  | electrovalence = electrovalence.add(tChargingOrder.getElectrovalence()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 累加服务费 | 
|---|
|  |  |  | if (tChargingOrder.getServiceCharge()!=null){ | 
|---|
|  |  |  | serviceCharge = serviceCharge.add(tChargingOrder.getServiceCharge()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 累加会员折扣 | 
|---|
|  |  |  | if (tChargingOrder.getVipDiscountAmount()!=null){ | 
|---|
|  |  |  | vipDiscount = vipDiscount.add(tChargingOrder.getVipDiscountAmount()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 累加优惠券折扣 | 
|---|
|  |  |  | if (tChargingOrder.getCouponDiscountAmount()!=null){ | 
|---|
|  |  |  | couponDiscount = couponDiscount.add(tChargingOrder.getCouponDiscountAmount()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (tChargingOrder.getRefundStatus()!=null &&tChargingOrder.getRefundStatus() == 2){ | 
|---|
|  |  |  | // 如果成功退款 那么减去退款金额 | 
|---|
|  |  |  | paymentAmount = paymentAmount.add(tChargingOrder.getPaymentAmount().subtract(tChargingOrder.getRefundAmount())); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | if (tChargingOrder.getPaymentAmount()!=null){ | 
|---|
|  |  |  | paymentAmount = paymentAmount.add(tChargingOrder.getPaymentAmount()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 三方交易手续费 三方收费*0.6% | 
|---|
|  |  |  | commissionAmount = sharingAmount.multiply(new BigDecimal("0.006")); | 
|---|
|  |  |  | // 订单手续费 订单支付金额 - 退款金额*0.6% | 
|---|
|  |  |  | orderCommission = paymentAmount.multiply(new BigDecimal("0.006")); | 
|---|
|  |  |  | tSettlementConfirm.setSharingAmount(sharingAmount); | 
|---|
|  |  |  | tSettlementConfirm.setCommissionAmount(commissionAmount); | 
|---|
|  |  |  | tSettlementConfirm.setElectrovalence(electrovalence); | 
|---|
|  |  |  | // 服务费=总服务费-三费收费-交易手续费-交易手续费-服务费会员抵扣-服务费优惠券抵扣 | 
|---|
|  |  |  | tSettlementConfirm.setServiceCharge(serviceCharge.subtract(commissionAmount).subtract(sharingAmount).subtract(orderCommission).subtract(vipDiscount).subtract(couponDiscount)); | 
|---|
|  |  |  | tSettlementConfirm.setOrderCommission(orderCommission); | 
|---|
|  |  |  | tSettlementConfirm.setVipDiscount(vipDiscount); | 
|---|
|  |  |  | tSettlementConfirm.setCouponDiscount(couponDiscount); | 
|---|
|  |  |  | tSettlementConfirm.setSiteId(dto.getSiteId()); | 
|---|
|  |  |  | tSettlementConfirm.setChargingElectronic(chargingElectronic); | 
|---|
|  |  |  | tSettlementConfirm.setIncome(chargingElectronic.add(serviceCharge)); | 
|---|
|  |  |  | tSettlementConfirm.setProfitMoney(new BigDecimal("0")); | 
|---|
|  |  |  | tSettlementConfirm.setNewMoney(new BigDecimal("0")); | 
|---|
|  |  |  | tSettlementConfirm.setNewSettlement(new BigDecimal("0")); | 
|---|
|  |  |  | tSettlementConfirm.setVipDiscount(vipDiscount); | 
|---|
|  |  |  | tSettlementConfirm.setCouponDiscount(couponDiscount); | 
|---|
|  |  |  | tSettlementConfirm.setType(dto.getType()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (dto.getState() == 2){ | 
|---|
|  |  |  | tSettlementConfirm.setSupplyElectronic(dto.getSupplyElectronic()); | 
|---|
|  |  |  | tSettlementConfirm.setVenue(dto.getVenue()); | 
|---|
|  |  |  | tSettlementConfirm.setMetering(dto.getMetering()); | 
|---|
|  |  |  | tSettlementConfirm.setClean(dto.getClean()); | 
|---|
|  |  |  | tSettlementConfirm.setLossElectronic(dto.getMeteringElectronic().subtract(dto.getChargingElectronic())); | 
|---|
|  |  |  | tSettlementConfirm.setMaintain(dto.getMaintain()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | tSettlementConfirm.setMeteringElectronic(dto.getMeteringElectronic()); | 
|---|
|  |  |  | tSettlementConfirm.setProportionPartner(dto.getProportionPartner()); | 
|---|
|  |  |  | tSettlementConfirm.setProportionMoney(dto.getProportionMoney()); | 
|---|
|  |  |  | tSettlementConfirm.setTotalElectronic(dto.getTotalElectronic()); | 
|---|
|  |  |  | tSettlementConfirm.setTotalService(dto.getTotalService()); | 
|---|
|  |  |  | tSettlementConfirm.setRemark(dto.getRemark()); | 
|---|
|  |  |  | tSettlementConfirm.setServicePartner(dto.getServicePartner()); | 
|---|
|  |  |  | tSettlementConfirm.setServiceMoney(dto.getServiceMoney()); | 
|---|
|  |  |  | tSettlementConfirm.setTotalService(dto.getTotalService()); | 
|---|
|  |  |  | tSettlementConfirm.setServiceRemark(dto.getServiceRemark()); | 
|---|
|  |  |  | tSettlementConfirm.setDistribution(dto.getDistribution()); | 
|---|
|  |  |  | tSettlementConfirm.setIncome(dto.getElectrovalence().add(dto.getServiceCharge())); | 
|---|
|  |  |  | tSettlementConfirm.setCost(dto.getVenue().add(dto.getClean()).add(dto.getMaintain())); | 
|---|
|  |  |  | tSettlementConfirmMapper.insert(tSettlementConfirm); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return tSettlementConfirm; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public PageInfo<TSettlementConfirm> settlementList(SettlementListQuery dto) { | 
|---|
|  |  |  | PageInfo<TSettlementConfirm> pageInfo = new PageInfo<>(dto.getPageCurr(),dto.getPageSize()); | 
|---|
|  |  |  | List<TSettlementConfirm> list = tSettlementConfirmMapper.settlementList(pageInfo,dto); | 
|---|
|  |  |  | for (TSettlementConfirm tSettlementConfirm : list) { | 
|---|
|  |  |  | tSettlementConfirm.setUid(tSettlementConfirm.getId().toString()); | 
|---|
|  |  |  | List<Site> data1 = siteClient.getSiteByIds(Arrays.asList(tSettlementConfirm.getSiteId())).getData(); | 
|---|
|  |  |  | if (!data1.isEmpty()){ | 
|---|
|  |  |  | tSettlementConfirm.setSiteName(data1.get(0).getName()); | 
|---|
|  |  |  | Partner data = siteClient.getPartnerR(data1.get(0).getPartnerId()).getData(); | 
|---|
|  |  |  | if (data!=null){ | 
|---|
|  |  |  | tSettlementConfirm.setPartnerName(data.getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String format = tSettlementConfirm.getStartTime().format(DateTimeFormatter.ofPattern("yyyy年MM月dd日HH:mm:ss")); | 
|---|
|  |  |  | String format1 = tSettlementConfirm.getEndTime().format(DateTimeFormatter.ofPattern("yyyy年MM月dd日HH:mm:ss")); | 
|---|
|  |  |  | tSettlementConfirm.setTime(format+"至"+format1); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | pageInfo.setRecords(list); | 
|---|
|  |  |  | return pageInfo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public SettlementTotalVO settlementTotal(String time) { | 
|---|
|  |  |  | SettlementTotalVO res = new SettlementTotalVO(); | 
|---|
|  |  |  | List<TSettlementConfirm> list1 = tSettlementConfirmMapper.settlementTotal(time); | 
|---|
|  |  |  | LocalDateTime parse = LocalDateTime.parse(time, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")); | 
|---|
|  |  |  | // 减少一个月 | 
|---|
|  |  |  | LocalDateTime minus = parse.minusMonths(1); | 
|---|
|  |  |  | List<TSettlementConfirm> list2 = tSettlementConfirmMapper.settlementTotal(time); | 
|---|
|  |  |  | // 合计 | 
|---|
|  |  |  | List<TSettlementConfirm> total = new ArrayList<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | TSettlementConfirm tSettlementConfirm1 = new TSettlementConfirm(); | 
|---|
|  |  |  | BigDecimal meteringElectronic = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal chargingElectronic = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal lossElectronic = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal income = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal venue = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal metering = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal clean = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal maintain = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal cost = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal profitMoney = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal newMoney = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal newSettlement = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal supplyElectronic = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal proportionPartner = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal proportionMoney = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal totalElectronic = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal totalService = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal servicePartner = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal serviceMoney = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal sharingAmount = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal commissionAmount = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal electrovalence = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal serviceCharge = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal orderCommission = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal vipDiscount = new BigDecimal("0"); | 
|---|
|  |  |  | BigDecimal couponDiscount = new BigDecimal("0"); | 
|---|
|  |  |  | //      tSettlementConfirm1.setIncomePercentage(); | 
|---|
|  |  |  | //      tSettlementConfirm1.setTotalPercentage(); | 
|---|
|  |  |  | tSettlementConfirm1.setElectronicRefund(0); | 
|---|
|  |  |  | // 上月成本合计 | 
|---|
|  |  |  | BigDecimal beforeCost= new BigDecimal("0"); | 
|---|
|  |  |  | // 上月利润合计 | 
|---|
|  |  |  | BigDecimal beforeIncome= new BigDecimal("0"); | 
|---|
|  |  |  | for (TSettlementConfirm tSettlementConfirm : list1) { | 
|---|
|  |  |  | List<Site> data1 = siteClient.getSiteByIds(Arrays.asList(tSettlementConfirm.getSiteId())).getData(); | 
|---|
|  |  |  | if (!data1.isEmpty()){ | 
|---|
|  |  |  | tSettlementConfirm.setSiteName(data1.get(0).getName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | meteringElectronic = meteringElectronic.add(tSettlementConfirm.getMeteringElectronic()); | 
|---|
|  |  |  | chargingElectronic = chargingElectronic.add(tSettlementConfirm.getChargingElectronic()); | 
|---|
|  |  |  | lossElectronic = lossElectronic.add(tSettlementConfirm.getLossElectronic()); | 
|---|
|  |  |  | income = income.add(tSettlementConfirm.getIncome()); | 
|---|
|  |  |  | venue = venue.add(tSettlementConfirm.getVenue()); | 
|---|
|  |  |  | metering = metering.add(tSettlementConfirm.getMetering()); | 
|---|
|  |  |  | clean = clean.add(tSettlementConfirm.getClean()); | 
|---|
|  |  |  | maintain = maintain.add(tSettlementConfirm.getMaintain()); | 
|---|
|  |  |  | cost = cost.add(tSettlementConfirm.getCost()); | 
|---|
|  |  |  | profitMoney = profitMoney.add(tSettlementConfirm.getProfitMoney()); | 
|---|
|  |  |  | newMoney = newMoney.add(tSettlementConfirm.getNewMoney()); | 
|---|
|  |  |  | newSettlement = newSettlement.add(tSettlementConfirm.getNewSettlement()); | 
|---|
|  |  |  | supplyElectronic = supplyElectronic.add(tSettlementConfirm.getSupplyElectronic()); | 
|---|
|  |  |  | proportionPartner = proportionPartner.add(tSettlementConfirm.getProportionPartner()); | 
|---|
|  |  |  | proportionMoney = proportionMoney.add(tSettlementConfirm.getProportionMoney()); | 
|---|
|  |  |  | totalElectronic = totalElectronic.add(tSettlementConfirm.getTotalElectronic()); | 
|---|
|  |  |  | totalService = totalService.add(tSettlementConfirm.getTotalService()); | 
|---|
|  |  |  | servicePartner = servicePartner.add(tSettlementConfirm.getServicePartner()); | 
|---|
|  |  |  | serviceMoney = serviceMoney.add(tSettlementConfirm.getServiceMoney()); | 
|---|
|  |  |  | sharingAmount = sharingAmount.add(tSettlementConfirm.getSharingAmount()); | 
|---|
|  |  |  | commissionAmount = commissionAmount.add(tSettlementConfirm.getCommissionAmount()); | 
|---|
|  |  |  | electrovalence = electrovalence.add(tSettlementConfirm.getElectrovalence()); | 
|---|
|  |  |  | serviceCharge = serviceCharge.add(tSettlementConfirm.getServiceCharge()); | 
|---|
|  |  |  | orderCommission = orderCommission.add(tSettlementConfirm.getOrderCommission()); | 
|---|
|  |  |  | vipDiscount = vipDiscount.add(tSettlementConfirm.getVipDiscount()); | 
|---|
|  |  |  | couponDiscount = couponDiscount.add(tSettlementConfirm.getCouponDiscount()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 查询结算确认单开始时间和结束时间的单子 | 
|---|
|  |  |  | QueryWrapper<TChargingOrder> eq = new QueryWrapper<TChargingOrder>() | 
|---|
|  |  |  | .eq("site_id", tSettlementConfirm.getSiteId()) | 
|---|
|  |  |  | .eq("recharge_payment_status",2); | 
|---|
|  |  |  | switch (tSettlementConfirm.getType()){ | 
|---|
|  |  |  | case 1: | 
|---|
|  |  |  | eq.between("start_time", tSettlementConfirm.getStartTime(), tSettlementConfirm.getEndTime()); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 2: | 
|---|
|  |  |  | eq.between("end_time", tSettlementConfirm.getStartTime(), tSettlementConfirm.getEndTime()); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<TChargingOrder> tChargingOrders = this.baseMapper.selectList(eq); | 
|---|
|  |  |  | Map<String,TChargingOrder> map = new HashMap<>(); | 
|---|
|  |  |  | StringBuilder stringBuilder = new StringBuilder(); | 
|---|
|  |  |  | for (TChargingOrder tChargingOrder : tChargingOrders) { | 
|---|
|  |  |  | stringBuilder.append(tChargingOrder.getCode()).append(","); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Long temp = 0L; | 
|---|
|  |  |  | if (StringUtils.hasLength(stringBuilder.toString())){ | 
|---|
|  |  |  | List<UploadRealTimeMonitoringData> data6 = uploadRealTimeMonitoringDataClient.getOrderInfoByCodes(stringBuilder.substring(0,stringBuilder.length()-1)).getData(); | 
|---|
|  |  |  | temp+=data6.stream().mapToLong(UploadRealTimeMonitoringData::getCumulative_charging_time).sum(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<TChargingPile> data = siteClient.getPileListBySiteId(tSettlementConfirm.getSiteId()).getData(); | 
|---|
|  |  |  | // 计算充电桩的功率平均值 | 
|---|
|  |  |  | BigDecimal bigDecimal = new BigDecimal("0"); | 
|---|
|  |  |  | for (TChargingPile datum : data) { | 
|---|
|  |  |  | bigDecimal = bigDecimal.add(datum.getRatedPower()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | tSettlementConfirm.setIncome(tSettlementConfirm.getElectrovalence().add(tSettlementConfirm.getServiceCharge())); | 
|---|
|  |  |  | // todo 计算利用率 该电站充电桩本月利用率: | 
|---|
|  |  |  | //利用率=充电量/(桩数量*功率*时间) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (TSettlementConfirm settlementConfirm : list2) { | 
|---|
|  |  |  | settlementConfirm.setIncome(settlementConfirm.getElectrovalence().add(settlementConfirm.getServiceCharge())); | 
|---|
|  |  |  | if (tSettlementConfirm.getSiteId().equals(settlementConfirm.getSiteId())){ | 
|---|
|  |  |  | // 电站相同比较收入涨幅跌幅 | 
|---|
|  |  |  | BigDecimal subtract = tSettlementConfirm.getIncome().subtract(settlementConfirm.getIncome()).divide(tSettlementConfirm.getIncome()).setScale(2, RoundingMode.HALF_DOWN).multiply(new BigDecimal("100")); | 
|---|
|  |  |  | tSettlementConfirm.setIncomePercentage(subtract+"%"); | 
|---|
|  |  |  | // 比较总利润 收入合计-成本合计 | 
|---|
|  |  |  | BigDecimal subtract1 = tSettlementConfirm.getIncome().subtract(tSettlementConfirm.getCost()); | 
|---|
|  |  |  | BigDecimal subtract2 = settlementConfirm.getIncome().subtract(settlementConfirm.getCost()); | 
|---|
|  |  |  | tSettlementConfirm.setTotalPercentage(subtract1.subtract(subtract2).divide(subtract2).setScale(2, RoundingMode.HALF_DOWN).multiply(new BigDecimal("100"))+"%"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | beforeCost = beforeCost.add(settlementConfirm.getCost()); | 
|---|
|  |  |  | beforeIncome = beforeIncome.add(settlementConfirm.getIncome()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TSettlementConfirm tSettlementConfirm = new TSettlementConfirm(); | 
|---|
|  |  |  | tSettlementConfirm.setMeteringElectronic(meteringElectronic); | 
|---|
|  |  |  | tSettlementConfirm.setChargingElectronic(chargingElectronic); | 
|---|
|  |  |  | tSettlementConfirm.setLossElectronic(lossElectronic); | 
|---|
|  |  |  | tSettlementConfirm.setIncome(income); | 
|---|
|  |  |  | tSettlementConfirm.setVenue(venue); | 
|---|
|  |  |  | tSettlementConfirm.setMetering(metering); | 
|---|
|  |  |  | tSettlementConfirm.setClean(clean); | 
|---|
|  |  |  | tSettlementConfirm.setMaintain(maintain); | 
|---|
|  |  |  | tSettlementConfirm.setCost(cost); | 
|---|
|  |  |  | tSettlementConfirm.setProfitMoney(profitMoney); | 
|---|
|  |  |  | tSettlementConfirm.setNewMoney(newMoney); | 
|---|
|  |  |  | tSettlementConfirm.setNewSettlement(newSettlement); | 
|---|
|  |  |  | tSettlementConfirm.setSupplyElectronic(supplyElectronic); | 
|---|
|  |  |  | tSettlementConfirm.setProportionPartner(proportionPartner); | 
|---|
|  |  |  | tSettlementConfirm.setProportionMoney(proportionMoney); | 
|---|
|  |  |  | tSettlementConfirm.setTotalElectronic(totalElectronic); | 
|---|
|  |  |  | tSettlementConfirm.setTotalService(totalService); | 
|---|
|  |  |  | tSettlementConfirm.setServicePartner(servicePartner); | 
|---|
|  |  |  | tSettlementConfirm.setServiceMoney(serviceMoney); | 
|---|
|  |  |  | tSettlementConfirm.setSharingAmount(sharingAmount); | 
|---|
|  |  |  | tSettlementConfirm.setCommissionAmount(commissionAmount); | 
|---|
|  |  |  | tSettlementConfirm.setElectrovalence(electrovalence); | 
|---|
|  |  |  | tSettlementConfirm.setServiceCharge(serviceCharge); | 
|---|
|  |  |  | tSettlementConfirm.setOrderCommission(orderCommission); | 
|---|
|  |  |  | tSettlementConfirm.setVipDiscount(vipDiscount); | 
|---|
|  |  |  | tSettlementConfirm.setCouponDiscount(couponDiscount); | 
|---|
|  |  |  | // 本月 | 
|---|
|  |  |  | if (beforeIncome.compareTo(new BigDecimal("0")) == 0){ | 
|---|
|  |  |  | tSettlementConfirm.setIncomePercentage(0+"%"); | 
|---|
|  |  |  | tSettlementConfirm.setIncomePercentage(0+"%"); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | BigDecimal subtract = income.subtract(beforeIncome).divide(beforeIncome).setScale(2, RoundingMode.HALF_DOWN).multiply(new BigDecimal("100")); | 
|---|
|  |  |  | tSettlementConfirm.setIncomePercentage(subtract+"%"); | 
|---|
|  |  |  | tSettlementConfirm.setIncomePercentage(subtract+"%"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 比较总利润 收入合计-成本合计 | 
|---|
|  |  |  | BigDecimal subtract1 = income.subtract(cost); | 
|---|
|  |  |  | BigDecimal subtract2 = beforeIncome.subtract(beforeCost); | 
|---|
|  |  |  | if (subtract2.compareTo(new BigDecimal("0")) == 0){ | 
|---|
|  |  |  | tSettlementConfirm.setTotalPercentage(0+"%"); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | tSettlementConfirm.setTotalPercentage(subtract1.subtract(subtract2).divide(subtract2).setScale(2, RoundingMode.HALF_DOWN).multiply(new BigDecimal("100"))+"%"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tSettlementConfirm.setElectronicRefund(0); | 
|---|
|  |  |  | // 查询上次汇报数据 进行比对涨幅跌幅 | 
|---|
|  |  |  | total.add(tSettlementConfirm); | 
|---|
|  |  |  | res.setList1(list1); | 
|---|
|  |  |  | res.setList2(total); | 
|---|
|  |  |  | return res; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> countBySource(List<Integer> siteIds) { | 
|---|
|  |  |  | return this.baseMapper.countBySource(siteIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> equipmentUserType1(List<Integer> siteIds, ChargingStatisticsQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.equipmentUserType1(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> equipmentUserType2(List<Integer> siteIds, ChargingStatisticsQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.equipmentUserType2(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> equipmentMapbroke1(List<Integer> siteIds, ChargingStatisticsQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.equipmentMapbroke1(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> equipmentMapbroke2(List<Integer> siteIds, ChargingStatisticsQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.equipmentMapbroke2(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> equipmentMapOut1(List<Integer> siteIds, ChargingStatisticsQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.equipmentMapOut1(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> equipmentMapOut2(List<Integer> siteIds, ChargingStatisticsQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.equipmentMapOut2(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> needElec(List<Integer> siteIds, ChargingStatisticsQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.needElec(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> getHourType(List<Integer> siteIds, ChargingDetailQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.getHourType(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> getDateType(List<Integer> siteIds, ChargingDetailQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.getDateType(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> getMonthType(List<Integer> siteIds, ChargingDetailQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.getMonthType(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> getchargingCapacity(List<Integer> siteIds, ChargingDetailQueryDto statisticsQueryDto) { | 
|---|
|  |  |  | return this.baseMapper.getchargingCapacity(siteIds,statisticsQueryDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<Map<String, Object>> countAllUserData() { | 
|---|
|  |  |  | return this.baseMapper.countAllUserData(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public static void main(String[] args) { | 
|---|
|  |  |  | //      String format = LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy年MM月dd日HH:mm:ss")); | 
|---|
|  |  |  | //      String format1 = LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy年MM月dd日HH:mm:ss")); | 
|---|
|  |  |  | //      System.err.println(format+"至"+format1); | 
|---|
|  |  |  | //      LocalDateTime parse = LocalDateTime.parse("2024-01-12 00:00:00", DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")); | 
|---|
|  |  |  | //      System.err.println(parse.format(DateTimeFormatter.ofPattern("yyyy-dd"))); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|