|
@@ -225,7 +225,7 @@
|
|
|
v-model="detailVisible"
|
|
|
title="设备监控"
|
|
|
direction="rtl"
|
|
|
- size="50%"
|
|
|
+ size="80%"
|
|
|
>
|
|
|
<el-tabs v-model="activeTab">
|
|
|
<el-tab-pane label="设备详情" name="detail">
|
|
@@ -244,26 +244,348 @@
|
|
|
<el-descriptions-item label="序列号">{{currentDevice.serialNumber}}</el-descriptions-item>
|
|
|
</el-descriptions>
|
|
|
</el-tab-pane>
|
|
|
+
|
|
|
<el-tab-pane label="设备组态" name="configuration">
|
|
|
- <!-- 设备组态内容 -->
|
|
|
+ <div class="configuration-container">
|
|
|
+ <el-row :gutter="20">
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-card>
|
|
|
+ <template #header>
|
|
|
+ <div class="card-header">
|
|
|
+ <span>设备参数配置</span>
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+ <el-form label-width="120px">
|
|
|
+ <el-form-item label="运行模式">
|
|
|
+ <el-select v-model="configData.runMode" placeholder="请选择">
|
|
|
+ <el-option label="自动模式" value="auto"></el-option>
|
|
|
+ <el-option label="手动模式" value="manual"></el-option>
|
|
|
+ <el-option label="节能模式" value="energy"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="温度设定">
|
|
|
+ <el-input-number v-model="configData.tempSetting" :min="16" :max="30" :step="0.5"></el-input-number>
|
|
|
+ <span style="margin-left: 10px;">℃</span>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="湿度设定">
|
|
|
+ <el-slider v-model="configData.humiditySetting" :min="30" :max="80" show-input></el-slider>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="风速调节">
|
|
|
+ <el-radio-group v-model="configData.fanSpeed">
|
|
|
+ <el-radio label="low">低速</el-radio>
|
|
|
+ <el-radio label="medium">中速</el-radio>
|
|
|
+ <el-radio label="high">高速</el-radio>
|
|
|
+ </el-radio-group>
|
|
|
+ </el-form-item>
|
|
|
+ </el-form>
|
|
|
+ </el-card>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-card>
|
|
|
+ <template #header>
|
|
|
+ <div class="card-header">
|
|
|
+ <span>设备控制点位</span>
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+ <el-table :data="controlPoints" style="width: 100%">
|
|
|
+ <el-table-column prop="pointName" label="点位名称" width="120"></el-table-column>
|
|
|
+ <el-table-column prop="pointType" label="类型" width="80"></el-table-column>
|
|
|
+ <el-table-column prop="currentValue" label="当前值"></el-table-column>
|
|
|
+ <el-table-column label="操作" width="100">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-switch v-if="scope.row.pointType === '开关'" v-model="scope.row.status"></el-switch>
|
|
|
+ <el-input-number v-else size="small" v-model="scope.row.currentValue" :min="0" :max="100"></el-input-number>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ </el-table>
|
|
|
+ </el-card>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ </div>
|
|
|
</el-tab-pane>
|
|
|
+
|
|
|
<el-tab-pane label="设备告警" name="alarm">
|
|
|
- <!-- 设备告警内容 -->
|
|
|
+ <div class="alarm-container">
|
|
|
+ <el-row class="mb8">
|
|
|
+ <el-col :span="24">
|
|
|
+ <el-button type="primary" size="small" @click="handleAlarmAck">批量确认</el-button>
|
|
|
+ <el-button type="warning" size="small" @click="handleAlarmExport">导出告警</el-button>
|
|
|
+ <el-tag class="ml10" type="danger">未处理: {{unhandledAlarms}}</el-tag>
|
|
|
+ <el-tag class="ml10" type="warning">处理中: {{processingAlarms}}</el-tag>
|
|
|
+ <el-tag class="ml10" type="success">已处理: {{handledAlarms}}</el-tag>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ <el-table :data="alarmList" @selection-change="handleAlarmSelection" stripe>
|
|
|
+ <el-table-column type="selection" width="55"></el-table-column>
|
|
|
+ <el-table-column prop="alarmTime" label="告警时间" width="160" sortable></el-table-column>
|
|
|
+ <el-table-column prop="alarmLevel" label="告警级别" width="100">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-tag :type="getAlarmLevelType(scope.row.alarmLevel)">
|
|
|
+ {{scope.row.alarmLevel}}
|
|
|
+ </el-tag>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="alarmType" label="告警类型" width="120"></el-table-column>
|
|
|
+ <el-table-column prop="alarmContent" label="告警内容" show-overflow-tooltip></el-table-column>
|
|
|
+ <el-table-column prop="status" label="状态" width="100">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-tag :type="getAlarmStatusType(scope.row.status)">
|
|
|
+ {{scope.row.status}}
|
|
|
+ </el-tag>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="操作" width="150">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-button link type="primary" size="small" @click="handleAlarmDetail(scope.row)">详情</el-button>
|
|
|
+ <el-button link type="primary" size="small" @click="handleAlarmConfirm(scope.row)">确认</el-button>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ </el-table>
|
|
|
+ </div>
|
|
|
</el-tab-pane>
|
|
|
- <el-tab-pane label="控制纪录" name="control">
|
|
|
- <!-- 控制纪录内容 -->
|
|
|
+
|
|
|
+ <el-tab-pane label="控制记录" name="control">
|
|
|
+ <div class="control-container">
|
|
|
+ <el-form :inline="true" class="mb8">
|
|
|
+ <el-form-item label="时间范围">
|
|
|
+ <el-date-picker
|
|
|
+ v-model="controlDateRange"
|
|
|
+ type="datetimerange"
|
|
|
+ range-separator="至"
|
|
|
+ start-placeholder="开始时间"
|
|
|
+ end-placeholder="结束时间"
|
|
|
+ format="YYYY-MM-DD HH:mm:ss"
|
|
|
+ value-format="YYYY-MM-DD HH:mm:ss"
|
|
|
+ />
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item>
|
|
|
+ <el-button type="primary" @click="queryControlRecords">查询</el-button>
|
|
|
+ </el-form-item>
|
|
|
+ </el-form>
|
|
|
+ <el-table :data="controlRecords" stripe>
|
|
|
+ <el-table-column prop="controlTime" label="控制时间" width="160"></el-table-column>
|
|
|
+ <el-table-column prop="operator" label="操作人" width="100"></el-table-column>
|
|
|
+ <el-table-column prop="controlType" label="控制类型" width="120"></el-table-column>
|
|
|
+ <el-table-column prop="controlPoint" label="控制点" width="150"></el-table-column>
|
|
|
+ <el-table-column prop="beforeValue" label="控制前值" width="100"></el-table-column>
|
|
|
+ <el-table-column prop="afterValue" label="控制后值" width="100"></el-table-column>
|
|
|
+ <el-table-column prop="result" label="执行结果" width="100">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-tag :type="scope.row.result === '成功' ? 'success' : 'danger'">
|
|
|
+ {{scope.row.result}}
|
|
|
+ </el-tag>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="remark" label="备注" show-overflow-tooltip></el-table-column>
|
|
|
+ </el-table>
|
|
|
+ </div>
|
|
|
</el-tab-pane>
|
|
|
+
|
|
|
<el-tab-pane label="实时数据" name="realtime">
|
|
|
- <!-- 实时数据内容 -->
|
|
|
+ <div class="realtime-container">
|
|
|
+ <el-row :gutter="20">
|
|
|
+ <el-col :span="8" v-for="(item, index) in realtimeData" :key="index">
|
|
|
+ <el-card class="mb20">
|
|
|
+ <div class="realtime-item">
|
|
|
+ <div class="item-header">
|
|
|
+ <i :class="item.icon" :style="{color: item.color}"></i>
|
|
|
+ <span class="item-title">{{item.name}}</span>
|
|
|
+ </div>
|
|
|
+ <div class="item-value">
|
|
|
+ <span class="value">{{item.value}}</span>
|
|
|
+ <span class="unit">{{item.unit}}</span>
|
|
|
+ </div>
|
|
|
+ <div class="item-info">
|
|
|
+ <span :class="['status', item.status]">{{item.statusText}}</span>
|
|
|
+ <span class="update-time">更新时间: {{item.updateTime}}</span>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </el-card>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ <el-card>
|
|
|
+ <template #header>
|
|
|
+ <div class="card-header">
|
|
|
+ <span>实时趋势图</span>
|
|
|
+ <el-button-group style="float: right;">
|
|
|
+ <el-button size="small" @click="changeChartPeriod('5m')">5分钟</el-button>
|
|
|
+ <el-button size="small" @click="changeChartPeriod('30m')">30分钟</el-button>
|
|
|
+ <el-button size="small" @click="changeChartPeriod('1h')">1小时</el-button>
|
|
|
+ </el-button-group>
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+ <div id="realtimeChart" style="height: 300px;">
|
|
|
+ <!-- 这里应该集成图表库如ECharts -->
|
|
|
+ <el-empty description="实时趋势图区域"></el-empty>
|
|
|
+ </div>
|
|
|
+ </el-card>
|
|
|
+ </div>
|
|
|
</el-tab-pane>
|
|
|
+
|
|
|
<el-tab-pane label="历史数据" name="instant">
|
|
|
- <!-- 历史数据内容 -->
|
|
|
+ <div class="history-container">
|
|
|
+ <el-form :inline="true" class="mb8">
|
|
|
+ <el-form-item label="数据点">
|
|
|
+ <el-select v-model="historyQuery.dataPoint" placeholder="请选择数据点" multiple>
|
|
|
+ <el-option label="温度" value="temperature"></el-option>
|
|
|
+ <el-option label="湿度" value="humidity"></el-option>
|
|
|
+ <el-option label="电压" value="voltage"></el-option>
|
|
|
+ <el-option label="电流" value="current"></el-option>
|
|
|
+ <el-option label="功率" value="power"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="时间范围">
|
|
|
+ <el-date-picker
|
|
|
+ v-model="historyDateRange"
|
|
|
+ type="datetimerange"
|
|
|
+ range-separator="至"
|
|
|
+ start-placeholder="开始时间"
|
|
|
+ end-placeholder="结束时间"
|
|
|
+ />
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item>
|
|
|
+ <el-button type="primary" @click="queryHistoryData">查询</el-button>
|
|
|
+ <el-button type="success" @click="exportHistoryData">导出</el-button>
|
|
|
+ </el-form-item>
|
|
|
+ </el-form>
|
|
|
+ <el-table :data="historyData" stripe max-height="400">
|
|
|
+ <el-table-column prop="recordTime" label="记录时间" width="160" sortable></el-table-column>
|
|
|
+ <el-table-column prop="temperature" label="温度(℃)" width="100"></el-table-column>
|
|
|
+ <el-table-column prop="humidity" label="湿度(%)" width="100"></el-table-column>
|
|
|
+ <el-table-column prop="voltage" label="电压(V)" width="100"></el-table-column>
|
|
|
+ <el-table-column prop="current" label="电流(A)" width="100"></el-table-column>
|
|
|
+ <el-table-column prop="power" label="功率(kW)" width="100"></el-table-column>
|
|
|
+ <el-table-column prop="energy" label="能耗(kWh)" width="100"></el-table-column>
|
|
|
+ </el-table>
|
|
|
+ <div class="history-chart mt20">
|
|
|
+ <el-card>
|
|
|
+ <template #header>
|
|
|
+ <span>历史趋势分析</span>
|
|
|
+ </template>
|
|
|
+ <div id="historyChart" style="height: 300px;">
|
|
|
+ <el-empty description="历史趋势图区域"></el-empty>
|
|
|
+ </div>
|
|
|
+ </el-card>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
</el-tab-pane>
|
|
|
+
|
|
|
<el-tab-pane label="自动抄表" name="meter">
|
|
|
- <!-- 自动抄表内容 -->
|
|
|
+ <div class="meter-container">
|
|
|
+ <el-row class="mb8">
|
|
|
+ <el-col :span="24">
|
|
|
+ <el-button type="primary" @click="handleManualRead">手动抄表</el-button>
|
|
|
+ <el-button type="success" @click="handleMeterExport">导出数据</el-button>
|
|
|
+ <span style="margin-left: 20px;">
|
|
|
+ 自动抄表周期:
|
|
|
+ <el-select v-model="meterConfig.period" size="small" style="width: 120px;">
|
|
|
+ <el-option label="每小时" value="hourly"></el-option>
|
|
|
+ <el-option label="每天" value="daily"></el-option>
|
|
|
+ <el-option label="每周" value="weekly"></el-option>
|
|
|
+ <el-option label="每月" value="monthly"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </span>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ <el-table :data="meterData" stripe>
|
|
|
+ <el-table-column prop="meterTime" label="抄表时间" width="160"></el-table-column>
|
|
|
+ <el-table-column prop="meterType" label="表计类型" width="100">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-tag>{{scope.row.meterType}}</el-tag>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="lastReading" label="上次读数" width="120"></el-table-column>
|
|
|
+ <el-table-column prop="currentReading" label="本次读数" width="120"></el-table-column>
|
|
|
+ <el-table-column prop="usage" label="用量" width="100">
|
|
|
+ <template #default="scope">
|
|
|
+ <span style="color: #409EFF;">{{scope.row.usage}}</span>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="unit" label="单位" width="80"></el-table-column>
|
|
|
+ <el-table-column prop="status" label="状态" width="100">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-tag :type="scope.row.status === '正常' ? 'success' : 'warning'">
|
|
|
+ {{scope.row.status}}
|
|
|
+ </el-tag>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="remark" label="备注"></el-table-column>
|
|
|
+ </el-table>
|
|
|
+ <el-row :gutter="20" class="mt20">
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-card>
|
|
|
+ <template #header>
|
|
|
+ <span>能耗统计</span>
|
|
|
+ </template>
|
|
|
+ <el-descriptions :column="2">
|
|
|
+ <el-descriptions-item label="本月电量">12,345 kWh</el-descriptions-item>
|
|
|
+ <el-descriptions-item label="本月水量">456 m³</el-descriptions-item>
|
|
|
+ <el-descriptions-item label="同比增长">+5.2%</el-descriptions-item>
|
|
|
+ <el-descriptions-item label="环比增长">+2.1%</el-descriptions-item>
|
|
|
+ </el-descriptions>
|
|
|
+ </el-card>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="12">
|
|
|
+ <el-card>
|
|
|
+ <template #header>
|
|
|
+ <span>费用预估</span>
|
|
|
+ </template>
|
|
|
+ <el-descriptions :column="2">
|
|
|
+ <el-descriptions-item label="本月电费">¥8,641.5</el-descriptions-item>
|
|
|
+ <el-descriptions-item label="本月水费">¥1,824.0</el-descriptions-item>
|
|
|
+ <el-descriptions-item label="预计总费用">¥10,465.5</el-descriptions-item>
|
|
|
+ <el-descriptions-item label="费用预警">正常</el-descriptions-item>
|
|
|
+ </el-descriptions>
|
|
|
+ </el-card>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ </div>
|
|
|
</el-tab-pane>
|
|
|
+
|
|
|
<el-tab-pane label="事件记录" name="event">
|
|
|
- <!-- 事件记录内容 -->
|
|
|
+ <div class="event-container">
|
|
|
+ <el-form :inline="true" class="mb8">
|
|
|
+ <el-form-item label="事件类型">
|
|
|
+ <el-select v-model="eventQuery.type" placeholder="全部类型">
|
|
|
+ <el-option label="全部" value=""></el-option>
|
|
|
+ <el-option label="系统事件" value="system"></el-option>
|
|
|
+ <el-option label="操作事件" value="operation"></el-option>
|
|
|
+ <el-option label="告警事件" value="alarm"></el-option>
|
|
|
+ <el-option label="维护事件" value="maintenance"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="时间范围">
|
|
|
+ <el-date-picker
|
|
|
+ v-model="eventDateRange"
|
|
|
+ type="daterange"
|
|
|
+ range-separator="至"
|
|
|
+ start-placeholder="开始日期"
|
|
|
+ end-placeholder="结束日期"
|
|
|
+ />
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item>
|
|
|
+ <el-button type="primary" @click="queryEvents">查询</el-button>
|
|
|
+ </el-form-item>
|
|
|
+ </el-form>
|
|
|
+ <el-timeline>
|
|
|
+ <el-timeline-item
|
|
|
+ v-for="(event, index) in eventList"
|
|
|
+ :key="index"
|
|
|
+ :timestamp="event.eventTime"
|
|
|
+ placement="top"
|
|
|
+ :type="getEventType(event.type)"
|
|
|
+ >
|
|
|
+ <el-card>
|
|
|
+ <h4>{{event.title}}</h4>
|
|
|
+ <p>{{event.content}}</p>
|
|
|
+ <p style="margin-top: 10px;">
|
|
|
+ <el-tag size="small" :type="getEventType(event.type)">{{event.type}}</el-tag>
|
|
|
+ <span style="margin-left: 10px; color: #909399;">操作人: {{event.operator}}</span>
|
|
|
+ </p>
|
|
|
+ </el-card>
|
|
|
+ </el-timeline-item>
|
|
|
+ </el-timeline>
|
|
|
+ </div>
|
|
|
</el-tab-pane>
|
|
|
</el-tabs>
|
|
|
</el-drawer>
|
|
@@ -297,7 +619,156 @@ function handleDetail(row) {
|
|
|
detailVisible.value = true;
|
|
|
}
|
|
|
|
|
|
+//================
|
|
|
+// 新增的响应式数据
|
|
|
+const configData = ref({
|
|
|
+ runMode: 'auto',
|
|
|
+ tempSetting: 25,
|
|
|
+ humiditySetting: 60,
|
|
|
+ fanSpeed: 'medium'
|
|
|
+});
|
|
|
+
|
|
|
+const controlPoints = ref([
|
|
|
+ { pointName: '电源开关', pointType: '开关', currentValue: '开启', status: true },
|
|
|
+ { pointName: '温度设定', pointType: '模拟量', currentValue: 25 },
|
|
|
+ { pointName: '风速控制', pointType: '模拟量', currentValue: 50 },
|
|
|
+ { pointName: '新风阀门', pointType: '开关', currentValue: '关闭', status: false }
|
|
|
+]);
|
|
|
+
|
|
|
+const alarmList = ref([
|
|
|
+ { alarmTime: '2025-06-12 14:30:25', alarmLevel: '严重', alarmType: '温度异常', alarmContent: '设备温度超过设定阈值,当前温度32℃', status: '未处理' },
|
|
|
+ { alarmTime: '2025-06-12 13:15:10', alarmLevel: '警告', alarmType: '通信故障', alarmContent: '设备通信中断超过5分钟', status: '处理中' },
|
|
|
+ { alarmTime: '2025-06-12 10:20:30', alarmLevel: '一般', alarmType: '维护提醒', alarmContent: '设备运行时间已达到维护周期', status: '已处理' }
|
|
|
+]);
|
|
|
+
|
|
|
+const unhandledAlarms = ref(1);
|
|
|
+const processingAlarms = ref(1);
|
|
|
+const handledAlarms = ref(1);
|
|
|
+
|
|
|
+const controlDateRange = ref([]);
|
|
|
+const controlRecords = ref([
|
|
|
+ { controlTime: '2025-06-12 14:00:00', operator: '张三', controlType: '手动控制', controlPoint: '温度设定', beforeValue: '26℃', afterValue: '25℃', result: '成功', remark: '用户反馈温度过高' },
|
|
|
+ { controlTime: '2025-06-12 12:30:00', operator: '系统', controlType: '自动调节', controlPoint: '风速控制', beforeValue: '30%', afterValue: '50%', result: '成功', remark: '根据负荷自动调节' }
|
|
|
+]);
|
|
|
+
|
|
|
+const realtimeData = ref([
|
|
|
+ { name: '室内温度', value: 25.3, unit: '℃', icon: 'el-icon-sunny', color: '#E6A23C', status: 'normal', statusText: '正常', updateTime: '14:35:20' },
|
|
|
+ { name: '室内湿度', value: 58, unit: '%', icon: 'el-icon-drop', color: '#409EFF', status: 'normal', statusText: '正常', updateTime: '14:35:20' },
|
|
|
+ { name: '设备功率', value: 3.85, unit: 'kW', icon: 'el-icon-lightning', color: '#67C23A', status: 'normal', statusText: '正常', updateTime: '14:35:20' },
|
|
|
+ { name: '运行电流', value: 16.5, unit: 'A', icon: 'el-icon-battery-full', color: '#F56C6C', status: 'normal', statusText: '正常', updateTime: '14:35:20' },
|
|
|
+ { name: '累计能耗', value: 1256.8, unit: 'kWh', icon: 'el-icon-chart-line', color: '#909399', status: 'normal', statusText: '正常', updateTime: '14:35:20' },
|
|
|
+ { name: 'CO2浓度', value: 456, unit: 'ppm', icon: 'el-icon-wind-power', color: '#00CED1', status: 'normal', statusText: '正常', updateTime: '14:35:20' }
|
|
|
+]);
|
|
|
+
|
|
|
+const historyQuery = ref({
|
|
|
+ dataPoint: []
|
|
|
+});
|
|
|
+
|
|
|
+const historyDateRange = ref([]);
|
|
|
+const historyData = ref([
|
|
|
+ { recordTime: '2025-06-12 14:00:00', temperature: 25.2, humidity: 58, voltage: 220, current: 16.4, power: 3.61, energy: 3.61 },
|
|
|
+ { recordTime: '2025-06-12 13:00:00', temperature: 25.5, humidity: 57, voltage: 221, current: 16.6, power: 3.67, energy: 3.67 },
|
|
|
+ { recordTime: '2025-06-12 12:00:00', temperature: 26.1, humidity: 55, voltage: 219, current: 17.1, power: 3.74, energy: 3.74 }
|
|
|
+]);
|
|
|
+
|
|
|
+const meterConfig = ref({
|
|
|
+ period: 'daily'
|
|
|
+});
|
|
|
+
|
|
|
+const meterData = ref([
|
|
|
+ { meterTime: '2025-06-12 00:00:00', meterType: '电表', lastReading: '12000.5', currentReading: '12095.3', usage: '94.8', unit: 'kWh', status: '正常', remark: '自动抄表' },
|
|
|
+ { meterTime: '2025-06-11 00:00:00', meterType: '水表', lastReading: '5420.2', currentReading: '5435.7', usage: '15.5', unit: 'm³', status: '正常', remark: '自动抄表' }
|
|
|
+]);
|
|
|
+
|
|
|
+const eventQuery = ref({
|
|
|
+ type: ''
|
|
|
+});
|
|
|
|
|
|
+const eventDateRange = ref([]);
|
|
|
+const eventList = ref([
|
|
|
+ { eventTime: '2025-06-12 14:30:25', type: '告警事件', title: '温度异常告警', content: '空调设备AHU-01温度超限,已自动调节', operator: '系统' },
|
|
|
+ { eventTime: '2025-06-12 12:00:00', type: '维护事件', title: '设备维护完成', content: '完成空调过滤网清洗和制冷剂检查', operator: '李四' },
|
|
|
+ { eventTime: '2025-06-12 09:15:30', type: '操作事件', title: '设备参数调整', content: '根据天气预报调整温度设定值', operator: '张三' },
|
|
|
+ { eventTime: '2025-06-11 18:00:00', type: '系统事件', title: '设备自动启停', content: '根据排程计划,设备自动停机', operator: '系统' }
|
|
|
+]);
|
|
|
+
|
|
|
+// 新增的方法
|
|
|
+function getAlarmLevelType(level) {
|
|
|
+ const typeMap = {
|
|
|
+ '严重': 'danger',
|
|
|
+ '警告': 'warning',
|
|
|
+ '一般': 'info'
|
|
|
+ };
|
|
|
+ return typeMap[level] || 'info';
|
|
|
+}
|
|
|
+
|
|
|
+function getAlarmStatusType(status) {
|
|
|
+ const typeMap = {
|
|
|
+ '未处理': 'danger',
|
|
|
+ '处理中': 'warning',
|
|
|
+ '已处理': 'success'
|
|
|
+ };
|
|
|
+ return typeMap[status] || 'info';
|
|
|
+}
|
|
|
+
|
|
|
+function handleAlarmSelection(selection) {
|
|
|
+ // 处理告警选择
|
|
|
+}
|
|
|
+
|
|
|
+function handleAlarmAck() {
|
|
|
+ proxy.$modal.msgSuccess("批量确认成功");
|
|
|
+}
|
|
|
+
|
|
|
+function handleAlarmExport() {
|
|
|
+ proxy.$modal.msgSuccess("导出告警数据");
|
|
|
+}
|
|
|
+
|
|
|
+function handleAlarmDetail(row) {
|
|
|
+ proxy.$modal.msgInfo("查看告警详情");
|
|
|
+}
|
|
|
+
|
|
|
+function handleAlarmConfirm(row) {
|
|
|
+ proxy.$modal.msgSuccess("告警已确认");
|
|
|
+}
|
|
|
+
|
|
|
+function queryControlRecords() {
|
|
|
+ proxy.$modal.msgSuccess("查询控制记录");
|
|
|
+}
|
|
|
+
|
|
|
+function changeChartPeriod(period) {
|
|
|
+ proxy.$modal.msgInfo(`切换到${period}视图`);
|
|
|
+}
|
|
|
+
|
|
|
+function queryHistoryData() {
|
|
|
+ proxy.$modal.msgSuccess("查询历史数据");
|
|
|
+}
|
|
|
+
|
|
|
+function exportHistoryData() {
|
|
|
+ proxy.$modal.msgSuccess("导出历史数据");
|
|
|
+}
|
|
|
+
|
|
|
+function handleManualRead() {
|
|
|
+ proxy.$modal.msgSuccess("手动抄表成功");
|
|
|
+}
|
|
|
+
|
|
|
+function handleMeterExport() {
|
|
|
+ proxy.$modal.msgSuccess("导出抄表数据");
|
|
|
+}
|
|
|
+
|
|
|
+function queryEvents() {
|
|
|
+ proxy.$modal.msgSuccess("查询事件记录");
|
|
|
+}
|
|
|
+
|
|
|
+function getEventType(type) {
|
|
|
+ const typeMap = {
|
|
|
+ '系统事件': 'primary',
|
|
|
+ '操作事件': 'success',
|
|
|
+ '告警事件': 'danger',
|
|
|
+ '维护事件': 'warning'
|
|
|
+ };
|
|
|
+ return typeMap[type] || 'info';
|
|
|
+}
|
|
|
+//================
|
|
|
const data = reactive({
|
|
|
form: {},
|
|
|
queryParams: {
|
|
@@ -454,3 +925,76 @@ function handleExport() {
|
|
|
|
|
|
getList();
|
|
|
</script>
|
|
|
+<style scoped>
|
|
|
+/* 新增的样式 */
|
|
|
+.configuration-container .card-header {
|
|
|
+ display: flex;
|
|
|
+ justify-content: space-between;
|
|
|
+ align-items: center;
|
|
|
+}
|
|
|
+
|
|
|
+.realtime-container .realtime-item {
|
|
|
+ text-align: center;
|
|
|
+ padding: 20px;
|
|
|
+}
|
|
|
+
|
|
|
+.realtime-item .item-header {
|
|
|
+ display: flex;
|
|
|
+ align-items: center;
|
|
|
+ justify-content: center;
|
|
|
+ margin-bottom: 10px;
|
|
|
+}
|
|
|
+
|
|
|
+.realtime-item .item-header i {
|
|
|
+ font-size: 24px;
|
|
|
+ margin-right: 10px;
|
|
|
+}
|
|
|
+
|
|
|
+.realtime-item .item-title {
|
|
|
+ font-size: 16px;
|
|
|
+ color: #303133;
|
|
|
+}
|
|
|
+
|
|
|
+.realtime-item .item-value {
|
|
|
+ margin: 15px 0;
|
|
|
+}
|
|
|
+
|
|
|
+.realtime-item .value {
|
|
|
+ font-size: 32px;
|
|
|
+ font-weight: bold;
|
|
|
+ color: #409EFF;
|
|
|
+}
|
|
|
+
|
|
|
+.realtime-item .unit {
|
|
|
+ font-size: 14px;
|
|
|
+ color: #909399;
|
|
|
+ margin-left: 5px;
|
|
|
+}
|
|
|
+
|
|
|
+.realtime-item .item-info {
|
|
|
+ display: flex;
|
|
|
+ justify-content: space-between;
|
|
|
+ font-size: 12px;
|
|
|
+ color: #909399;
|
|
|
+}
|
|
|
+
|
|
|
+.realtime-item .status.normal {
|
|
|
+ color: #67C23A;
|
|
|
+}
|
|
|
+
|
|
|
+.ml10 {
|
|
|
+ margin-left: 10px;
|
|
|
+}
|
|
|
+
|
|
|
+.mt20 {
|
|
|
+ margin-top: 20px;
|
|
|
+}
|
|
|
+
|
|
|
+.mb8 {
|
|
|
+ margin-bottom: 8px;
|
|
|
+}
|
|
|
+
|
|
|
+.mb20 {
|
|
|
+ margin-bottom: 20px;
|
|
|
+}
|
|
|
+</style>
|