Newer
Older
KaiFengPC / src / views / sponeScreen / evaluationKH / chanChuJiXiao.vue
@jimengfei jimengfei on 16 Oct 8 KB updata
<template>
  <!--  产出绩效 -->
  <div class="chanChuJiXiao">
    <div class="partTitleHM">
      产出绩效
      <div class="tabs flex">
        <div class="tabItem" v-for="item in tabList" :key="item.id" :class="{ active: curTab === item.id }" @click="tabClick(item)">
          {{ item.name }}
        </div>
      </div>
    </div>

    <div class="ConstrucClass">
      <div class="content">
        <div class="target flex flex-j-left flex-align-center">
          <div class="titles titlesmb">
            <div class="mbs">目标</div>
          </div>
          <div class="valsText" :title="quotaInfo.improveGoals">{{ quotaInfo.improveGoals }}</div>
        </div>
        <div class="measures flex flex-j-left flex-align-center">
          <div class="titles titlecs">
            <div class="mbs">措施</div>
          </div>
          <div class="valsText" :title="quotaInfo.reformMethod">{{ quotaInfo.reformMethod }}</div>
        </div>
        <el-table ref="table" :data="tableData" height="120">
          <el-table-column label="改造工程" prop="reformProjectName" show-overflow-tooltip />
          <el-table-column label="提升成效" prop="reformAchievement" show-overflow-tooltip />
        </el-table>

        <div class="achievements flex flex-align-center">
          <div class="titles titlecg">
            <div class="mbs">成果</div>
          </div>
          <div class="vals" :class="quotaInfo.isCompliance == '1' ? 'colors1' : 'colors2'">
            {{ quotaInfo.isCompliance == '1' ? '达标' : '不达标' }}
          </div>
        </div>
        <div class="bottom flex-v">
          <span v-for="item in quotaInfo.remarkData">{{ item }}</span>
        </div>
      </div>
    </div>
  </div>
</template>
<script setup>
import bus from '@/bus';
import { quotaCommomInfoList, hmyztQuotaDataList } from '@/api/sponeScreen/jxkh.js';
import kaifengFangHong from '@/assets/geojson/kaifeng/kaifengFangHong.json'; //防洪标准
import kaifengRainUse from '@/assets/geojson/kaifeng/kaifengRainUse.json'; //雨水利用
import kaifengTouShuiArea from '@/assets/geojson/kaifeng/kaifengTouShuiArea.json'; //透水面积
import kaifengNatureWater from '@/assets/geojson/kaifeng/kaifengNatureWater.json'; //天然水域
import kaifengShengHuoWS from '@/assets/geojson/kaifeng/kaifengShengHuoWS.json'; //生活污水
import kaifengBOD from '@/assets/geojson/kaifeng/kaifengBOD.json'; //进水BOD
import newfiberMapBoxVectorLayer from '@/views/sponeScreen/gisMF/mapboxVectorLayer.js';
import tuLi72X from '@/assets/newImgs/tuLi72X.png';

const { proxy } = getCurrentInstance();
const tabList = ref([
  { id: 'fhbz', name: '防洪标准' },
  { id: 'nlbz', name: '内涝标准' },
  { id: 'nlxc', name: '内涝消除' },
]);

const curTab = ref('fhbz');
const quotaInfo = ref({ isCompliance: 1 }); //改造措施数据
const tableData = ref([]);

const tabClick = item => {
  bus.emit('closeAllLayer');
  curTab.value = item.id;
  if (curTab.value == 'fhbz') {
    bus.emit('jhkhclick', 'fhbz');
    newfiberMapBoxVectorLayer.addGeojsonSymbol('kaifengFangHong', kaifengFangHong, tuLi72X, 20, 1); //图层名、图层geojson,图标,标注每行多少个字,行间距
    bus.emit('setIniteLayer', [
      {
        layername: 'waterLoging',
        show: true,
      },
      {
        layername: 'cesiumPaishuiArea2',
        show: true,
      },
    ]);
    newfiberMapbox.map.easeTo({
      center: [114.315, 34.852],
      zoom: 10.4,
    });
  } else if (curTab.value == 'nlbz') {
    bus.emit('jhkhclick', 'nlbz');
    if (newfiberMapbox.map.getLayer('waterLine')) {
      newfiberMapbox.map.removeLayer('waterLine');
      newfiberMapbox.map.removeLayer('waterLabel');
      newfiberMapbox.map.removeSource('waterLine');
      newfiberMapbox.map.removeSource('waterLabel');
    }
    if (newfiberMapbox.map.hasImage('kaifengFangHong')) {
      newfiberMapbox.map.removeImage('kaifengFangHong');
      newfiberMapBoxVectorLayer.removeByIds(['kaifengFangHong']);
    }
    bus.emit('setIniteLayer', [
      {
        layername: 'waterLoging',
        show: true,
      },
      {
        layername: 'cesiumPaishuiArea2',
        show: false,
      },
    ]);
    newfiberMapbox.map.easeTo({
      center: [114.315, 34.852],
      zoom: 10.4,
    });
  } else {
    bus.emit('jhkhclick', 'nlxc');
    if (newfiberMapbox.map.getLayer('waterLine')) {
      newfiberMapbox.map.removeLayer('waterLine');
      newfiberMapbox.map.removeLayer('waterLabel');
      newfiberMapbox.map.removeSource('waterLine');
      newfiberMapbox.map.removeSource('waterLabel');
    }
    bus.emit('setIniteLayer', [
      {
        layername: 'waterLoging',
        show: false,
      },
      {
        layername: 'cesiumPaishuiArea2',
        show: true,
      },
    ]);
    newfiberMapbox.map.easeTo({
      center: [114.315, 34.852],
      zoom: 10.4,
    });
  }
  getjb();
  getkhzn();
};

// 产出绩效公共指标信息
async function getjb() {
  let res = await quotaCommomInfoList({
    quotaCode: curTab.value,
  });
  if (res && res.code == 200) {
    let data = res.data;
    quotaInfo.value = data && data.length ? data[0] : {};
    quotaInfo.value.remarkData = quotaInfo.value.remark ? quotaInfo.value.remark.split(';') : [];
  }
}
// 产出绩效公共指标信息
async function getkhzn() {
  let res = await hmyztQuotaDataList({
    quotaType: curTab.value,
  });
  if (res && res.code == 200) {
    tableData.value = res.data;
    console.log('-----', tableData.value);
  }
}
//删除图层
const removeSelectedLayer = layerList => {
  layerList.forEach(element => {
    if (newfiberMapbox.map.hasImage(element)) {
      newfiberMapbox.map.removeImage(element);
      newfiberMapBoxVectorLayer.removeByIds([element]);
    }
  });
};
onMounted(() => {
  getjb();
  getkhzn();
});
</script>
<style lang="scss" scoped>
.chanChuJiXiao {
  width: 460px;

  .ConstrucClass {
    background: rgba(8, 75, 125, 1);
    padding: 10px;
    margin-top: -3px;
    .content {
      width: 100%;
      height: 100%;

      .target,
      .measures,
      .achievements {
        background: linear-gradient(0deg, rgba(26, 109, 255, 0.2) 0%, rgba(40, 193, 250, 0.2) 100%) !important;
        border-radius: 3px;
        width: 100%;
        height: 40px;
        padding: 0 10px;

        .titles {
          width: 50px;
          font-size: 16px;
          color: #ffffff;
          position: relative;
          height: 20px;
          margin-top: 15px;

          .mbs {
            position: absolute;
            top: -10px;
            left: 5px;
          }
        }

        .titlesmb {
          background: url('@/assets/newImgs/HMScreen/jxkh/mb.png') no-repeat;
        }

        .titlecs {
          background: url('@/assets/newImgs/HMScreen/jxkh/cs.png') no-repeat;
        }

        .titlecg {
          background: url('@/assets/newImgs/HMScreen/jxkh/cg.png') no-repeat;
        }
      }

      .measures {
        margin-top: 5px;
      }

      .valsText {
        width: 350px;
        color: #58d6ff;
        margin-left: 10px;
        font-size: 14px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
      }

      .renovation {
        width: 100%;
        height: 78px;
        .renovationcons {
          height: 50px;
          color: #58d6ff;
          font-size: 14px;
          padding: 5px;

          .sy,
          .mj {
            width: 50%;
            text-align: center;
          }
        }
      }

      .achievements {
        font-family: Source Han Sans CN;
        font-size: 18px;
        margin-top: 10px !important;

        .vals {
          color: #00fe00 !important;
          margin-left: 20px;
        }
        .colors1 {
          color: #00fe00;
        }
        .colors2 {
          color: #ff5e66;
        }
      }

      .bottom {
        width: 100%;
        height: 50px;
        background: linear-gradient(0deg, rgba(26, 109, 255, 0.2) 0%, rgba(40, 193, 250, 0.2) 100%) !important;
        color: #58d6ff;
        font-size: 14px;
        padding: 5px;
        justify-content: flex-start;
        display: flex;
        overflow: auto;
      }
    }
  }

  .tabs {
    float: right;
    margin: 8px 40px 0px 0px;
    .tabItem {
      width: 78px;
      height: 24px;
      line-height: 24px;
      background: url('@/assets/newImgs/HMScreen/jxkh/normal.png') no-repeat;
      background-size: 100% 100%;
      margin-left: 10px;
      font-size: 14px;
      color: #ffffff;
      text-align: center;
      cursor: pointer;

      &:first-of-type {
        margin-left: 0;
      }

      &.active {
        background: url('@/assets/newImgs/HMScreen/jxkh/active.png') no-repeat;
        background-size: 100% 100%;
      }
    }
  }
}
</style>