From a4f4cadc93ade3af83450acaa32b355cc66048f5 Mon Sep 17 00:00:00 2001
From: liujie <1793218484@qq.com>
Date: 星期一, 21 七月 2025 13:57:59 +0800
Subject: [PATCH] 大屏接口替换

---
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/LargeScreenController.java |   75 +++++++++++++++++++++++++++++++++++++
 1 files changed, 75 insertions(+), 0 deletions(-)

diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/LargeScreenController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/LargeScreenController.java
new file mode 100644
index 0000000..8a10c24
--- /dev/null
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/LargeScreenController.java
@@ -0,0 +1,75 @@
+package com.ruoyi.order.controller;
+
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.web.domain.BasePojo;
+import com.ruoyi.integration.api.model.UploadRealTimeMonitoringData;
+import com.ruoyi.order.api.model.TChargingOrder;
+import com.ruoyi.order.service.TChargingOrderService;
+import com.ruoyi.order.vo.LargeChargingPowerVo;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import lombok.SneakyThrows;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+import javax.annotation.Resource;
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.text.SimpleDateFormat;
+import java.time.LocalDate;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.List;
+import java.util.stream.Collectors;
+
+@Api(tags = "大屏")
+@RestController
+@RequestMapping("/large-screen")
+public class LargeScreenController {
+
+    private SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+
+    @Resource
+    private TChargingOrderService chargingOrderService;
+
+
+    @SneakyThrows
+    @ApiOperation(tags = {"大屏-停车场充电功率曲线图"},value = "停车场充电功率曲线图")
+    @GetMapping("/getChargingPower")
+    public R<List<LargeChargingPowerVo>> getChargingPower(){
+        String sevenDayAgo = LocalDate.now().minusDays(7) + " 00:00:00";
+        String oneDayAgo = LocalDate.now().minusDays(1) + " 23:59:59";
+        Date oneDayAgoTime = format.parse(oneDayAgo);
+        Date sevenDayAgoTime = format.parse(sevenDayAgo);
+        ArrayList<LargeChargingPowerVo> largeChargingPowerVos = new ArrayList<>();
+        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
+        List<TChargingOrder> list1 = chargingOrderService.list(new LambdaQueryWrapper<TChargingOrder>().between(BasePojo::getCreateTime, sevenDayAgoTime, oneDayAgoTime).eq(BasePojo::getDelFlag, 0));
+
+        for (int count = 7; count > 0; count--) {
+            LargeChargingPowerVo largeChargingPowerVo = new LargeChargingPowerVo();
+            String time = LocalDate.now().minusDays(count).toString();
+
+            List<TChargingOrder> list = list1.stream().filter(e ->e.getCreateTime().toString().contains(time)).collect(Collectors.toList());
+            if(!list.isEmpty()){
+                System.out.println(list);
+                list.stream().forEach(e -> {
+                    if(e.getChargingPower()==null){
+                        e.setChargingPower(BigDecimal.ZERO);
+                    }
+                });
+                BigDecimal powerAverage = list.stream().map(TChargingOrder::getChargingPower).reduce(BigDecimal.ZERO, BigDecimal::add).divide(BigDecimal.valueOf(list.size()), 0, RoundingMode.HALF_UP);
+                largeChargingPowerVo.setPower(powerAverage);
+            }
+            largeChargingPowerVo.setTime(time);
+            largeChargingPowerVos.add(largeChargingPowerVo);
+        }
+
+        return R.ok(largeChargingPowerVos);
+    }
+
+
+
+}

--
Gitblit v1.7.1