¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <div class="page"> |
| | | <div> |
| | | <div class="form-card"> |
| | | <el-form :model="queryParams" ref="queryRef" :inline="true"> |
| | | <el-form-item label="æé´" prop="timeType"> |
| | | <el-select |
| | | v-model="queryParams.timeType" |
| | | placeholder="æé´" |
| | | clearable |
| | | style="width: 120px" |
| | | @change="handleTimeType" |
| | | > |
| | | <el-option v-for="dict in period" :key="dict.value" :label="dict.label" :value="dict.value" /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="æ¶é´" prop="dataTime"> |
| | | <el-date-picker |
| | | v-model="queryParams.dataTime" |
| | | :type="queryParams.timeType == 'YEAR' ? 'year' : queryParams.timeType == 'MONTH' ? 'month' : 'date'" |
| | | :format=" |
| | | queryParams.timeType == 'YEAR' ? 'YYYY' : queryParams.timeType == 'MONTH' ? 'YYYY-MM' : 'YYYY-MM-DD' |
| | | " |
| | | value-format="YYYY-MM-DD" |
| | | placeholder="æ¶é´" |
| | | style="width: 100%" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item> |
| | | <el-button type="primary" icon="Search" @click="handleQuery"> æç´¢ </el-button> |
| | | </el-form-item> |
| | | <!-- <el-form-item> |
| | | <el-button type="primary" icon="Download" @click="handleExport"> å¯¼åº </el-button> |
| | | </el-form-item> --> |
| | | </el-form> |
| | | </div> |
| | | <div class="table-bg-style"> |
| | | <div class="table-box theme-dark-mt20" style=""> |
| | | <el-table :data="tableData" v-loading="loading"> |
| | | <el-table-column label="æ¶é´" prop="dateCode" align="center" width="160" /> |
| | | <el-table-column label="æ»è´¹ç¨(å
)" prop="total" align="center" width="120" /> |
| | | <el-table-column :label="col.energyName" v-for="(col, index) in columns" :key="index" align="center"> |
| | | <el-table-column :prop="'energyTotal' + col.energyType" label="æ¶èé" min-width="120" align="center" /> |
| | | <el-table-column :prop="'costTotal' + col.energyType" label="è´¹ç¨ï¼å
ï¼" min-width="120" align="center" /> |
| | | </el-table-column> |
| | | </el-table> |
| | | </div> |
| | | </div> |
| | | <div class="charts-view" v-loading="loading"> |
| | | <el-row :gutter="2" class="" v-for="item in chartDataList" :key="item.energyType"> |
| | | <el-col :span="12"> |
| | | <BaseCard :title="item.costLabel + '(å
)'"> |
| | | <div class=""> |
| | | <LineChart |
| | | :ref="'LineChartCostRef' + item.energyType" |
| | | :domId="'costDom_' + item.energyType" |
| | | :chartData="{ |
| | | title: item.costLabel, |
| | | chartType: 'line', |
| | | xAxis: item.costKeyList, |
| | | series: [ |
| | | { |
| | | name: item.costLabel, |
| | | data: item.costValueList, |
| | | markPoint: { |
| | | data: [ |
| | | { type: 'max', name: 'Max' }, |
| | | { type: 'min', name: 'Min' }, |
| | | ], |
| | | }, |
| | | }, |
| | | ], |
| | | }" |
| | | /> |
| | | </div> |
| | | </BaseCard> |
| | | </el-col> |
| | | <el-col :span="12"> |
| | | <BaseCard :title="item.accumulationLabel + '(' + item.energyUnit + ')'"> |
| | | <div class=""> |
| | | <LineChart |
| | | :ref="'LineChartaccumulationRef' + item.energyType" |
| | | :domId="'accumulationDom_' + item.energyType" |
| | | :chartType="'bar'" |
| | | :chartData="{ |
| | | title: item.accumulationLabel, |
| | | chartType: 'bar', |
| | | xAxis: item.accumulationKeyList, |
| | | series: [ |
| | | { |
| | | name: item.accumulationLabel, |
| | | color: '#19be6b', |
| | | data: item.accumulationValueList, |
| | | markPoint: { |
| | | data: [ |
| | | { type: 'max', name: 'Max' }, |
| | | { type: 'min', name: 'Min' }, |
| | | ], |
| | | }, |
| | | }, |
| | | ], |
| | | }" |
| | | /> |
| | | </div> |
| | | </BaseCard> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </template> |
| | | <script setup name="loadAnalysis"> |
| | | import { listEnergyCostTrend, listEnergyCostTrendDetail } from "@/api/cost/api.js" |
| | | import LineChart from "@/components/Echarts/LineChart.vue" |
| | | import { deepClone } from "@/utils/index.js" |
| | | const { proxy } = getCurrentInstance() |
| | | import { useRoute } from "vue-router" |
| | | const { period } = proxy.useDict("period") |
| | | import useSettingsStore from "@/store/modules/settings" |
| | | const settingsStore = useSettingsStore() |
| | | watch( |
| | | () => settingsStore.sideTheme, |
| | | (val) => { |
| | | getList() |
| | | } |
| | | ) |
| | | const activeKey = ref(1) |
| | | const loading = ref(false) |
| | | const tableData = ref([]) |
| | | const columns = ref([]) |
| | | const detailData = ref({}) |
| | | const lineChartData = ref({}) |
| | | const chartDataList = ref([]) |
| | | const data = reactive({ |
| | | queryParams: { |
| | | nodeId: null, |
| | | nodeName: null, |
| | | timeType: null, |
| | | dataTime: null, |
| | | meterId: "", |
| | | modelCode: useRoute().query.modelCode, |
| | | }, |
| | | query: { ...useRoute().query }, |
| | | }) |
| | | const { queryParams, query } = toRefs(data) |
| | | |
| | | function handleTimeType(e) { |
| | | queryParams.value.timeType = e |
| | | queryParams.value.dataTime = proxy.dayjs(new Date()).format("YYYY-MM-DD") |
| | | getTableData() |
| | | getList() |
| | | } |
| | | |
| | | function getTableData() { |
| | | let params = { |
| | | ...queryParams.value, |
| | | nodeId: queryParams.value.nodeId, |
| | | timeType: queryParams.value.timeType, |
| | | timeCode: queryParams.value.dataTime, |
| | | meterId: queryParams.value.meterId, |
| | | } |
| | | if (queryParams.value.timeType == "DAY") { |
| | | params.timeCode = proxy.dayjs(new Date(queryParams.value.dataTime)).format("YYYY-MM-DD") |
| | | } else if (queryParams.value.timeType == "MONTH") { |
| | | params.timeCode = proxy.dayjs(new Date(queryParams.value.dataTime)).format("YYYY-MM") |
| | | } else if (queryParams.value.timeType == "YEAR") { |
| | | params.timeCode = proxy.dayjs(new Date(queryParams.value.dataTime)).format("YYYY") |
| | | } |
| | | listEnergyCostTrend(params).then((res) => { |
| | | if (res.code === 200) { |
| | | let data = deepClone(res.data.itemList || []) |
| | | // è¡¨å¤´çæ°æ® |
| | | if (data.length > 0 && data[0].itemList.length > 0) { |
| | | let energyList = data[0].itemList |
| | | columns.value = energyList.map((item) => { |
| | | return { |
| | | energyName: item.energyName, |
| | | energyType: item.energyType, |
| | | } |
| | | }) |
| | | } |
| | | tableData.value = data.map((item) => { |
| | | let tempObj = {} |
| | | item.itemList.forEach((element) => { |
| | | tempObj["energyTotal" + element.energyType] = element.accumulation |
| | | tempObj["costTotal" + element.energyType] = element.cost |
| | | }) |
| | | return { |
| | | ...item, |
| | | ...tempObj, |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | } |
| | | const LineChartRef = ref() |
| | | function getList() { |
| | | loading.value = true |
| | | let params = { |
| | | ...queryParams.value, |
| | | nodeId: queryParams.value.nodeId, |
| | | timeType: queryParams.value.timeType, |
| | | timeCode: queryParams.value.dataTime, |
| | | meterId: queryParams.value.meterId, |
| | | } |
| | | if (queryParams.value.timeType == "DAY") { |
| | | params.timeCode = proxy.dayjs(new Date(queryParams.value.dataTime)).format("YYYY-MM-DD") |
| | | } else if (queryParams.value.timeType == "MONTH") { |
| | | params.timeCode = proxy.dayjs(new Date(queryParams.value.dataTime)).format("YYYY-MM") |
| | | } else if (queryParams.value.timeType == "YEAR") { |
| | | params.timeCode = proxy.dayjs(new Date(queryParams.value.dataTime)).format("YYYY") |
| | | } |
| | | listEnergyCostTrendDetail(params) |
| | | .then((res) => { |
| | | if (res.code == 200) { |
| | | loading.value = false |
| | | chartDataList.value = res.data |
| | | } |
| | | }) |
| | | .catch(() => { |
| | | loading.value = false |
| | | }) |
| | | } |
| | | // ç¢³ææ¾ç®¡ç-ç¢³ææ¾éæ ¸ç®-æç´¢ |
| | | function handleQuery() { |
| | | getTableData() |
| | | getList() |
| | | } |
| | | // ç¢³ææ¾ç®¡ç-ç¢³ææ¾éæ ¸ç®-éç½® |
| | | function resetQuery() { |
| | | proxy.resetForm("queryRef") |
| | | queryParams.value.timeType = null |
| | | queryParams.value.dataTime = null |
| | | handleTimeType(period.value[0].value) |
| | | handleQuery() |
| | | } |
| | | // ç¢³ææ¾ç®¡ç-ç¢³ææ¾éæ ¸ç®-å¯¼åº |
| | | function handleExport() { |
| | | proxy.download( |
| | | "carbonEmission/export", |
| | | { |
| | | emissionType: "allType", |
| | | ...queryParams.value, |
| | | ...query.value, |
| | | }, |
| | | `${queryParams.value.nodeName}-ç¢³ææ¾éæ ¸ç®_${new Date().getTime()}.xlsx` |
| | | ) |
| | | } |
| | | |
| | | onMounted(() => { |
| | | setTimeout(() => { |
| | | handleTimeType(period.value[0].value) |
| | | }, 200) |
| | | }) |
| | | </script> |
| | | <style scoped lang="scss"> |
| | | @import "@/assets/styles/page.scss"; |
| | | |
| | | .table-box { |
| | | margin-top: 0; |
| | | :deep .el-table--border .el-table__inner-wrapper:after { |
| | | height: 0; |
| | | } |
| | | |
| | | :deep .el-table--border:after { |
| | | width: 0; |
| | | } |
| | | |
| | | :deep .el-table--border:before { |
| | | width: 0; |
| | | } |
| | | |
| | | :deep .el-table__border-left-patch { |
| | | background: transparent; |
| | | } |
| | | |
| | | :deep .el-table--border .el-table__cell { |
| | | border-right: none; |
| | | } |
| | | } |
| | | |
| | | .charts-view { |
| | | width: 100%; |
| | | margin-top: 20px; |
| | | // padding: 0 30px; |
| | | } |
| | | .display-buttons { |
| | | display: flex; |
| | | justify-content: flex-end; |
| | | align-items: center; |
| | | margin-top: 16px; |
| | | margin-right: 16px; |
| | | .display-btn, |
| | | .active-display-btn { |
| | | width: 78px; |
| | | height: 34px; |
| | | background: #fff; |
| | | color: #409eff; |
| | | border: 2px solid #409eff; |
| | | border-radius: 4px; |
| | | margin-left: 10px; |
| | | text-align: center; |
| | | line-height: 31px; |
| | | font-size: 14px; |
| | | font-weight: 400; |
| | | cursor: pointer; |
| | | &:hover { |
| | | opacity: 0.9; |
| | | } |
| | | } |
| | | .active-display-btn { |
| | | background: #409eff; |
| | | color: #fff; |
| | | } |
| | | } |
| | | </style> |