From 562c82e54b9fc9ac9a640f07b9d03355226ae3f4 Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期五, 20 五月 2022 18:06:13 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightEnergyDataService.java |   84 ++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 84 insertions(+), 0 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightEnergyDataService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightEnergyDataService.java
index c3fcfa4..1e16d26 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightEnergyDataService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightEnergyDataService.java
@@ -1,10 +1,23 @@
 package com.sandu.ximon.admin.service;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.sandu.common.service.impl.BaseServiceImpl;
+import com.sandu.common.util.SpringContextHolder;
+import com.sandu.ximon.admin.security.SecurityUtils;
 import com.sandu.ximon.dao.domain.LightEnergyData;
+import com.sandu.ximon.dao.domain.LightTaskPoleRelation;
 import com.sandu.ximon.dao.mapper.LightEnergyDataMapper;
 import lombok.AllArgsConstructor;
 import org.springframework.stereotype.Service;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.util.ArrayList;
+import java.util.LinkedHashMap;
+import java.util.List;
+import java.util.Map;
 
 /**
  * @author LHN
@@ -15,4 +28,75 @@
 public class LightEnergyDataService extends BaseServiceImpl<LightEnergyDataMapper, LightEnergyData> {
 
 
+    public List energy(int flag) {
+        Long userId = null;
+        if (SecurityUtils.getClientId() != null) {
+            userId = SecurityUtils.getUserId();
+        }
+        LambdaQueryWrapper<LightEnergyData> lightEnergyDataLambdaQueryWrapper = Wrappers.lambdaQuery(LightEnergyData.class);
+        if (userId != null) {
+            Long finalUserId = userId;
+            lightEnergyDataLambdaQueryWrapper.eq(LightEnergyData::getUserId, finalUserId).or(w -> {
+                w.eq(LightEnergyData::getClientId, finalUserId);
+            });
+        }
+
+        LocalDateTime now = LocalDateTime.now();
+        List<Map> listResult = new ArrayList<>();
+
+        for (int i = 1; i < 8; i++) {
+
+            String format = now.minusDays(i).format(DateTimeFormatter.ofPattern("yyyy-MM-dd"));
+
+
+            lightEnergyDataLambdaQueryWrapper.eq(LightEnergyData::getYtdTime, format);
+            List<LightEnergyData> list = list(lightEnergyDataLambdaQueryWrapper);
+
+            BigDecimal[] energyAll = {new BigDecimal(0.00)};
+            BigDecimal[] energySavingAll = {new BigDecimal(0.00)};
+            list.forEach(
+                    bean -> {
+                        int lightSize = SpringContextHolder.getBean(LightTaskPoleRelationService.class)
+                                .list(Wrappers.lambdaQuery(LightTaskPoleRelation.class)
+                                        .eq(LightTaskPoleRelation::getTaskId, bean.getTaskId()).eq(LightTaskPoleRelation::getIssueStatus, 0)).size();
+
+                        BigDecimal energy;
+                        BigDecimal energySaving;
+                        if (lightSize == 0) {
+                            energy = new BigDecimal(0);
+                            energySaving = new BigDecimal(1);
+                        } else {
+                            if (bean.getEnergy().equals(0.00)) {
+                                energy = new BigDecimal(0);
+                                energySaving = new BigDecimal(1);
+                            } else if (bean.getEnergySaving().equals(0.00)) {
+                                energy = new BigDecimal(0);
+                                energySaving = new BigDecimal(1);
+                            } else {
+
+                                energy = bean.getEnergy().multiply(new BigDecimal(lightSize)).setScale(2, BigDecimal.ROUND_HALF_UP);
+                                energySaving = bean.getEnergySaving().divide(new BigDecimal(lightSize)).setScale(2, BigDecimal.ROUND_HALF_UP);
+                            }
+
+                        }
+
+                        energyAll[0] = energyAll[0].add(energy);
+                        energySavingAll[0] = energySavingAll[0].add(energySaving);
+                    });
+            Map map = new LinkedHashMap();
+
+            //0涓鸿兘鑰楋紝1涓鸿妭鑳界巼
+            if (flag == 0) {
+                map.put("time", format);
+                map.put("value", energyAll[0]);
+                listResult.add(map);
+            } else {
+                map.put("time", format);
+                map.put("value", energySavingAll[0]);
+                listResult.add(map);
+            }
+
+        }
+        return listResult;
+    }
 }

--
Gitblit v1.9.3