From dda268997ca8f8a364f7c19b45d7a43a50a98efe Mon Sep 17 00:00:00 2001
From: liuhaonan <31457034@qq.com>
Date: 星期二, 25 十月 2022 18:00:11 +0800
Subject: [PATCH] changes

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/C3mChargingChargeService.java |  115 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 112 insertions(+), 3 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/C3mChargingChargeService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/C3mChargingChargeService.java
index 229f7b3..2a8b82c 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/C3mChargingChargeService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/C3mChargingChargeService.java
@@ -1,10 +1,14 @@
 package com.sandu.ximon.admin.service;
 
 import cn.hutool.core.bean.BeanUtil;
+import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.sandu.common.execption.BusinessException;
 import com.sandu.common.service.impl.BaseServiceImpl;
+import com.sandu.common.util.SpringContextHolder;
 import com.sandu.ximon.admin.param.C3mChargingChargeParam;
+import com.sandu.ximon.admin.utils.StoreOperationRecordsUtils;
+import com.sandu.ximon.dao.domain.C3mCharging;
 import com.sandu.ximon.dao.domain.C3mChargingCharge;
 import com.sandu.ximon.dao.domain.PoleBinding;
 import com.sandu.ximon.dao.mapper.C3mChargingChargeMapper;
@@ -12,10 +16,13 @@
 import lombok.AllArgsConstructor;
 import org.springframework.stereotype.Service;
 
+import java.math.BigDecimal;
+import java.time.LocalTime;
 import java.util.Collections;
 import java.util.Comparator;
 import java.util.Date;
 import java.util.List;
+import java.util.stream.Collectors;
 
 /**
  * @Author liuhaonan
@@ -39,15 +46,37 @@
      */
     public boolean updateCharge(List<C3mChargingCharge> chargeEntities) {
         //  鍒犻櫎鍘熸湰瀛樺湪鐨勮垂鐜�
-        c3mChargingChargeMapper.deleteCharge(chargeEntities.get(0).getC3Id());
+        Integer c3Id = chargeEntities.get(0).getC3Id();
+
+        if (c3Id == null) {
+            throw new BusinessException("c3Id涓嶈兘涓虹┖");
+        }
+        c3mChargingChargeMapper.deleteCharge(c3Id);
         Long timestamp = new Date().getTime();
+
+        C3ChargingService chargingService = SpringContextHolder.getBean(C3ChargingService.class);
+        C3mCharging byId = chargingService.getById(c3Id);
+        if (byId == null) {
+            throw new BusinessException("c3Id涓嶅瓨鍦�");
+        }
+        String s = chargingService.setRate(byId.getC3Mac(), chargeEntities,false);
+        if (!"鎿嶄綔鎴愬姛".equals(s)) {
+            throw new BusinessException("璁剧疆澶辫触,澶辫触鍘熷洜: " + s);
+        }
         //  灏嗚垂鐜囨坊鍔犺嚦鏁版嵁搴�
         for (C3mChargingCharge c3m : chargeEntities) {
             c3m.setTimestamp(timestamp);
             save(c3m);
         }
-//        LogService.getBean().log(userId,username,"淇敼C3m璐圭巼",null,
-//                "{ "+ JSON.toJSONString(chargeEntities)+" }");
+
+        /**
+         * c3鍏呯數妗╄垂鐜囨洿鏀� 鏃ュ織璁板綍寮�濮�
+         */
+        String content = "c3鍏呯數妗╄垂鐜囨洿鏀癸細" + JSON.toJSONString(chargeEntities);
+        StoreOperationRecordsUtils.storeOperationData(null, null, "c3鍏呯數妗╄垂鐜囨洿鏀�", content);
+        /**
+         * c3鍏呯數妗╄垂鐜囨洿鏀� 鏃ュ織璁板綍缁撴潫
+         */
         return true;
     }
 
@@ -62,6 +91,8 @@
         BeanUtil.copyProperties(c3, charge);
         charge.setTimestamp(new Date().getTime());
 //        c3mChargingChargeMapper.insertCharge(charge);
+
+
         return save(charge);
     }
 
@@ -140,6 +171,7 @@
 
     /**
      * 鏍规嵁鐏潌id鏌ユ壘璐圭巼
+     *
      * @param poleId
      * @return
      */
@@ -151,4 +183,81 @@
         Long c3Id = chargingMapper.getAllByC3Mac(one.getDeviceCode()).getC3Id();
         return getChargeByC3Id(c3Id.intValue());
     }
+
+    public boolean deleteC3mCharging(Integer c3mId) {
+        return c3mChargingChargeMapper.deleteCharge(c3mId);
+    }
+
+    /**
+     * 鏍规嵁c3Id鏌ユ壘璐圭巼  骞惰绠楄姳璐�
+     *
+     * @param c3Id
+     * @return
+     */
+    public BigDecimal getCostByC3id(Long c3Id, Integer power) {
+        BigDecimal chargeDecimal = getchargeDecimalByC3id(c3Id);
+        BigDecimal powerDecimal = new BigDecimal(power);
+        BigDecimal result = chargeDecimal.multiply(powerDecimal);
+        return result;
+    }
+
+
+    /**
+     * 鏍规嵁c3Id鏌ユ壘璐圭巼
+     *
+     * @param c3Id
+     * @return
+     */
+    public BigDecimal getchargeDecimalByC3id(Long c3Id) {
+        List<C3mChargingCharge> list = list(Wrappers.lambdaQuery(C3mChargingCharge.class).eq(C3mChargingCharge::getC3Id, c3Id));
+
+        //鍙湁涓�鏉¤垂鐜囨椂锛岀洿鎺ヨ繑鍥�
+        if (list.size() == 1) {
+            return BigDecimal.valueOf(list.get(0).getCharge());
+        } else {//璐圭巼澶т簬涓�鏉℃椂鍊欙紝璁$畻璐圭巼
+
+            //鎺掑簭璐圭巼(鏍规嵁鏃堕棿鎺掑簭)
+            List<C3mChargingCharge> collect =
+                    list.stream().sorted(Comparator.comparing(C3mChargingCharge::getHour).thenComparing(C3mChargingCharge::getMin)).collect(Collectors.toList());
+            System.out.println("-----    " + collect);
+
+            //鑾峰彇褰撳墠鏃堕棿
+            LocalTime localTime = LocalTime.now();
+//            LocalTime localTime = LocalTime.of(18, 00);
+            System.out.println("time"+localTime);
+
+            C3mChargingCharge temp1 = collect.get(collect.size() - 1);
+            if (localTime.isAfter(LocalTime.of(temp1.getHour(), temp1.getMin()))) {
+                return BigDecimal.valueOf(temp1.getCharge());
+            }
+
+            C3mChargingCharge temp2= collect.get(0);
+            if (localTime.isBefore(LocalTime.of(temp2.getHour(), temp2.getMin()))) {
+                return BigDecimal.valueOf(temp1.getCharge());
+            }
+
+
+            for (int i = 0; i < collect.size(); i++) {
+                int x = i;
+                int y = i + 1;
+                if (y == collect.size()) {
+                    y = 0;
+                }
+                LocalTime startTime = LocalTime.of(collect.get(x).getHour(), collect.get(x).getMin());
+                LocalTime endTime = LocalTime.of(collect.get(y).getHour(), collect.get(y).getMin());
+
+                //褰撳墠鏃堕棿绛変簬璐圭巼鏃堕棿娈电殑寮�濮嬫椂闂�
+                if (localTime.equals(startTime)) {
+                    return BigDecimal.valueOf(collect.get(x).getCharge());
+                }
+
+                //褰撳墠鏃堕棿鍦ㄨ垂鐜囨椂闂存鍐�
+                if (localTime.isAfter(startTime) && localTime.isBefore(endTime)) {
+                    return BigDecimal.valueOf(collect.get(x).getCharge());
+                }
+            }
+        }
+
+        return BigDecimal.valueOf(8.8);
+    }
 }

--
Gitblit v1.9.3