From afd12bd4683489925575346214080faf05394a73 Mon Sep 17 00:00:00 2001
From: 潘志宝 <979469083@qq.com>
Date: 星期一, 20 一月 2025 18:29:03 +0800
Subject: [PATCH] 预警消息列表

---
 src/views/model/pre/item/MmPredictItemChart.vue |  160 ++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 116 insertions(+), 44 deletions(-)

diff --git a/src/views/model/pre/item/MmPredictItemChart.vue b/src/views/model/pre/item/MmPredictItemChart.vue
index 215c854..4d24c06 100644
--- a/src/views/model/pre/item/MmPredictItemChart.vue
+++ b/src/views/model/pre/item/MmPredictItemChart.vue
@@ -1,8 +1,9 @@
 <template>
   <el-dialog
-    title="采集值"
+    title="预测数据"
     :close-on-click-modal="false"
     width="50%"
+    @close="dialogClose"
     v-model="visible"
   >
     <el-form
@@ -12,7 +13,6 @@
     >
       <el-form-item label="开始时间">
         <el-date-picker
-          size="mini"
           v-model="dataForm.startTime"
           format="YYYY-MM-DD HH:mm:00"
           value-format="YYYY-MM-DD HH:mm:00"
@@ -22,7 +22,6 @@
       </el-form-item>
       <el-form-item label="结束时间">
         <el-date-picker
-          size="mini"
           v-model="dataForm.endTime"
           format="YYYY-MM-DD HH:mm:00"
           value-format="YYYY-MM-DD HH:mm:00"
@@ -39,47 +38,57 @@
           plain
           @click="handleExport"
           :loading="exportLoading"
-          v-hasPermi="['data:point:export']"
         >
-          <Icon icon="ep:download" />导出
+          <Icon icon="ep:download"/>
+          导出
         </el-button>
       </el-form-item>
     </el-form>
-    <div ref="chartDom" class="result-chart"></div>
+    <div ref="chartDomPre" class="result-chart"></div>
   </el-dialog>
 </template>
 
 <script lang="ts" setup>
 import {ref} from 'vue';
 import * as echarts from 'echarts';
-import * as DaPoint from '@/api/data/da/point/daPointChart'
+import * as McsApi from '@/api/model/mcs'
 import {getYMDHM0} from "@/utils/dateUtil"
 import download from "@/utils/download";
+
 const message = useMessage() // 消息弹窗
 const visible = ref(false);
-const chartDom = ref(null);
-let myChart = null;
+const chartDomPre = ref();
+let myChart = undefined;
 const chartParams = reactive({
-  codes:[],
-  startDate : undefined,
-  endDate: undefined,
+  itemId: undefined,
+  startTime: undefined,
+  endTime: undefined,
 })
 const dataForm = ref({
   id: "",
-  pointNo: "",
-  pointName: "",
-  pointTypeName: "",
+  itemName: "",
   startTime: getYMDHM0(new Date() - 60 * 60 * 1000),
-  endTime: "",
+  endTime: getYMDHM0(new Date() + 60 * 60 * 1000),
 });
 
 /** 打开弹窗 */
 const open = async (row: object) => {
   visible.value = true
+  resetForm()
   dataForm.value.id = row.id;
-  dataForm.value.pointNo = row.pointNo;
-  dataForm.value.pointName = row.pointName;
-  getDataList();
+  dataForm.value.itemName = row.itemname;
+  if (row.id) {
+    nextTick(() => {
+      myChart = echarts.init(chartDomPre.value);
+    });
+    getDataList();
+  }
+}
+
+const dialogClose = () => {
+  if (myChart) {
+    myChart.dispose(); // 组件卸载时销毁实例
+  }
 }
 
 defineExpose({open}) // 提供 open 方法,用于打开弹窗
@@ -88,31 +97,82 @@
   visible.value = true;
   if (dataForm.value.id) {
     try {
-      chartParams.codes=[dataForm.value.pointNo];
-      chartParams.startDate = dataForm.value.startTime;
-      chartParams.endDate = dataForm.value.endTime;
-      const data = await DaPoint.getPointDaChart(chartParams)
+      chartParams.itemId = dataForm.value.id;
+      chartParams.startTime = dataForm.value.startTime;
+      chartParams.endTime = dataForm.value.endTime;
+      const data = await McsApi.getPreDataItemChart(chartParams)
+      let legendData = []
+      // if (data.legend && data.legend.length > 0) {
+      //   data.legend.forEach(item => {
+      //     legendData.push(item + ":" + '真实值')
+      //     legendData.push(item + ":" + '预测值')
+      //   })
+      // }
+
       let seriesData = []
-      data.series.forEach(item => {
+      if (data.predictTime) {
         seriesData.push({
-          name: item.name,
-          type: "line",
-          data: item.data,
-          showSymbol: true,
-          smooth: false,
-          lineStyle: {
-            normal: {
-              color: "#5B8FF9",
-              width: 1,
+          name: '',
+          data: [null],
+          type: 'line',
+          smooth: true,
+          color: 'green',
+          markLine: {
+            silent: true,
+            lineStyle: {
+              color: '#32a487',
+              width: 2
             },
+            data: [{
+              xAxis: data.predictTime
+            }],
+            label: {
+              normal: {
+                formatter: data.predictTime
+              }
+            },
+            symbol: ['circle', 'none'],
           },
         });
-      })
+      }
 
-      myChart = echarts.init(chartDom.value);
+      if (data.viewMap) {
+        Object.keys(data.viewMap).forEach(key => {
+          let viewData = data.viewMap[key]
+          if(viewData.realData) {
+            legendData.push(key + ":" + '真实值')
+            seriesData.push({
+              name: key + ":" + '真实值',
+              type: "line",
+              data: viewData.realData,
+              showSymbol: false,
+              smooth: false,
+              lineStyle: {
+                normal: {
+                  width: 1,
+                },
+              },
+            })
+          }
+          legendData.push(key + ":" + '预测值')
+          seriesData.push({
+            name: key + ":" + '预测值',
+            type: "line",
+            data: viewData.preDataN,
+            showSymbol: false,
+            smooth: false,
+            lineStyle: {
+              normal: {
+                width: 1,
+              },
+            },
+          })
+        })
+      }
+
       const option = {
         title: {
-          text: dataForm.value.pointName,
+          text: dataForm.value.itemName,
           top: 0,
           left: "1%",
           textStyle: {
@@ -131,11 +191,12 @@
           },
         },
         legend: {
-          show: false,
-          top: 10,
+          show: true,
+          top: 20,
+          data: legendData
         },
         grid: {
-          top: 30,
+          top: "20%",
           left: "3%",
           right: "5%",
           bottom: 10,
@@ -162,24 +223,35 @@
     }
   }
 }
+
 /** 导出按钮操作 */
 const exportLoading = ref(false)
 const handleExport = async () => {
-  chartParams.codes=[dataForm.value.pointNo];
-  chartParams.startDate = dataForm.value.startTime;
-  chartParams.endDate = dataForm.value.endTime;
+  chartParams.itemId = dataForm.value.id;
+  chartParams.startTime = dataForm.value.startTime?dataForm.value.startTime:"";
+  chartParams.endTime = dataForm.value.endTime?dataForm.value.endTime:"";
   try {
     // 导出的二次确认
     await message.exportConfirm()
     // 发起导出
     exportLoading.value = true
-    const data = await DaPoint.exportDaPointValue(chartParams)
-    download.excel(data, dataForm.value.pointName +'.xls')
+    const data = await McsApi.exportPredictValue(chartParams)
+    download.excel(data, dataForm.value.itemName + '.xls')
   } catch {
   } finally {
     exportLoading.value = false
   }
 }
+
+/** 重置表单 */
+const resetForm = () => {
+  dataForm.value = {
+    id: undefined,
+    itemName: undefined,
+    startTime: undefined,
+    endTime: undefined
+  }
+}
 </script>
 <style>
 .el-select {

--
Gitblit v1.9.3