Newer
Older
KaiFengPC / src / views / sponeScreen / waterFlood / pipeDetail.vue
@zhangdeliang zhangdeliang on 30 Oct 13 KB update
<template>
  <!-- 管网监测点详情 -->
  <div class="pipeMonitorDetail">
    <el-tabs v-model="tabActive" @tab-change="changeTab">
      <el-tab-pane label="管网剖面" name="1"></el-tab-pane>
      <el-tab-pane label="监测数据" name="2"></el-tab-pane>
    </el-tabs>
    <div class="content">
      <!-- 管网剖面 -->
      <div class="pipePou flex" v-if="tabActive == 1">
        <div class="leftP">
          <!-- 井深 -->
          <div class="part partJ">井深:{{ pipeDetail.bottomBuriedDepthTemp || '--' }}米</div>

          <!-- 水高度 -->
          <img src="@/assets/newImgs/HMScreen/pipeW.png" alt="" class="water" :style="{ height: waterHeight + 'px' }" />
          <div :class="['part', 'partW', realData.z > pipeDetail.pipelineDiameterTemp ? 'red' : '']">水深:{{ realData.z || '--' }} 米</div>

          <!-- 瞬时流量 -->
          <div class="part partL">流速:{{ realData.va || '--' }} m/s</div>

          <!-- 设备 -->
          <img src="@/assets/newImgs/HMScreen/equip.png" alt="" class="equipA" />
        </div>
        <div class="rightP">
          <div class="title">基本信息</div>
          <div class="part flex">
            <div class="biaoti">站点名称:</div>
            <div class="cont">{{ realData.stName }}</div>
          </div>
          <div class="part flex">
            <div class="biaoti">所在位置:</div>
            <div class="cont">{{ pipeDetail.address || '--' }}</div>
          </div>
          <div class="part flex">
            <div class="biaoti">建设方式:</div>
            <div class="cont">{{ pipeDetail.buildType == 'owner' ? '自建' : '共享' }}</div>
          </div>
          <div class="part flex">
            <div class="biaoti">管网直径:</div>
            <div class="cont">{{ pipeDetail.pipelineDiameterTemp || '--' }} 米</div>
          </div>
          <div class="part flex">
            <div class="biaoti">安装高度:</div>
            <div class="cont">{{ pipeDetail.installHeight || '--' }} 米</div>
          </div>

          <div class="title" style="margin-top: 30px">实时数据</div>
          <div class="part flex">
            <div class="biaoti">水深:</div>
            <div class="cont">{{ realData.z || '--' }} 米</div>
          </div>
          <div class="part flex">
            <div class="biaoti">流速:</div>
            <div class="cont">{{ realData.va || '--' }}m/s</div>
          </div>
          <div class="part flex">
            <div class="biaoti">SS:</div>
            <div class="cont">{{ realData.turb || '--' }} mg/L</div>
          </div>
          <div class="part flex">
            <div class="biaoti">更新时间:</div>
            <div class="cont">{{ realData.tt || '--' }}</div>
          </div>

          <div class="title">责任信息</div>
          <div class="part flex">
            <div class="biaoti">负责人:</div>
            <div class="cont">张小强 13328873032</div>
          </div>

          <!-- 实时数据 -->
          <div v-if="props.ifReal">
            <!-- 有满管、溢流风险时推送消息 -->
            <div class="part flex" v-if="realData.z >= (pipeDetail.pipelineDiameterTemp || '2')">
              <div class="biaoti">
                <el-button type="warning" @click="dialogShow = true">有满管风险,通知相关责任人进行处理</el-button>
              </div>
            </div>
            <div class="part flex" v-if="realData.z >= (pipeDetail.bottomBuriedDepthTemp || '2')">
              <div class="biaoti">
                <el-button type="warning" @click="dialogShow = true">有溢流风险,通知相关责任人进行处理</el-button>
              </div>
            </div>
          </div>

          <!-- 历史数据 -->
          <div v-if="!props.ifReal">
            <div class="part flex" v-if="realData.z >= (pipeDetail.pipelineDiameterTemp || '2')">
              <div class="biaoti" @click="dialogShow = true"><el-button type="warning">已短信通知相关责任人进行处理</el-button></div>
            </div>
          </div>
        </div>
      </div>
      <!-- 监测数据 -->
      <div class="pipeMonitor" v-if="tabActive == 2">
        <div class="selectToolList">
          <el-date-picker
            v-model="pipeTime"
            type="daterange"
            value-format="YYYY-MM-DD"
            start-placeholder="开始时间"
            end-placeholder="结束时间"
            style="width: 240px"
            :clearable="false"
          />
          <el-button type="warning" @click="changePipeDate" style="margin: -4px 0px 0px 8px">搜索</el-button>
        </div>
        <div id="monitorPipe" v-loading="pipeLoading"></div>
      </div>

      <!-- 发送短信给城管局相关人员 -->
      <el-dialog v-model="dialogShow" title="监测报警反馈" width="600px" append-to-body>
        <el-form :model="formData" label-width="100px" :rules="formRules">
          <el-form-item label="负责人:" prop="name">
            <el-input clearable v-model="formData.name" placeholder="请输入负责人"></el-input>
          </el-form-item>
          <el-form-item label="负责人电话:" prop="phone">
            <el-input clearable v-model="formData.phone" max-length="11" placeholder="请输入负责人电话"></el-input>
          </el-form-item>
          <el-form-item label="短信预览:" prop="content">
            <el-input type="textarea" disabled :rows="4" v-model="formData.content" placeholder=""></el-input>
          </el-form-item>
          <el-form-item>
            <el-button type="warning" icon="Phone" @click="dialogShow = false">发送短信</el-button>
          </el-form-item>
        </el-form>
      </el-dialog>
    </div>
  </div>
</template>

<script setup>
import chartOption from '@/components/Echarts/pieChart_1.js';
import * as echarts from 'echarts';
import { graphicReport, realtimeDataLatest, getStationDetail } from '@/api/dataAnalysis/syntherticData';
import { nextTick } from 'vue';

const { proxy } = getCurrentInstance();
const tabActive = ref('1');
const pipeTime = ref([proxy.moment(new Date()).subtract(1, 'days').format('YYYY-MM-DD'), proxy.moment().format('YYYY-MM-DD')]);
const realData = ref({});
const pipeDetail = ref({});
const pipeLoading = ref(true);
const valIndex = ref(0);
const dialogShow = ref(false);
const waterHeight = ref(0);
const formData = ref({
  name: '李文峰',
  phone: '13837899917',
  content: '',
});
const formRules = ref({
  name: [{ required: true, message: '请输入负责人', trigger: 'blur' }],
  phone: [{ required: true, message: '请输入负责人电话', trigger: 'blur' }],
});

const props = defineProps({
  pipeParams: {
    type: Object,
  },
  ifReal: {
    type: Boolean,
  },
});

// tab切换
function changeTab(val) {
  if (val == 2) {
    setTimeout(() => {
      initPipeChart();
    });
  }
}
// 监测数据日期搜索
function changePipeDate() {
  initPipeChart();
}

//管网监测趋势图
let pipeChart = null;
const initPipeChart = async () => {
  pipeChart && pipeChart.dispose();
  pipeChart = echarts.init(document.getElementById('monitorPipe'));
  let params = {
    startTime: pipeTime.value[0],
    endTime: pipeTime.value[1],
    stCode: props.pipeParams.stCode,
  };
  pipeLoading.value = true;
  //管网监测值
  let res = await graphicReport(params);
  if (res && res.code == 200) {
    let datas = res.data;
    chartOption.floodOneMapPipeSupervise.xAxis[0].data = datas.propertyMonitorXList;
    chartOption.floodOneMapPipeSupervise.yAxis[0].name = '水深(m)';
    chartOption.floodOneMapPipeSupervise.yAxis[1].name = '雨量(mm)';

    chartOption.floodOneMapPipeSupervise.legend.data = ['水深', '雨量'];
    chartOption.floodOneMapPipeSupervise.series[0].name = '水深';
    chartOption.floodOneMapPipeSupervise.series[0].data = datas.propertyMonitorList[0].ylist;
  }

  // 雨量站数据
  let params2 = {
    startTime: pipeTime.value[0],
    endTime: pipeTime.value[1],
    stCode: pipeDetail.value.referRainStCode,
  };
  let res2 = await graphicReport(params2);
  if (res2 && res2.code == 200) {
    let datas = res2.data;
    chartOption.floodOneMapPipeSupervise.series[1].data = datas.propertyMonitorList[0].ylist;
    chartOption.floodOneMapPipeSupervise.yAxis[1].max = Math.max(...datas.propertyMonitorList[0].ylist) + 0.5;
    chartOption.floodOneMapPipeSupervise.series[1].name = '雨量';
    chartOption.floodOneMapPipeSupervise.series[1].type = 'bar';
    chartOption.floodOneMapPipeSupervise.series[1].barWidth = '10';
    chartOption.floodOneMapPipeSupervise.yAxis[1].inverse = true; //翻转
    chartOption.floodOneMapPipeSupervise.yAxis[1].nameLocation = 'start'; //坐标轴名称显示位置
    if (datas.propertyMonitorXList.length > 0) {
      chartOption.floodOneMapPipeSupervise.graphic.invisible = true; //暂无数据
    } else {
      chartOption.floodOneMapPipeSupervise.graphic.invisible = false; //暂无数据
    }
    // 设置鼠标滚轮放大缩小展示数据区间
    chartOption.floodOneMapPipeSupervise.dataZoom = [
      { type: 'inside', startValue: datas.propertyMonitorXList[datas.propertyMonitorXList.length - 48] },
    ];
  }
  pipeChart.clear();
  pipeChart.setOption(chartOption.floodOneMapPipeSupervise);
  pipeLoading.value = false;
};

// 获取管网详情实时数据
function getDetailData() {
  // 实时数据
  realtimeDataLatest(props.pipeParams.stCode).then(res => {
    realData.value = res.data;
    getWaterHeight();
  });
}

// 获取管网详情某一天数据
async function getHistoryData() {
  let params = {
    startTime: localStorage.getItem('setRainDateKF'),
    endTime: localStorage.getItem('setRainDateKF'),
    stCode: props.pipeParams.stCode,
  };
  pipeLoading.value = true;
  //管网监测值
  let res = await graphicReport(params);
  if (res && res.code == 200) {
    let datas = res.data;
    // 取最大的值
    let max = Math.max(...nameToData(datas.propertyMonitorList, '水位'));
    valIndex.value = nameToData(datas.propertyMonitorList, '水位').findIndex(item => {
      return item == max;
    });
    realData.value.z = nameToData(datas.propertyMonitorList, '水位')[valIndex.value];
    realData.value.va = nameToData(datas.propertyMonitorList, '流速')[valIndex.value];
    realData.value.turb = nameToData(datas.propertyMonitorList, 'SS')[valIndex.value];
    realData.value.tt = datas.propertyMonitorXList[valIndex.value];
    realData.value.stName = datas.propertyMonitorList[0].stName;
    getWaterHeight();
  }
}
// 公共方法,根据监测名称来匹配对应的数值
function nameToData(data, name) {
  let arr = data.filter(item => item.monitorPropertyName == name);
  let lists = arr[0] ? arr[0].ylist : [];
  return lists;
}

// 获取站点详情
function getStationData() {
  getStationDetail(props.pipeParams.id).then(res => {
    pipeDetail.value = res.data;
  });
}

// 水深高度
function getWaterHeight() {
  setTimeout(() => {
    // 水深高度判断 非满管  满管溢流
    if (realData.value.z > pipeDetail.value.bottomBuriedDepthTemp) {
      waterHeight.value = 390;
    } else if (realData.value.z <= pipeDetail.value.pipelineDiameterTemp) {
      waterHeight.value = (140 * realData.value.z) / pipeDetail.value.pipelineDiameterTemp;
    } else if (realData.value.z > pipeDetail.value.pipelineDiameterTemp) {
      // 满管溢流
      waterHeight.value =
        140 +
        (250 * (realData.value.z - pipeDetail.value.pipelineDiameterTemp)) /
          (pipeDetail.value.bottomBuriedDepthTemp - pipeDetail.value.pipelineDiameterTemp);
    }
  });
}

onMounted(() => {
  getStationData();
  // 项目建设中需要获取某一天的监测数据,排水防涝里面获取实时数据
  if (props.ifReal) {
    getDetailData();
  } else {
    pipeTime.value = [localStorage.getItem('setRainDateKF'), localStorage.getItem('setRainDateKF')];
    getHistoryData();
  }

  // 短信内容
  setTimeout(() => {
    formData.value.content =
      '【开封海绵办】在' +
      realData.value.stName +
      ',时间:' +
      realData.value.tt +
      ',监测到水深为' +
      realData.value.z +
      '米,管网直径为' +
      (pipeDetail.value.pipelineDiameterTemp || '--') +
      '米,发生了满管溢流风险,请及时前往查看并做好处理措施。';
  }, 1500);
});
</script>

<style lang="scss" scoped>
// prettier-ignore
.pipeMonitorDetail {
  width: 100%;
  .content {
    height: 600PX;
    .pipePou{
      .leftP{
        width:530PX;
        height: 570PX;
        background: url('@/assets/newImgs/HMScreen/pipe.gif') no-repeat;
        background-size:100% 100%;
        position:relative;
        .water{
          position:absolute;
          bottom:50PX;
          left:0px;
          z-index: 10;
          width:530PX;
          height: 128PX;
        }
        .part{
          background: #0874EF;
          border-radius: 12px;
          padding:0px 10px;
          height: 26px;
          line-height: 26px;
          font-family: Source Han Sans CN;
          font-weight: 400;
          font-size: 16px;
          color: #FFFFFF;
          text-align: center
        }
        .partW{
          position:absolute;
          bottom:190PX;
          left:60px;
          z-index: 10;
        }
        .partJ{
          position:absolute;
          top:175PX;
          left:325px;
          z-index: 20;
        }
        .partL{
          position:absolute;
          bottom:190PX;
          left:325px;
          z-index: 10;
        }
        .equipA{
          position:absolute;
          bottom:60PX;
          left:30px;
          z-index: 15;
          width:470PX;
          height: 339PX;
        }
        
      }
      .rightP{
        margin-left:30px;
        color: #fff;
        .title{
          border-left:5px solid #67BCFA;
          padding-left:8px;
          font-size: 16px;
          font-weight: 600;
          margin-top:20px;
        }
        .part{
          margin:15px 0px 10px 10px;
          color: #C8DBE0;
          font-size: 15px;
          .biaoti{
            width:100px;
          }
        }
      }
    }
    #monitorPipe {
      width: 100%;
      height: 520px;
      margin-top: 10px;
    }
  }
}
</style>