Newer
Older
KaiFengPC / src / views / floodSys / floodOneMap / waterLeverAlongRiner.vue
@zhangdeliang zhangdeliang on 27 Jun 2 KB update
<template>
  <!-- 断面监测弹窗 -->
  <div class="waterLeverEchart" v-show="allData.popupShow">
    <div class="title">
      <div class="titleName">{{ allData.dataList['名称'] }}</div>
      <div class="closePopup">
        <el-icon :size="18" @click="closePopup"><Close /></el-icon>
      </div>
    </div>
    <div class="dividerLine"></div>
    <div id="chartWaterLevel" style="height: 200px"></div>
  </div>
</template>

<script setup name="waterLeverEchart">
import bus from '@/bus';
import { nextTick } from 'vue';
import chartOption from '@/components/Echarts/pieChart_1.js';
import * as echarts from 'echarts';
const allData = reactive({
  popupShow: false,
  dataList: {},
});

const closePopup = () => {
  allData.popupShow = false;
};
// 积水点势折线图
let chartPopupWaterLevel = null;
const initEchartsWater = () => {
  if (!!chartPopupWaterLevel) chartPopupWaterLevel.dispose();
  chartPopupWaterLevel = echarts.init(document.getElementById('chartWaterLevel'));
  chartPopupWaterLevel.clear();
  chartPopupWaterLevel.setOption(chartOption.floodOneMapWaterLevel);
};

onMounted(() => {
  bus.on('closeCommonPopup', closeCommonPopup => {
    allData.popupShow = closeCommonPopup;
  });
  bus.on('popupDuanMianData', data => {
    console.log(data);
    allData.popupShow = data.popupShow;
    let newName = `${data.popupInfo['名称'].split('断')[0]}沿程水位`;
    allData.dataList = data.popupInfo;
    allData.dataList['名称'] = newName;
    nextTick(() => {
      initEchartsWater();
    });
  });
});
onBeforeUnmount(() => {
  bus.off('popupDuanMianData');
  bus.off('closeCommonPopup');
});
</script>
<style lang="scss">
.waterLeverEchart {
  width: 850px;
  height: 250px;
  position: absolute;
  bottom: 8%;
  left: 16%;
  background: #00314e;
  border: 1px solid #094065;
  z-index: 115;
  .title {
    margin-top: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    .titleName {
      display: flex;
      align-items: center;
      height: 22px;
      font-size: 16px;
      font-family: PingFang SC;
      font-weight: 400;
      color: #ccf1ff;
      line-height: 22px;
      &:before {
        display: block;
        content: '';
        width: 3px;
        height: 16px;
        background: #00d1ff;
        margin-right: 10px;
      }
    }
    .closePopup {
      margin-right: 20px;
      height: 22px;
      cursor: pointer;
    }
  }
  .dividerLine {
    height: 2px;
    border: 1px;
    margin: 0px 0 10px 0px;
    background: linear-gradient(90deg, rgba(0, 115, 165, 0) 0.79%, #0073a5 20.43%, #0073a5 82.43%, rgba(0, 115, 165, 0) 100%);
  }
}
</style>