Commit 37c3e824 authored by maoying's avatar maoying

Merge branch 'dev_bitmap' of 172.16.10.76:moa/amos-boot-biz into dev_bitmap

parents 25ff30a2 39b15f6e
...@@ -54,4 +54,10 @@ public class EquipmentStateVo { ...@@ -54,4 +54,10 @@ public class EquipmentStateVo {
*/ */
private List<SpeIndexVo> speindexList; private List<SpeIndexVo> speindexList;
/**
* 紧急程度颜色
*/
private String color;
} }
...@@ -6,10 +6,13 @@ import com.yeejoin.equipmanage.common.enums.EquipmentRiskTypeEnum; ...@@ -6,10 +6,13 @@ import com.yeejoin.equipmanage.common.enums.EquipmentRiskTypeEnum;
import com.yeejoin.equipmanage.common.enums.EquipmentStateEnum; import com.yeejoin.equipmanage.common.enums.EquipmentStateEnum;
import com.yeejoin.equipmanage.common.enums.TrueOrFalseEnum; import com.yeejoin.equipmanage.common.enums.TrueOrFalseEnum;
import com.yeejoin.equipmanage.common.vo.AlarmDataVO; import com.yeejoin.equipmanage.common.vo.AlarmDataVO;
import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.util.ObjectUtils; import org.springframework.util.ObjectUtils;
import org.typroject.tyboot.core.foundation.utils.ValidationUtil;
import javax.validation.Validation;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Comparator; import java.util.Comparator;
import java.util.List; import java.util.List;
...@@ -264,15 +267,10 @@ public class EquipmentStateUtil { ...@@ -264,15 +267,10 @@ public class EquipmentStateUtil {
} }
public static String judgeEquipState(EquipmentSpecificIndex index) { public static String judgeEquipState(EquipmentSpecificIndex index) {
String status = EquipmentStateEnum.ZC.getStatus(); if (TrueOrFalseEnum.real.value.toUpperCase().equals(String.valueOf(index.getValue()).toUpperCase())) {
String keyValue = String.valueOf(index.getValue()); return StringUtils.isNotEmpty(index.getEmergencyLevelColor()) ? index.getEmergencyLevelColor() : "#49AA19";
for (EquipmentRiskTypeEnum enums : EquipmentRiskTypeEnum.values()) { } else {
if (enums.getCode().equals(index.getTypeCode()) && TrueOrFalseEnum.real.value.equals(keyValue)) { return "#49AA19";
status = enums.getStateCode();
break;
}
} }
log.info("此装备的状态为: " + status + "(屏蔽-5, 火灾告警-4, 故障-3, 正常-2, 挂起-1)");
return status;
} }
} }
...@@ -27,4 +27,8 @@ public class SpeIndexVo { ...@@ -27,4 +27,8 @@ public class SpeIndexVo {
private String emergencyLevel = ""; private String emergencyLevel = "";
private String emergencyLevelDescribe = ""; private String emergencyLevelDescribe = "";
private String indexValue;
private String indexName;
} }
...@@ -542,6 +542,7 @@ public class FireFightingSystemServiceImpl extends ServiceImpl<FireFightingSyste ...@@ -542,6 +542,7 @@ public class FireFightingSystemServiceImpl extends ServiceImpl<FireFightingSyste
SpeIndexVo latestVo = statusList.get(0); SpeIndexVo latestVo = statusList.get(0);
BeanUtils.copyProperties(latestVo, spe); BeanUtils.copyProperties(latestVo, spe);
spe.setName("当前状态"); spe.setName("当前状态");
spe.setValue(getStatus(statusList));
statusList.clear(); statusList.clear();
statusList.add(spe); statusList.add(spe);
statusList.addAll(newList); statusList.addAll(newList);
...@@ -556,17 +557,8 @@ public class FireFightingSystemServiceImpl extends ServiceImpl<FireFightingSyste ...@@ -556,17 +557,8 @@ public class FireFightingSystemServiceImpl extends ServiceImpl<FireFightingSyste
*/ */
private String getStatus(List<SpeIndexVo> statusList) { private String getStatus(List<SpeIndexVo> statusList) {
SpeIndexVo indexVo = statusList.get(0); SpeIndexVo indexVo = statusList.get(0);
if (EquipmentRiskTypeEnum.HZGJ.getCode().equals(indexVo.getTypeCode()) && TrueOrFalseEnum.real.value.equals(indexVo.getValue())) { if (StringUtil.isNotEmpty(indexVo.getIndexValue()) && TrueOrFalseEnum.real.value.toUpperCase().equals(indexVo.getIndexValue().toUpperCase())) {
return "报警"; return indexVo.getIndexName();
}
if (EquipmentRiskTypeEnum.GZ.getCode().equals(indexVo.getTypeCode()) && TrueOrFalseEnum.real.value.equals(indexVo.getValue())) {
return "故障";
}
if (EquipmentRiskTypeEnum.PB.getCode().equals(indexVo.getTypeCode()) && TrueOrFalseEnum.real.value.equals(indexVo.getValue())) {
return "屏蔽";
}
if (EquipmentRiskTypeEnum.YXZT.getCode().equals(indexVo.getTypeCode()) && TrueOrFalseEnum.fake.value.equals(indexVo.getValue())) {
return "停运";
} }
return "运行"; return "运行";
} }
......
...@@ -387,18 +387,8 @@ public class MqttReceiveServiceImpl implements MqttReceiveService { ...@@ -387,18 +387,8 @@ public class MqttReceiveServiceImpl implements MqttReceiveService {
syncDataService.syncCreatedFireEquipMeasurement(fireEquipMeasurementCollect); syncDataService.syncCreatedFireEquipMeasurement(fireEquipMeasurementCollect);
} }
} }
String status = EquipmentStateUtil.judgeEquipState(newIndexList); // 发送数据到画布
equipmentStateVo.setStatus(status); publishDataToCanvas(newIndexList, iotCode);
// 添加性能指标项
equipmentStateVo.setSpeindexList(fireFightingSystemService.getSpeIndex(equipmentSpecificIndexList.get(0).getEquipmentSpecificId()));
//平台数据结构调整,equipCode、status 放到一个对象里
Map<String, Object> topicObject = new HashMap<>();
topicObject.put("equipCode", equipmentStateVo.getEquipCode());
topicObject.put("status", equipmentStateVo.getStatus());
Map<String, Object> map = JSON.parseObject(JSON.toJSONString(equipmentStateVo));
map.put(canvasTopic, topicObject);
// 发送数据至画布
mqttSendGateway.sendToMqtt(canvasTopic, JSON.toJSONString(map));
} }
// 设备报警日报表数据储存更新 // 设备报警日报表数据储存更新
...@@ -735,13 +725,13 @@ public class MqttReceiveServiceImpl implements MqttReceiveService { ...@@ -735,13 +725,13 @@ public class MqttReceiveServiceImpl implements MqttReceiveService {
}); });
//若为物联设备,则更新拓扑节点数据及告警状态 //若为物联设备,则更新拓扑节点数据及告警状态
if (!ObjectUtils.isEmpty(indexList)) { // if (!ObjectUtils.isEmpty(indexList)) {
EquipmentVo equipmentVo = equipmentService.getEquipBySpecific(indexList.get(0).getEquipmentSpecificId()); // EquipmentVo equipmentVo = equipmentService.getEquipBySpecific(indexList.get(0).getEquipmentSpecificId());
if (equipmentVo.getIsIot().equals("1")) { // if (equipmentVo.getIsIot().equals("1")) {
List<EquipmentSpecificAlarm> alarmList = equipmentSpecificAlarmService.getEquipListBySpecific(true, indexList.get(0).getEquipmentSpecificId()); // List<EquipmentSpecificAlarm> alarmList = equipmentSpecificAlarmService.getEquipListBySpecific(true, indexList.get(0).getEquipmentSpecificId());
topographyService.updateNodeDateByEquipId(indexList.get(0).getEquipmentSpecificId(), indexList, alarmList); // topographyService.updateNodeDateByEquipId(indexList.get(0).getEquipmentSpecificId(), indexList, alarmList);
} // }
} // }
} }
static void upAlarmLogStatus(String iotCode, String equipmentSpecificIndexKey, IEquipmentSpecificAlarmLogService equipmentSpecificAlarmLogService) { static void upAlarmLogStatus(String iotCode, String equipmentSpecificIndexKey, IEquipmentSpecificAlarmLogService equipmentSpecificAlarmLogService) {
...@@ -759,6 +749,35 @@ public class MqttReceiveServiceImpl implements MqttReceiveService { ...@@ -759,6 +749,35 @@ public class MqttReceiveServiceImpl implements MqttReceiveService {
} }
} }
public void publishDataToCanvas(List<EquipmentSpecificIndex> indexList, String iotCode) {
if (!ObjectUtils.isEmpty(indexList)) {
EquipmentSpecificIndex index = indexList.stream().filter(x -> x.getUpdateDate() != null)
.sorted(Comparator.comparing(EquipmentSpecificIndex::getUpdateDate).reversed())
.collect(Collectors.toList()).get(0);
EquipmentStateVo equipmentStateVo = new EquipmentStateVo();
equipmentStateVo.setEquipName(index.getEquipmentSpecificName());
equipmentStateVo.setOrgCode(index.getOrgCode());
equipmentStateVo.setSpecificId(index.getEquipmentSpecificId());
equipmentStateVo.setEquipCode(index.getQrCode());
equipmentStateVo.setEquipIotCode(iotCode);
equipmentStateVo.setStatus("");
equipmentStateVo.setColor(index.getEmergencyLevelColor());
// 添加性能指标项
equipmentStateVo.setSpeindexList(fireFightingSystemService.getSpeIndex(index.getEquipmentSpecificId()));
Map<String, Object> topicObject = new HashMap<>();
topicObject.put("equipCode", equipmentStateVo.getEquipCode());
if (TrueOrFalseEnum.real.value.toUpperCase().equals(index.getValue().toUpperCase())) {
topicObject.put("color", equipmentStateVo.getColor());
} else {
topicObject.put("color", "#49AA19");
}
Map<String, Object> map = JSON.parseObject(JSON.toJSONString(equipmentStateVo));
map.put(canvasTopic, topicObject);
// 发送数据至画布
mqttSendGateway.sendToMqtt(canvasTopic, JSON.toJSONString(map));
}
}
void syncSystemctlMsg(EquipmentSpecificAlarmLog equipmentSpecificAlarmLog) { void syncSystemctlMsg(EquipmentSpecificAlarmLog equipmentSpecificAlarmLog) {
try { try {
MessageModel model = new MessageModel(); MessageModel model = new MessageModel();
......
...@@ -348,7 +348,7 @@ public class RiskSourceSceneServiceImpl extends ServiceImpl<RiskSourceSceneMappe ...@@ -348,7 +348,7 @@ public class RiskSourceSceneServiceImpl extends ServiceImpl<RiskSourceSceneMappe
equipIndexLatestStatus.forEach(action->{ equipIndexLatestStatus.forEach(action->{
Map<String, String> map = new HashMap<>(); Map<String, String> map = new HashMap<>();
map.put("equipCode", action.getQrCode()); map.put("equipCode", action.getQrCode());
map.put("color", action.getEmergencyLevelColor()); map.put("color", EquipmentStateUtil.judgeEquipState(action));
data.add(map); data.add(map);
}); });
return data; return data;
......
...@@ -275,13 +275,15 @@ ...@@ -275,13 +275,15 @@
SELECT SELECT
equipindex.`value`, equipindex.`value`,
ei.type_code AS 'typeCode', ei.type_code AS 'typeCode',
es.qr_code AS 'qrCode' es.qr_code AS 'qrCode',
equipindex.color AS emergencyLevelColor
FROM FROM
( (
SELECT SELECT
esi.equipment_index_id, esi.equipment_index_id,
esi.equipment_specific_id, esi.equipment_specific_id,
esi.`value` esi.`value`,
esi.emergency_level_color as color
FROM FROM
wl_equipment_specific_index esi, wl_equipment_specific_index esi,
( (
...@@ -316,7 +318,7 @@ ...@@ -316,7 +318,7 @@
es.qr_code AS 'qrCode', es.qr_code AS 'qrCode',
es.iot_code AS 'iotCode', es.iot_code AS 'iotCode',
es.realtime_iot_index_value AS 'value', es.realtime_iot_index_value AS 'value',
sc.color AS color sc.emergency_level_color AS 'emergencyLevelColor'
FROM FROM
wl_equipment_specific es, wl_equipment_specific es,
wl_equipment_index ei, wl_equipment_index ei,
......
...@@ -361,7 +361,9 @@ ...@@ -361,7 +361,9 @@
spein.emergency_level_color AS color, spein.emergency_level_color AS color,
spein.is_alarm AS isAlarm, spein.is_alarm AS isAlarm,
spein.emergency_level AS emergencyLevel, spein.emergency_level AS emergencyLevel,
spein.emergency_level_describe AS emergencyLevelDescribe spein.emergency_level_describe AS emergencyLevelDescribe,
spein.`value` AS indexValue,
spein.equipment_index_name AS indexName
FROM FROM
wl_equipment_specific_index AS spein wl_equipment_specific_index AS spein
LEFT JOIN wl_equipment_index AS eqin ON spein.equipment_index_id = eqin.id LEFT JOIN wl_equipment_index AS eqin ON spein.equipment_index_id = eqin.id
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment