@@ -205,10 +205,21 @@
import { dict , getEnum } from '/@/api' ;
import dayjs from 'dayjs' ;
// 全局变量
import { items } from '/@/store/item' ;
defineOptions ( {
name : 'AggregateData' , // 与页面路由name一致缓存才可生效
} ) ;
const l oading = ref ( false ) ;
let statusL oading = ref ( false ) ;
let averageLoading = ref ( false ) ;
let hotLoading = ref ( false ) ;
// 全局变量
const state = items ( ) ;
// 采集频率
const frequencyValue = ref < string > ( ) ;
@@ -241,25 +252,35 @@
// 获取设备状态
const getDeviceStatus = ( ) => {
http . post ( environmentMonitor . getDeviceStatus , { orgId : orgId . value } ) . then ( ( res ) => {
ringData . value = [
{
name : '在线' ,
value : res . data . 在线 ,
unit : '台' ,
} ,
{
name : '离线 ' ,
value : res . data . 离线 ,
unit : '台' ,
} ,
] ;
sum . value = res . data . 在线 + res . data . 离线 ;
// drawRing(ringData.value);
} ) ;
statusLoading . value = true ;
http
. post ( environmentMonitor . getDeviceStatus , { orgId : orgId . value } )
. then ( ( res ) => {
ringData . value = [
{
name : '在线' ,
value : res . data . 在线 ,
unit : '台 ' ,
} ,
{
name : '离线' ,
value : res . data . 离线 ,
unit : '台' ,
} ,
] ;
sum . value = res . data . 在线 + res . data . 离线 ;
// drawRing(ringData.value);
} )
. finally ( ( ) => {
statusLoading . value = false ;
if ( ! statusLoading . value && ! averageLoading . value && ! hotLoading . value ) {
state . setLoading ( false ) ;
}
} ) ;
} ;
// 获取平均值
const getAverageData = ( ) => {
averageLoading . value = true ;
const now = new Date ( ) ;
const year = now . getFullYear ( ) ;
// getMonth() 返回的月份是从0开始的, 所以需要加1
@@ -319,6 +340,12 @@
'' ,
} ,
] ;
} )
. finally ( ( ) => {
averageLoading . value = false ;
if ( ! statusLoading . value && ! averageLoading . value && ! hotLoading . value ) {
state . setLoading ( false ) ;
}
} ) ;
} ;
// 获取区域数据
@@ -336,6 +363,7 @@
// 获取热力图数据
const getDeviceHotMap = ( ) => {
hotLoading . value = true ;
let environmentType = '' ;
for ( let i = 0 ; i < typeList . value . length ; i ++ ) {
if ( typeList . value [ i ] . value == typeValue . value ) {
@@ -356,10 +384,18 @@
. then ( ( res ) => {
let hotData = res . data ;
drawHot ( hotData ) ;
} )
. finally ( ( ) => {
hotLoading . value = false ;
if ( ! statusLoading . value && ! averageLoading . value && ! hotLoading . value ) {
state . setLoading ( false ) ;
}
} ) ;
} ;
const initOptions = ( ) => { } ;
const initOptions = ( ) => {
state . setLoading ( true ) ;
} ;
onMounted ( async ( ) => {
initOptions ( ) ;
//获取设备状态