From af4cd17b9851e940dd1dc8a43b3b21fbdd452f76 Mon Sep 17 00:00:00 2001
From: liuhaonan <31457034@qq.com>
Date: 星期五, 23 九月 2022 17:09:54 +0800
Subject: [PATCH] changes
---
ximon-admin/src/main/java/com/sandu/ximon/admin/service/C3mChargingChargeService.java | 188 ++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 171 insertions(+), 17 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..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,15 +1,28 @@
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;
+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;
import java.util.List;
+import java.util.stream.Collectors;
/**
* @Author liuhaonan
@@ -21,33 +34,83 @@
@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());
+ 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;
}
+ /**
+ * 鎻掑叆璐圭巼
+ *
+ * @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 +120,7 @@
// 鏌ユ壘鏁版嵁搴撴墍鏈夎垂鐜�
List<C3mChargingCharge> list = c3mChargingChargeMapper.getChargeByC3Id(c3Id);
// 鍒ゆ柇list涓哄崟鏉$洿鎺ヨ繑鍥�
- if(list.size()<2){
+ if (list.size() < 2) {
return list;
}
// 灏嗘椂鍒嗚繘琛屾帓搴�
@@ -65,7 +128,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 +142,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 +169,95 @@
}
+ /**
+ * 鏍规嵁鐏潌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));
+
+ //鍙湁涓�鏉¤垂鐜囨椂锛岀洿鎺ヨ繑鍥�
+ 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