From edbb2fe4eabbb7c526fb2f7313bead37d38928e2 Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期一, 15 八月 2022 14:57:16 +0800
Subject: [PATCH] 充电桩上电请求

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/C3mChargingChargeService.java |  156 ++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 140 insertions(+), 16 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 785a3f7..88c1060 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,11 +1,21 @@
 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.ximon.admin.param.C3mChargingChargeParam;
+import com.sandu.ximon.admin.utils.StoreOperationRecordsUtils;
 import com.sandu.ximon.dao.domain.C3mChargingCharge;
+import com.sandu.ximon.dao.domain.PoleBinding;
 import com.sandu.ximon.dao.mapper.C3mChargingChargeMapper;
+import com.sandu.ximon.dao.mapper.C3mChargingMapper;
 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;
@@ -21,15 +31,17 @@
 @AllArgsConstructor
 public class C3mChargingChargeService extends BaseServiceImpl<C3mChargingChargeMapper, C3mChargingCharge> {
     private final C3mChargingChargeMapper c3mChargingChargeMapper;
+    private final PoleBindingService bindingService;
+    private final C3mChargingMapper chargingMapper;
 
     /**
      * 淇敼璐圭巼
+     *
      * @param chargeEntities
-     * @param userId
-     * @param username
+     * @param
      * @return
      */
-    public boolean updateCharge(List<C3mChargingCharge> chargeEntities, Long userId, String username) {
+    public boolean updateCharge(List<C3mChargingCharge> chargeEntities) {
         //  鍒犻櫎鍘熸湰瀛樺湪鐨勮垂鐜�
         c3mChargingChargeMapper.deleteCharge(chargeEntities.get(0).getC3Id());
         Long timestamp = new Date().getTime();
@@ -38,16 +50,49 @@
             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;
     }
 
+    /**
+     * 鎻掑叆璐圭巼
+     *
+     * @param c3
+     * @return
+     */
+    public boolean initCharge(C3mChargingChargeParam c3) {
+        C3mChargingCharge charge = new C3mChargingCharge();
+        BeanUtil.copyProperties(c3, charge);
+        charge.setTimestamp(new Date().getTime());
+//        c3mChargingChargeMapper.insertCharge(charge);
+
+
+        return save(charge);
+    }
+
+    /**
+     * 鑷姩鎻掑叆榛樿璐圭巼
+     *
+     * @param c3Id
+     */
     public void initCharge(Integer c3Id) {
         List<C3mChargingCharge> chargeList = getChargeByC3Id(c3Id);
-        if(chargeList.size() == 0) {
+        if (chargeList.size() == 0) {
             //  涓嶅瓨鍦ㄨ垂鐜囨椂锛岀敓鎴愬崟涓垂鐜囧苟鎻掑叆鏁版嵁搴�
-            C3mChargingCharge c3mChargeEntity = C3mChargingCharge.getInitInstance(c3Id);
+            C3mChargingCharge c3mChargeEntity = new C3mChargingCharge();/*C3mChargingCharge.getInitInstance(c3Id);*/
+            c3mChargeEntity.setC3Id(c3Id);
+            c3mChargeEntity.setHour(0);
+            c3mChargeEntity.setMin(0);
+            c3mChargeEntity.setCharge(8.8);
+            c3mChargeEntity.setTimestamp(new Date().getTime());
             c3mChargingChargeMapper.insertCharge(c3mChargeEntity);
         }
     }
@@ -57,7 +102,7 @@
         //  鏌ユ壘鏁版嵁搴撴墍鏈夎垂鐜�
         List<C3mChargingCharge> list = c3mChargingChargeMapper.getChargeByC3Id(c3Id);
         //  鍒ゆ柇list涓哄崟鏉$洿鎺ヨ繑鍥�
-        if(list.size()<2){
+        if (list.size() < 2) {
             return list;
         }
         //  灏嗘椂鍒嗚繘琛屾帓搴�
@@ -65,7 +110,7 @@
             @Override
             public int compare(C3mChargingCharge o1, C3mChargingCharge o2) {
                 int i = o2.getHour().compareTo(o1.getHour());
-                if(i == 0){
+                if (i == 0) {
                     return o2.getMin().compareTo(o1.getMin());
                 }
                 return i;
@@ -79,22 +124,22 @@
         //  list缈昏浆
         Collections.reverse(list);
         //  鏃堕棿娈靛瓧绗︽嫾鎺�
-        for(int i=1;i<list.size();i++){
+        for (int i = 1; i < list.size(); i++) {
             C3mChargingCharge pre = list.get(i - 1);
             C3mChargingCharge now = list.get(i);
             pre.setStrTime(
-                    pre.getHour()+"鐐�"+pre.getMin()+"鍒� 鍒� "+
-                            now.getHour()+"鐐�"+now.getMin()+"鍒�"
+                    pre.getHour() + "鐐�" + pre.getMin() + "鍒� 鍒� " +
+                            now.getHour() + "鐐�" + now.getMin() + "鍒�"
             );
-            if(i==list.size()-1){
+            if (i == list.size() - 1) {
                 pre = now;
                 now = list.get(0);
-                if(now.getHour() < pre.getHour()){
+                if (now.getHour() < pre.getHour()) {
                     pre.setStrTime(
                             pre.getHour() + "鐐�" + pre.getMin() + "鍒� 鍒� " +
-                                    "闅旀棩"+now.getHour() + "鐐�" + now.getMin() + "鍒�"
+                                    "闅旀棩" + now.getHour() + "鐐�" + now.getMin() + "鍒�"
                     );
-                }else {
+                } else {
                     pre.setStrTime(
                             pre.getHour() + "鐐�" + pre.getMin() + "鍒� 鍒� " +
                                     now.getHour() + "鐐�" + now.getMin() + "鍒�"
@@ -106,4 +151,83 @@
 
     }
 
+    /**
+     * 鏍规嵁鐏潌id鏌ユ壘璐圭巼
+     *
+     * @param poleId
+     * @return
+     */
+    public List<C3mChargingCharge> getChargeByPoleId(Long poleId) {
+        PoleBinding one = bindingService.getOne(Wrappers.lambdaQuery(PoleBinding.class).eq(PoleBinding::getDeviceType, 2).eq(PoleBinding::getPoleId, poleId));
+        if (one == null) {
+            throw new BusinessException("鏈壘鍒扮粦瀹氬叧绯�");
+        }
+        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));
+        //鑾峰彇褰撳墠鏃堕棿
+        LocalTime localTime = LocalTime.now();
+        //閬嶅巻璐圭巼闆嗗悎  鍒ゆ柇褰撳墠鏃堕棿鏄惁鍦ㄨ垂鐜囨椂闂存鍐�
+        LocalTime startTime;
+        LocalTime endTime;
+        //榛樿璐圭巼
+        Double charge = 8.8;
+        if (list.size() > 1) {
+            //璐圭巼鏉℃暟澶т簬1鏃讹紝閬嶅巻璐圭巼闆嗗悎  鑾峰彇褰撳墠鏃堕棿娈电殑璐圭巼
+            for (int i = 0; i < list.size(); i++) {
+                //鑾峰彇璐圭巼鏃堕棿娈�  杞寲涓篖ocalTime
+                startTime = LocalTime.of(list.get(i).getHour(), list.get(i).getMin());
+                endTime = LocalTime.of(list.get(i + 1).getHour(), list.get(i + 1).getMin());
+                if (i == list.size()) {
+                    startTime = LocalTime.of(list.get(i).getHour(), list.get(i).getMin());
+                    endTime = LocalTime.of(list.get(0).getHour(), list.get(0).getMin());
+                }
+                //鍒ゆ柇褰撳墠鏃堕棿鏄惁鍦ㄨ垂鐜囨椂闂存鍐�
+                if (localTime.isAfter(startTime) && localTime.isBefore(endTime)) {
+                    //鑾峰彇璐圭巼
+                    charge = list.get(i).getCharge();
+                }
+
+            }
+        } else if (list.size() == 1) {
+            //鍙湁涓�鏉¤垂鐜囨椂锛岀洿鎺ヨ幏鍙栬垂鐜�
+            charge = list.get(0).getCharge();
+        } else {
+            //鍏朵粬璐圭巼鏃讹紝鑾峰彇榛樿璐圭巼
+            charge = 8.8;
+        }
+
+        //charge杞寲涓築igDecimal
+        //double鐩存帴浣跨敤 new BigDecimal()鏃朵細鍑虹幇绮惧害闂锛屾墍浠ラ渶瑕佷娇鐢˙igDecimal.valueOf()鏂规硶  骞惰缃簿搴︿负2浣嶅皬鏁�
+        BigDecimal chargeDecimal = BigDecimal.valueOf(charge).setScale(2, BigDecimal.ROUND_HALF_UP);
+
+        return chargeDecimal;
+    }
 }

--
Gitblit v1.9.3