<template> <div class="totalContant"> <div class="ns-form-title"> <div class="title"> <span>查询</span> <a-date-picker v-if="selectedTime" style="margin-left: 5%" valueFormat="YYYY" v-model:value="selectYear" @change="changeYear" picker="year" /> <a-date-picker v-else style="margin-left: 5%" valueFormat="YYYY-MM" v-model:value="selectMonth" @change="changeMonth" picker="month" /> </div> <div class="operation"> <div class="month" :style="monthStyles" @click="changeToMonth"><span>月</span></div> <div class="year" :style="yearStyles" @click="changeToYear"><span>年</span></div> </div> </div> <div class="contant"> <div class="chartsPart"> <template v-for="(item, index) in data" :key="index"> <div class="electricityConsumption"> <div :id="'ydlChart_' + index" style="height: 100%; width: 100%"></div> </div> </template> </div> <div class="tablePart"> <a-table :columns="columns" :data-source="data" bordered :pagination="false" :scroll="{ x: 1300, y: 300 }"> </a-table> </div> </div> </div> </template> <script lang="ts" setup> import { ref, defineExpose } from 'vue'; import dayjs, { Dayjs } from 'dayjs'; import * as echarts from 'echarts'; import { http } from '/nerv-lib/util/http'; import { carbonPlanning } from '/@/api/carbonEmissionFactorLibrary'; defineOptions({ energyType: 'all', // 与页面路由name一致缓存才可生效 }); const orgId = ref(''); const result = JSON.parse(sessionStorage.getItem('ORGID')!); orgId.value = result; const fetch = (api, params = { orgId }) => { return http.post(api, params); }; const selectYear = ref<Dayjs>(dayjs(new Date().getFullYear().toString())); const selectMonth = ref<Dayjs>(dayjs().startOf('year').month(0)); // 年/月切换 const monthStyles = ref('background: #f2f2f2'); const yearStyles = ref('background: #2778ff'); const selectedTime = ref(true); const changeMonth = () => { queryParams.value.yearMonth = selectMonth.value; getTableData(); }; const changeToMonth = () => { monthStyles.value = 'background: #2778ff'; yearStyles.value = 'background: #f2f2f2'; queryParams.value.yearAndMonth = 'month'; queryParams.value.yearMonth = selectMonth.value.format('YYYY-DD'); columns.value[2].title = '月份'; columns.value[2].dataIndex = 'yearMonth'; selectedTime.value = false; getTableData(); }; const changeYear = () => { queryParams.value.year = selectYear.value; getTableData(); }; const changeToYear = () => { monthStyles.value = 'background: #f2f2f2'; yearStyles.value = 'background: #2778ff'; queryParams.value.yearAndMonth = 'year'; delete queryParams.value.yearMonth; // queryParams.value.year = selectYear.value; columns.value[2].title = '年份'; columns.value[2].dataIndex = 'year'; selectedTime.value = true; getTableData(); }; // 用电量 const ydlChart = ref({}); let chartInstance: echarts.ECharts | null = null; const drawEcharts = () => { data.value.forEach((item, index) => { const chart = echarts.init(document.getElementById(`ydlChart_${index}`)!); const bottomColor = [ 'rgba(219, 222, 232, 1)', 'rgba(221, 226, 223, 1)', 'rgba(233, 228, 219, 1)', 'rgba(221, 216, 235, 1)', 'rgba(240, 228, 228, 1)', ]; const mianColor = [ 'rgba(24, 106, 255, 1)', 'rgba(58, 194, 127, 1)', 'rgba(249, 183, 50, 1)', 'rgba(120, 76, 212, 1)', 'rgba(255, 55, 103, 1)', ]; let point = parseInt(item.budgetAchievement.replace('%', '')); const option = { backgroundColor: 'transparent', title: [ { text: point + '%', x: 'center', y: '35%', textStyle: { fontSize: 14, fontWeight: 'normal', fontStyle: 'normal', }, }, { text: item.budgetAchievementName, x: 'center', y: '85%', textStyle: { fontSize: 14, fontWeight: 'normal', fontStyle: 'normal', }, }, ], series: [ { type: 'pie', radius: ['40%', '50%'], center: ['50%', '40%'], label: { normal: { show: false, }, }, data: [ { name: '', value: 100, itemStyle: { normal: { color: bottomColor[index], }, }, }, ], zlevel: 1, }, { name: 'main', type: 'pie', radius: ['38%', '55%'], center: ['50%', '40%'], data: [ { value: point, label: { show: true, position: 'center', fontSize: 40, }, labelLine: { show: false }, itemStyle: { normal: { color: mianColor[index], shadowBlur: 10, shadowColor: mianColor[index], }, }, }, { value: 100 - point, itemStyle: { normal: { color: 'transparent', }, }, }, ], zlevel: 2, }, ], }; chart.setOption(option); }); }; // 表格 const queryParams = ref({ orgId: orgId.value, year: selectYear.value.format('YYYY'), yearAndMonth: 'year', }); const getTableData = () => { fetch(carbonPlanning.whole, queryParams.value).then((res) => { data.value = res.data; setTimeout(() => { drawEcharts(); }, 500); }); }; const columns = ref([ { title: '序号', customRender: (text: any) => { return text.index + 1; }, }, { title: '名称', dataIndex: 'itemizeName', }, { title: '年份', dataIndex: 'year', }, { title: '计量单位', dataIndex: 'unitMeasurement', }, { title: '总实际用量', dataIndex: 'actualUsage', }, { title: '总预算量', dataIndex: 'budget', }, { title: '基准值', dataIndex: 'referenceValue', }, { title: '节能量', dataIndex: 'energyConservation', }, { title: '预算达成率', dataIndex: 'budgetAchievement', }, ]); const data = ref([]); getTableData(); defineExpose({ getTableData, }); </script> <style lang="less" scoped> .totalContant { height: 100%; padding: 12px; } :deep(.ant-tabs-content) { padding: 16px; } .ns-form-title { font-weight: bold; user-select: text; display: flex; justify-content: space-between; align-items: center; width: 100%; height: 5vh; .title { text-align: left; height: 32px; line-height: 32px; font-weight: bold; user-select: text; position: relative; padding-left: 9px; width: 50%; } .title::before { content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%); height: 13px; width: 3px; border-radius: 1px; background-color: #2778ff; } .operation { display: flex; margin-right: 10px; font-weight: 400; height: 70%; cursor: pointer; width: 10%; } .month { width: 70px; display: flex; align-items: center; justify-content: center; // background: #f2f2f2; } .year { width: 70px; display: flex; align-items: center; justify-content: center; // background: #2778ff; } } .contant { width: 100%; height: calc(100% - 5vh); .chartsPart { width: 100%; height: 35%; display: flex; justify-content: space-between; .electricityConsumption { width: 19%; height: 100%; background: rgba(39, 120, 255, 0.05); } } .tablePart { height: calc(65% - 20px); margin-top: 20px; } } </style>