Newer
Older
ganzhou-feidu / src / pages / ywts / cszl / gd / gdPop.vue
wangxitong on 11 Sep 7 KB Default Changelist?
<template>
  <div class="bottom">
    <i class="el-icon-close close-pop" @click="$emit('close')"/>
    <div class="block" style="padding: 10px;width: 33%">
      <div style="display: flex;flex-wrap: wrap;flex-direction: row;justify-content: center;flex-wrap: wrap">
        <div class="num" style="text-align: left;width:100%;font-size: 18px;font-weight: bold">{{ gdInfo.name }}</div>
        <div class="num" style="color: #B3F3F6;width:50%;word-break: break-all;text-align: left;">类别:<span style="font-weight: bold">{{gdInfo.typename}}</span></div>
        <div class="num" style="color: #B3F3F6;width:50%;word-break: break-all;text-align: right;">状态:<span style="font-weight: bold">{{ gdInfo.statusname }}</span></div>
        <div class="num" style="color: #B3F3F6;width:100%;word-break: break-all;text-align: left;">位置:<span>{{ gdInfo.location }}</span></div>
        <div class="item" style="width: 33%">
          <el-image :src="require('@/assets/images/function/教育/专项数据看板图标/事件总数.png')" class="base-map-image" mode="fill" />
          <div class="item-text">
            <div class="num">{{gdInfo.casetotal}}<span class="unit">件</span></div>
            <div style="color: #B3F3F6;">事件总数</div>
          </div>
        </div>
        <div class="item" style="width: 33%">
          <el-image :src="require('@/assets/images/function/教育/专项数据看板图标/点位在线率.png')" class="base-map-image" mode="fill" />
          <div class="item-text">
            <div class="num">{{gdInfo.casefinishrate}}<span class="unit">%</span></div>
            <div style="color: #B3F3F6;">事件完结率</div>
          </div>
        </div>
        <div class="item" style="width: 33%">
          <el-image :src="require('@/assets/images/function/教育/专项数据看板图标/今日事件数.png')" class="base-map-image" mode="fill" />
          <div class="item-text">
            <div class="num">{{gdInfo.todaytotal}}<span class="unit">件</span></div>
            <div style="color: #B3F3F6;">今日事件数</div>
          </div>
        </div>
        <div class="item">
          <el-image :src="require('@/assets/images/function/教育/专项数据看板图标/监控点位.png')" class="base-map-image" mode="fill" />
          <div class="item-text">
            <div class="num">{{gdInfo.devicenum}}<span class="unit"></span></div>
            <div style="color: #B3F3F6;">监控点位</div>
          </div>
        </div>
        <div class="item">
          <el-image :src="require('@/assets/images/function/教育/专项数据看板图标/已部署点位.png')" class="base-map-image" mode="fill" />
          <div class="item-text">
            <div class="num">{{gdInfo.alreadynum}}<span class="unit"></span></div>
            <div style="color: #B3F3F6;">已部署点位</div>
          </div>
        </div>
        <div class="item">
          <el-image :src="require('@/assets/images/function/教育/专项数据看板图标/点位在线率.png')" class="base-map-image" mode="fill" />
          <div class="item-text">
            <div class="num">{{gdInfo.onlinerate}}<span class="unit"></span></div>
            <div style="color: #B3F3F6;">点位在线率</div>
          </div>
        </div>
        <div class="item">
          <el-image :src="require('@/assets/images/function/教育/专项数据看板图标/人员总数.png')" class="base-map-image" mode="fill" />
          <div class="item-text">
            <div class="num">{{gdInfo.person}}<span class="unit">人</span></div>
            <div style="color: #B3F3F6;">人数总数</div>
          </div>
        </div>
      </div>
    </div>
    <div class="block">
      <div :style="{backgroundImage:'url('+titleImg+')'}" class="title">人员年龄分析</div>
      <person-bar style="flex:1;" ref="personBar"/>
    </div>
<!--    <div class="block">-->
<!--      <div :style="{backgroundImage:'url('+titleImg+')'}" class="title">近1月事件类型分析</div>-->
<!--      <case-pie style="flex:1;" ref="casePie"/>-->
<!--    </div>-->
    <div class="block">
      <div :style="{backgroundImage:'url('+titleImg+')'}" class="title">近1年事件完结分析</div>
      <case-line-bar style="flex:1;" ref="caseLineBar"/>
    </div>
    <div class="block">
      <div :style="{backgroundImage:'url('+titleImg+')'}" class="title">近1年教育培训得分排行</div>
      <edu-line-bar style="flex:1;" ref="eduLineBar"/>
    </div>
    <div class="block">
      <div :style="{backgroundImage:'url('+titleImg+')'}" class="title">近1年工地综合得分排行</div>
      <score-line-bar style="flex:1;" ref="scoreLineBar"/>
    </div>
  </div>
</template>

<script>


import PersonBar from "./components/personBar";
import CasePie from "./components/casePie";
import CaseLineBar from "./components/caseLineBar";
import EduLineBar from "./components/eduLineBar";
import ScoreLineBar from "./components/scoreLineBar";
import {getGdPointInfo} from "../../../../api/ywts/cszl/gd";

export default {
  name: 'GdPop',
  components: {ScoreLineBar, EduLineBar, CaseLineBar, CasePie, PersonBar},
  data() {
    return {
      titleImg: require('@/assets/images/popup/title.png'), // 背景图片
      titleAll: require('@/assets/images/popup/title-all.png'),// 背景图片
      list: ['', '', '', ''],
      gdInfo: {}
    }
  },
  methods: {
    initData(item) {
      this.gdInfo = item
      getGdPointInfo(item.id).then(res => {
        if(res.code === 200) {
          this.gdInfo = { ...res.data.value[0], ...this.gdInfo }
        }
      })
      this.$refs.personBar.fetchData(item.id)
      // this.$refs.casePie.fetchData(item.id)
      this.$refs.caseLineBar.fetchData(item.id)
      this.$refs.eduLineBar.fetchData(item.id)
      this.$refs.scoreLineBar.fetchData(item.id)
    }
  }
}
</script>

<style rel="stylesheet/scss" lang="scss" scoped>

.bottom{
  z-index: 111111111111;
  width: 100%;
  height: 250px;
  position: absolute;
  bottom: 10px;
  left: 0px;
  display: flex;
  overflow: hidden;
  padding: 0px 0px;
  .block{
    flex: 1;
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    background: linear-gradient(to top left, rgba(5, 30, 61, 0.62), #0D3F7E9D);
    border-radius: 5px;
    box-shadow: 4px 4px 40px rgba(0, 0, 0, .05);
    border-color: rgba(0, 0, 0, .05);
    margin: 0px 5px;
    flex-direction: column;
  }
  .block1{
    width: 500px;
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    background: linear-gradient(to top left, rgba(5, 30, 61, 0.62), #0D3F7E9D);
    border-radius: 5px;
    box-shadow: 4px 4px 40px rgba(0, 0, 0, .05);
    border-color: rgba(0, 0, 0, .05);
    margin: 0px 10px;
    flex-direction: column;
  }
  .title{
    text-shadow: 0 0 5px #d1ffff;
    height: 35px;
    float: left;
    text-align: left;
    background-repeat: no-repeat;
    -webkit-background-size: 100% 100%;
    background-size: 100% 100% !important;
    color: white;
    font-weight: bold;
    padding-top: 4px;
    padding-left: 30px;
    font-family: 黑体;
    letter-spacing: 1px;
  }
  .item-text{
    text-shadow: 0 0 2px #d1ffff;
    flex: 1;
    font-weight: bold;
    text-align: center;
    font-size: 18px;
  }
  .base-map-image{
    width: 60px;
    height: 60px;
  }
  .num{
    text-shadow: 0 0 5px #ffb441;
    color: #ffb441;
    font-size: 20px;
    padding-top: 2px;
  }
  .unit{
    color: #B3F3F6;
    font-size: 14px;
    margin-left: 1px;
  }
  .item{
    width: 25%;
    height: 32%;
    display: flex;
    justify-content: left;
    align-items: center;
  }
}
</style>