|
|
|
@ -0,0 +1,779 @@
|
|
|
|
|
<template>
|
|
|
|
|
<el-dialog
|
|
|
|
|
title="数据展示"
|
|
|
|
|
:visible.sync="dialogVisible"
|
|
|
|
|
:fullscreen="true"
|
|
|
|
|
class="dataDialog"
|
|
|
|
|
>
|
|
|
|
|
<div class="dataReport">
|
|
|
|
|
<div class="reportTable">
|
|
|
|
|
<div class="reportHead">
|
|
|
|
|
<h3>数据展示</h3>
|
|
|
|
|
<div class="searchMain">
|
|
|
|
|
<el-form :inline="true" :model="formdata" class="demo-form-inline">
|
|
|
|
|
<el-form-item label="开始日期">
|
|
|
|
|
<el-date-picker
|
|
|
|
|
@change="changestartdate"
|
|
|
|
|
v-model="formdata.starttime"
|
|
|
|
|
:picker-options="pickerOptions"
|
|
|
|
|
:clearable="false"
|
|
|
|
|
type="date"
|
|
|
|
|
placeholder="开始日期"
|
|
|
|
|
:default-time="['00:00:00']"
|
|
|
|
|
>
|
|
|
|
|
</el-date-picker>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="结束日期">
|
|
|
|
|
<el-date-picker
|
|
|
|
|
@change="changeenddate"
|
|
|
|
|
v-model="formdata.endtime"
|
|
|
|
|
:clearable="false"
|
|
|
|
|
:picker-options="pickerOptions"
|
|
|
|
|
type="date"
|
|
|
|
|
:default-time="['23:59:59']"
|
|
|
|
|
placeholder="结束日期"
|
|
|
|
|
class="ml10"
|
|
|
|
|
>
|
|
|
|
|
</el-date-picker>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item>
|
|
|
|
|
<el-select v-model="formdata.dayValue" placeholder="请选择">
|
|
|
|
|
<el-option
|
|
|
|
|
v-for="item in dayOptions"
|
|
|
|
|
:key="item.value"
|
|
|
|
|
:label="item.label"
|
|
|
|
|
:value="item.value"
|
|
|
|
|
>
|
|
|
|
|
</el-option>
|
|
|
|
|
</el-select>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item>
|
|
|
|
|
<el-button
|
|
|
|
|
type="primary"
|
|
|
|
|
class="searchBtn"
|
|
|
|
|
@click="handleSearch"
|
|
|
|
|
>查询</el-button
|
|
|
|
|
>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
</el-form>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="reportContain">
|
|
|
|
|
<el-tabs
|
|
|
|
|
v-model="activeName"
|
|
|
|
|
type="border-card"
|
|
|
|
|
@tab-click="handleClick"
|
|
|
|
|
>
|
|
|
|
|
<el-tab-pane label="数据" name="dataTab">
|
|
|
|
|
<div class="dataTabHead">
|
|
|
|
|
<h3>{{ crrrentName }}</h3>
|
|
|
|
|
<div class="exportbtn">
|
|
|
|
|
<el-button
|
|
|
|
|
type="primary"
|
|
|
|
|
class="export"
|
|
|
|
|
@click="handleExport"
|
|
|
|
|
:disabled="tableData.length == 0"
|
|
|
|
|
>导出全部</el-button
|
|
|
|
|
>
|
|
|
|
|
<el-button
|
|
|
|
|
type="primary"
|
|
|
|
|
class="export"
|
|
|
|
|
@click="handleCurrentExport"
|
|
|
|
|
:disabled="tableData.length == 0"
|
|
|
|
|
>导出当前</el-button
|
|
|
|
|
>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="tableBox" v-loading="tableLoading">
|
|
|
|
|
<div class="leftTable">
|
|
|
|
|
<el-checkbox
|
|
|
|
|
:indeterminate="isIndeterminate"
|
|
|
|
|
v-model="checkAll"
|
|
|
|
|
@change="handleCheckAllChange"
|
|
|
|
|
>全选</el-checkbox
|
|
|
|
|
>
|
|
|
|
|
|
|
|
|
|
<el-checkbox-group
|
|
|
|
|
v-model="checkedList"
|
|
|
|
|
@change="handleCheckedCitiesChange"
|
|
|
|
|
>
|
|
|
|
|
<el-checkbox
|
|
|
|
|
v-for="item in optionList"
|
|
|
|
|
:label="item"
|
|
|
|
|
:key="item"
|
|
|
|
|
>{{ item }}</el-checkbox
|
|
|
|
|
>
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="rightTable">
|
|
|
|
|
<el-table
|
|
|
|
|
:data="tableData"
|
|
|
|
|
border
|
|
|
|
|
stripe
|
|
|
|
|
height="calc(100% - 40px)"
|
|
|
|
|
>
|
|
|
|
|
<!-- <el-table-column type="index" width="50"> </el-table-column> -->
|
|
|
|
|
<el-table-column
|
|
|
|
|
prop="acquisitionTime"
|
|
|
|
|
label="采集时间"
|
|
|
|
|
width="148"
|
|
|
|
|
>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column
|
|
|
|
|
min-width="120"
|
|
|
|
|
v-for="(column, index) in columns"
|
|
|
|
|
:key="index"
|
|
|
|
|
:label="
|
|
|
|
|
column.fieldDesc +
|
|
|
|
|
(column.unit == null ? '' : '(' + column.unit + ')')
|
|
|
|
|
"
|
|
|
|
|
:prop="column.field"
|
|
|
|
|
></el-table-column>
|
|
|
|
|
</el-table>
|
|
|
|
|
<div class="pageNation">
|
|
|
|
|
<el-pagination
|
|
|
|
|
@current-change="handleCurrentChange"
|
|
|
|
|
@size-change="handleSizeChange"
|
|
|
|
|
:current-page="page"
|
|
|
|
|
:page-size="pageSize"
|
|
|
|
|
:page-sizes="[20, 40, 100]"
|
|
|
|
|
layout="sizes, prev, pager, next, jumper,total"
|
|
|
|
|
:total="total"
|
|
|
|
|
>
|
|
|
|
|
</el-pagination>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</el-tab-pane>
|
|
|
|
|
<el-tab-pane label="图表" name="chartTab">
|
|
|
|
|
<div class="dataTabHead">
|
|
|
|
|
<h3>{{ crrrentName }}</h3>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="echartsBox">
|
|
|
|
|
<div
|
|
|
|
|
id="deviceEchart"
|
|
|
|
|
class="chartClass"
|
|
|
|
|
v-if="chartDataArr.total !== 0"
|
|
|
|
|
v-loading="chartLoading"
|
|
|
|
|
>
|
|
|
|
|
<lineChart :chartdata="chartDataArr"></lineChart>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<el-empty v-else description="暂无图表数据"></el-empty>
|
|
|
|
|
</div>
|
|
|
|
|
</el-tab-pane>
|
|
|
|
|
</el-tabs>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</el-dialog>
|
|
|
|
|
</template>
|
|
|
|
|
<script>
|
|
|
|
|
import { getTreeApi, getDetailApi, getexportApi } from "@/utils/api/index";
|
|
|
|
|
import lineChart from "./line";
|
|
|
|
|
export default {
|
|
|
|
|
components: { lineChart },
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
dialogVisible: false,
|
|
|
|
|
pickerOptions: {
|
|
|
|
|
disabledDate(date) {
|
|
|
|
|
return date.getTime() > Date.now(); // 禁用大于今天的日期
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
currentId: "", //选择的id
|
|
|
|
|
crrrentName: "",
|
|
|
|
|
formdata: {
|
|
|
|
|
dayValue: -1,
|
|
|
|
|
}, //查询定义的form数据
|
|
|
|
|
dayOptions: [
|
|
|
|
|
{
|
|
|
|
|
value: -1,
|
|
|
|
|
label: "全部数据",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
value: 1,
|
|
|
|
|
label: "每日最多1条",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
value: 2,
|
|
|
|
|
label: "每日最多2条",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
value: 4,
|
|
|
|
|
label: "每日最多4条",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
value: 6,
|
|
|
|
|
label: "每日最多6条",
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
activeName: "dataTab",
|
|
|
|
|
tableLoading: false, //loading
|
|
|
|
|
checkAll: true, //是否全选
|
|
|
|
|
optionList: [], //左侧check列表
|
|
|
|
|
checkedList: [], //选中
|
|
|
|
|
formTheadOptions: [],
|
|
|
|
|
isIndeterminate: false,
|
|
|
|
|
key: 1,
|
|
|
|
|
tableData: [], //表格数据
|
|
|
|
|
columns: [], //表头数据
|
|
|
|
|
page: 1, // 当前页数
|
|
|
|
|
pageSize: 20, // 每页数量
|
|
|
|
|
total: 0, //总条数
|
|
|
|
|
tabName: "dataTab",
|
|
|
|
|
//图表所有数据
|
|
|
|
|
chartDataArr: [], //数据
|
|
|
|
|
chartLoading: false,
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
watch: {
|
|
|
|
|
endtime(newVal) {
|
|
|
|
|
if (newVal) {
|
|
|
|
|
const date = new Date(newVal);
|
|
|
|
|
date.setHours(23);
|
|
|
|
|
date.setMinutes(59);
|
|
|
|
|
date.setSeconds(59);
|
|
|
|
|
this.formdata.endtime = date;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
checkedList(valArr) {
|
|
|
|
|
console.log("我是监听的", valArr);
|
|
|
|
|
this.columns = this.formTheadOptions.filter(
|
|
|
|
|
(i) => valArr.indexOf(i.fieldDesc) >= 0
|
|
|
|
|
);
|
|
|
|
|
this.key = this.key + 1; // 为了保证table 每次都会重渲
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
created() {
|
|
|
|
|
const thirtyDaysAgo = new Date();
|
|
|
|
|
this.$set(
|
|
|
|
|
this.formdata,
|
|
|
|
|
"starttime",
|
|
|
|
|
new Date(thirtyDaysAgo.setDate(thirtyDaysAgo.getDate() - 30))
|
|
|
|
|
);
|
|
|
|
|
console.log(this.formdata.starttime);
|
|
|
|
|
const currentDate = new Date(); // 获取当前时间
|
|
|
|
|
currentDate.setHours(23); // 设置小时为23
|
|
|
|
|
currentDate.setMinutes(59); // 设置分钟为59
|
|
|
|
|
currentDate.setSeconds(59); // 设置秒数为59
|
|
|
|
|
this.$set(this.formdata, "endtime", currentDate);
|
|
|
|
|
console.log("我是开始时间", this.formdata.starttime);
|
|
|
|
|
console.log("我是结束时间", currentDate);
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
display(value) {
|
|
|
|
|
this.dialogVisible = true;
|
|
|
|
|
this.currentId = value.id;
|
|
|
|
|
this.crrrentName = value.name;
|
|
|
|
|
this.getAllTimeTable();
|
|
|
|
|
},
|
|
|
|
|
handleClose() {
|
|
|
|
|
this.dialogVisible = false;
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
changestartdate(val) {
|
|
|
|
|
console.log(val);
|
|
|
|
|
if (val == null) {
|
|
|
|
|
console.log(new Date());
|
|
|
|
|
const startDate = new Date();
|
|
|
|
|
startDate.setHours(0); // 设置小时为23
|
|
|
|
|
startDate.setMinutes(0); // 设置分钟为59
|
|
|
|
|
startDate.setSeconds(0); // 设置秒数为59
|
|
|
|
|
this.formdata.starttime = startDate;
|
|
|
|
|
} else {
|
|
|
|
|
this.formdata.starttime = val;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
//结束日期
|
|
|
|
|
changeenddate(val) {
|
|
|
|
|
if (val == null) {
|
|
|
|
|
console.log(new Date());
|
|
|
|
|
const endDate = new Date();
|
|
|
|
|
endDate.setHours(23); // 设置小时为23
|
|
|
|
|
endDate.setMinutes(59); // 设置分钟为59
|
|
|
|
|
endDate.setSeconds(59); // 设置秒数为59
|
|
|
|
|
this.formdata.endtime = endDate;
|
|
|
|
|
console.log(this.formdata.endtime);
|
|
|
|
|
} else {
|
|
|
|
|
val.setHours(23); // 设置小时为23
|
|
|
|
|
val.setMinutes(59); // 设置分钟为59
|
|
|
|
|
val.setSeconds(59); // 设置秒数为59
|
|
|
|
|
this.formdata.endtime = val;
|
|
|
|
|
console.log(val);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
getAllTimeTable() {
|
|
|
|
|
getDetailApi({
|
|
|
|
|
id: this.currentId,
|
|
|
|
|
pageNum: this.page,
|
|
|
|
|
pageSize: this.pageSize,
|
|
|
|
|
})
|
|
|
|
|
.then((res) => {
|
|
|
|
|
console.log(res);
|
|
|
|
|
if (res.success) {
|
|
|
|
|
if (res.data.content.length == 0) {
|
|
|
|
|
// this.formdata.endtime = new Date();
|
|
|
|
|
// const thirtyDaysAgo = new Date(this.formdata.endtime);
|
|
|
|
|
// this.$set(
|
|
|
|
|
// this.formdata,
|
|
|
|
|
// "starttime",
|
|
|
|
|
// new Date(thirtyDaysAgo.setDate(thirtyDaysAgo.getDate() - 30))
|
|
|
|
|
// );
|
|
|
|
|
const thirtyDaysAgo = new Date();
|
|
|
|
|
this.$set(
|
|
|
|
|
this.formdata,
|
|
|
|
|
"starttime",
|
|
|
|
|
new Date(thirtyDaysAgo.setDate(thirtyDaysAgo.getDate() - 30))
|
|
|
|
|
);
|
|
|
|
|
console.log(this.formdata.starttime);
|
|
|
|
|
const currentDate = new Date(); // 获取当前时间
|
|
|
|
|
console.log("asddddadadadadadasd", currentDate);
|
|
|
|
|
currentDate.setHours(23); // 设置小时为23
|
|
|
|
|
currentDate.setMinutes(59); // 设置分钟为59
|
|
|
|
|
currentDate.setSeconds(59); // 设置秒数为59
|
|
|
|
|
this.$set(this.formdata, "endtime", currentDate);
|
|
|
|
|
console.log("我是开始时间", this.formdata.starttime);
|
|
|
|
|
console.log("我是结束时间", currentDate);
|
|
|
|
|
} else {
|
|
|
|
|
console.log(res.data.content[0].acquisitionTime);
|
|
|
|
|
this.formdata.endtime = res.data.content[0].acquisitionTime;
|
|
|
|
|
const qet = new Date(this.formdata.endtime);
|
|
|
|
|
qet.setHours(23); // 设置小时为23
|
|
|
|
|
qet.setMinutes(59); // 设置分钟为59
|
|
|
|
|
qet.setSeconds(59); // 设置秒数为59
|
|
|
|
|
this.$set(this.formdata, "endtime", qet);
|
|
|
|
|
|
|
|
|
|
const thirtyDaysAgo = new Date(this.formdata.endtime);
|
|
|
|
|
thirtyDaysAgo.setHours(0); // 设置小时为23
|
|
|
|
|
thirtyDaysAgo.setMinutes(0); // 设置分钟为59
|
|
|
|
|
thirtyDaysAgo.setSeconds(0); // 设置秒数为59
|
|
|
|
|
this.$set(
|
|
|
|
|
this.formdata,
|
|
|
|
|
"starttime",
|
|
|
|
|
new Date(thirtyDaysAgo.setDate(thirtyDaysAgo.getDate() - 30))
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this.handleSearch();
|
|
|
|
|
} else {
|
|
|
|
|
this.tableData = [];
|
|
|
|
|
this.$message({
|
|
|
|
|
showClose: true,
|
|
|
|
|
message: res.errorMsg,
|
|
|
|
|
type: "error",
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.catch((err) => {
|
|
|
|
|
console.log(err); //代码错误、请求失败捕获
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
//查询日期数据
|
|
|
|
|
handleSearch() {
|
|
|
|
|
//开始时间和结束时间
|
|
|
|
|
this.formdata.starttime = this.$moment(this.formdata.starttime).format(
|
|
|
|
|
"YYYY-MM-DD HH:mm:ss"
|
|
|
|
|
);
|
|
|
|
|
this.formdata.endtime = this.$moment(this.formdata.endtime).format(
|
|
|
|
|
"YYYY-MM-DD HH:mm:ss"
|
|
|
|
|
);
|
|
|
|
|
console.log(this.formdata.starttime);
|
|
|
|
|
console.log(this.formdata.endtime);
|
|
|
|
|
if (
|
|
|
|
|
this.formdata.starttime == "Invalid date" ||
|
|
|
|
|
this.formdata.endtime == "Invalid date"
|
|
|
|
|
) {
|
|
|
|
|
return this.$message({
|
|
|
|
|
duration: 1500,
|
|
|
|
|
showClose: true,
|
|
|
|
|
message: "请选择开始时间和结束时间",
|
|
|
|
|
type: "warning",
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
if (this.formdata.starttime > this.formdata.endtime) {
|
|
|
|
|
return this.$message({
|
|
|
|
|
duration: 1500,
|
|
|
|
|
showClose: true,
|
|
|
|
|
message: "开始日期不能大于结束日期",
|
|
|
|
|
type: "warning",
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.log(this.tabName);
|
|
|
|
|
if (this.tabName == "dataTab") {
|
|
|
|
|
this.getDetailTable(
|
|
|
|
|
this.currentId,
|
|
|
|
|
this.formdata.dayValue,
|
|
|
|
|
this.formdata.starttime,
|
|
|
|
|
this.formdata.endtime
|
|
|
|
|
);
|
|
|
|
|
} else if (this.tabName == "chartTab") {
|
|
|
|
|
this.getEchartData(
|
|
|
|
|
this.currentId,
|
|
|
|
|
this.formdata.starttime,
|
|
|
|
|
this.formdata.endtime
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
//获取数据接口
|
|
|
|
|
getDetailTable(id, dayval, stime, eTime) {
|
|
|
|
|
console.log(id, stime, eTime);
|
|
|
|
|
this.tableLoading = true;
|
|
|
|
|
// 创建一个空对象来存储API的参数
|
|
|
|
|
const apiParams = {
|
|
|
|
|
id: id,
|
|
|
|
|
startTime: stime,
|
|
|
|
|
endTime: eTime,
|
|
|
|
|
pageNum: this.page,
|
|
|
|
|
pageSize: this.pageSize,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// 如果dayval不等于-1,则添加numPerDay参数
|
|
|
|
|
if (dayval !== -1) {
|
|
|
|
|
apiParams.numPerDay = dayval;
|
|
|
|
|
}
|
|
|
|
|
getDetailApi(apiParams)
|
|
|
|
|
.then((res) => {
|
|
|
|
|
console.log(res);
|
|
|
|
|
if (res.success) {
|
|
|
|
|
this.total = res.data.total; //总共多少页
|
|
|
|
|
this.tableData = res.data.content; //表格数据
|
|
|
|
|
this.columns = res.data.points; //表头数据
|
|
|
|
|
console.log(this.columns);
|
|
|
|
|
this.formTheadOptions = res.data.points;
|
|
|
|
|
|
|
|
|
|
//左侧checkbox数据
|
|
|
|
|
this.optionList = res.data.points.map((i) => {
|
|
|
|
|
console.log(i);
|
|
|
|
|
return i.fieldDesc;
|
|
|
|
|
});
|
|
|
|
|
console.log(this.optionList);
|
|
|
|
|
this.checkedList = this.optionList;
|
|
|
|
|
this.tableLoading = false;
|
|
|
|
|
} else {
|
|
|
|
|
this.tableLoading = false;
|
|
|
|
|
this.tableData = [];
|
|
|
|
|
this.$message({
|
|
|
|
|
showClose: true,
|
|
|
|
|
message: res.errorMsg,
|
|
|
|
|
type: "error",
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.catch((err) => {
|
|
|
|
|
this.tableLoading = false;
|
|
|
|
|
console.log(err); //代码错误、请求失败捕获
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
//左侧全选
|
|
|
|
|
handleCheckAllChange(val) {
|
|
|
|
|
console.log(val, this.optionList);
|
|
|
|
|
this.checkedList = val ? this.optionList : [];
|
|
|
|
|
this.isIndeterminate = false;
|
|
|
|
|
console.log(val, "点击了全选");
|
|
|
|
|
},
|
|
|
|
|
handleCheckedCitiesChange(value) {
|
|
|
|
|
let checkedCount = value.length;
|
|
|
|
|
this.checkAll = checkedCount === this.optionList.length;
|
|
|
|
|
this.isIndeterminate =
|
|
|
|
|
checkedCount > 0 && checkedCount < this.optionList.length;
|
|
|
|
|
console.log(value, "点击了某个");
|
|
|
|
|
},
|
|
|
|
|
//图表切换
|
|
|
|
|
handleClick(tab, event) {
|
|
|
|
|
console.log(tab, event);
|
|
|
|
|
this.tabName = tab.name;
|
|
|
|
|
if (this.tabName === "chartTab") {
|
|
|
|
|
this.formdata.starttime = this.$moment(this.formdata.starttime).format(
|
|
|
|
|
"YYYY-MM-DD HH:mm:ss"
|
|
|
|
|
);
|
|
|
|
|
this.formdata.endtime = this.$moment(this.formdata.endtime).format(
|
|
|
|
|
"YYYY-MM-DD HH:mm:ss"
|
|
|
|
|
);
|
|
|
|
|
this.getEchartData(
|
|
|
|
|
this.currentId,
|
|
|
|
|
this.formdata.starttime,
|
|
|
|
|
this.formdata.endtime
|
|
|
|
|
);
|
|
|
|
|
} else {
|
|
|
|
|
this.getDetailTable(
|
|
|
|
|
this.currentId,
|
|
|
|
|
this.formdata.dayValue,
|
|
|
|
|
this.formdata.starttime,
|
|
|
|
|
this.formdata.endtime
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
//导出数据
|
|
|
|
|
handleExport() {
|
|
|
|
|
this.formdata.starttime = this.$moment(this.formdata.starttime).format(
|
|
|
|
|
"YYYY-MM-DD HH:mm:ss"
|
|
|
|
|
);
|
|
|
|
|
this.formdata.endtime = this.$moment(this.formdata.endtime).format(
|
|
|
|
|
"YYYY-MM-DD HH:mm:ss"
|
|
|
|
|
);
|
|
|
|
|
window.location.href =
|
|
|
|
|
"/cac-api/nsensor/export?id=" +
|
|
|
|
|
this.currentId +
|
|
|
|
|
"&numPerDay=" +
|
|
|
|
|
this.formdata.dayValue +
|
|
|
|
|
"&startTime=" +
|
|
|
|
|
this.formdata.starttime +
|
|
|
|
|
"&endTime=" +
|
|
|
|
|
this.formdata.endtime;
|
|
|
|
|
// getexportApi({
|
|
|
|
|
// id: this.currentId,
|
|
|
|
|
// startTime: this.formdata.starttime,
|
|
|
|
|
// endTime: this.formdata.endtime,
|
|
|
|
|
// // pageNum: this.page,
|
|
|
|
|
// // pageSize: this.pageSize,
|
|
|
|
|
// })
|
|
|
|
|
// .then((res) => {
|
|
|
|
|
// console.log(res);
|
|
|
|
|
// })
|
|
|
|
|
// .catch((err) => {
|
|
|
|
|
// console.log(err); //代码错误、请求失败捕获
|
|
|
|
|
// });
|
|
|
|
|
},
|
|
|
|
|
//导出当前
|
|
|
|
|
handleCurrentExport() {
|
|
|
|
|
this.formdata.starttime = this.$moment(this.formdata.starttime).format(
|
|
|
|
|
"YYYY-MM-DD HH:mm:ss"
|
|
|
|
|
);
|
|
|
|
|
this.formdata.endtime = this.$moment(this.formdata.endtime).format(
|
|
|
|
|
"YYYY-MM-DD HH:mm:ss"
|
|
|
|
|
);
|
|
|
|
|
window.location.href =
|
|
|
|
|
"/cac-api/nsensor/export?id=" +
|
|
|
|
|
this.currentId +
|
|
|
|
|
"&numPerDay=" +
|
|
|
|
|
this.formdata.dayValue +
|
|
|
|
|
"&startTime=" +
|
|
|
|
|
this.formdata.starttime +
|
|
|
|
|
"&endTime=" +
|
|
|
|
|
this.formdata.endtime +
|
|
|
|
|
"&pageNum=" +
|
|
|
|
|
this.page +
|
|
|
|
|
"&pageSize=" +
|
|
|
|
|
this.pageSize;
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
//点击分页
|
|
|
|
|
handleCurrentChange(val) {
|
|
|
|
|
this.page = val;
|
|
|
|
|
this.tableData = [];
|
|
|
|
|
this.getDetailTable(
|
|
|
|
|
this.currentId,
|
|
|
|
|
this.formdata.dayValue,
|
|
|
|
|
this.formdata.starttime,
|
|
|
|
|
this.formdata.endtime
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
//每页条数
|
|
|
|
|
handleSizeChange(val) {
|
|
|
|
|
this.pageSize = val;
|
|
|
|
|
this.tableData = [];
|
|
|
|
|
this.getDetailTable(
|
|
|
|
|
this.currentId,
|
|
|
|
|
this.formdata.dayValue,
|
|
|
|
|
this.formdata.starttime,
|
|
|
|
|
this.formdata.endtime
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
//获取折线图
|
|
|
|
|
getEchartData(id, stime, eTime) {
|
|
|
|
|
this.chartLoading = true;
|
|
|
|
|
this.chartDataArr = [];
|
|
|
|
|
getDetailApi({
|
|
|
|
|
id: id,
|
|
|
|
|
timeAsc: 1,
|
|
|
|
|
startTime: stime,
|
|
|
|
|
endTime: eTime,
|
|
|
|
|
})
|
|
|
|
|
.then((res) => {
|
|
|
|
|
console.log(res);
|
|
|
|
|
if (res.success) {
|
|
|
|
|
this.chartLoading = false;
|
|
|
|
|
this.chartDataArr = res.data; //表格数据
|
|
|
|
|
console.log("获取全部数据", this.chartDataArr);
|
|
|
|
|
//获取数据之后执行绘制echarts图
|
|
|
|
|
} else {
|
|
|
|
|
this.chartLoading = false;
|
|
|
|
|
this.chartDataArr = [];
|
|
|
|
|
this.$message({
|
|
|
|
|
showClose: true,
|
|
|
|
|
message: res.errorMsg,
|
|
|
|
|
type: "error",
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.catch((err) => {
|
|
|
|
|
console.log(err); //代码错误、请求失败捕获
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
</script>
|
|
|
|
|
<style lang="less">
|
|
|
|
|
.dataDialog {
|
|
|
|
|
.el-dialog {
|
|
|
|
|
background-image: url(../../../assets/bg_CAC.png);
|
|
|
|
|
background-size: cover;
|
|
|
|
|
background-position: center center;
|
|
|
|
|
.el-dialog__title {
|
|
|
|
|
color: #fff;
|
|
|
|
|
}
|
|
|
|
|
.el-dialog__headerbtn {
|
|
|
|
|
background: #337ab7;
|
|
|
|
|
}
|
|
|
|
|
.el-dialog__headerbtn .el-dialog__close {
|
|
|
|
|
color: #fff;
|
|
|
|
|
font-size: 24px;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.el-dialog__body {
|
|
|
|
|
padding: 12px;
|
|
|
|
|
height: calc(100% - 78px);
|
|
|
|
|
}
|
|
|
|
|
.dataReport {
|
|
|
|
|
height: 100%;
|
|
|
|
|
|
|
|
|
|
.reportTable {
|
|
|
|
|
height: 100%;
|
|
|
|
|
overflow-x: hidden;
|
|
|
|
|
background: rgba(8, 9, 36, 0.28);
|
|
|
|
|
-webkit-backdrop-filter: blur(10px);
|
|
|
|
|
backdrop-filter: blur(10px);
|
|
|
|
|
box-shadow: inset 0 4px 44px 0 #106cde;
|
|
|
|
|
padding: 0px 12px;
|
|
|
|
|
.reportHead {
|
|
|
|
|
height: 40px;
|
|
|
|
|
line-height: 40px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
h3 {
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
color: #fff;
|
|
|
|
|
font-weight: normal;
|
|
|
|
|
height: 40px;
|
|
|
|
|
line-height: 40px;
|
|
|
|
|
.exporBtn {
|
|
|
|
|
margin-left: 12px;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.searchMain {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
.el-form {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
.el-form-item--small.el-form-item {
|
|
|
|
|
margin-bottom: 0px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
.el-form-item__label {
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
color: #fff;
|
|
|
|
|
}
|
|
|
|
|
.el-input {
|
|
|
|
|
width: 150px;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.reportContain {
|
|
|
|
|
height: calc(100% - 52px);
|
|
|
|
|
//background: #fcc;
|
|
|
|
|
margin-top: 12px;
|
|
|
|
|
.el-tabs--border-card {
|
|
|
|
|
height: calc(100% - 2px);
|
|
|
|
|
.el-tabs__content {
|
|
|
|
|
padding: 0px;
|
|
|
|
|
height: calc(100% - 38px);
|
|
|
|
|
// background: #fcc;
|
|
|
|
|
.el-tab-pane {
|
|
|
|
|
height: 100%;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.dataTabHead {
|
|
|
|
|
height: 36px;
|
|
|
|
|
line-height: 36px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
background: #fff;
|
|
|
|
|
-webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.3);
|
|
|
|
|
-moz-box-shadow: 0 0 4px rgba(0, 0, 0, 0.3);
|
|
|
|
|
box-shadow: 0 0 4px rgba(0, 0, 0, 0.3);
|
|
|
|
|
padding: 0px 12px;
|
|
|
|
|
margin-top: 12px;
|
|
|
|
|
h3 {
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
color: #333;
|
|
|
|
|
font-weight: normal;
|
|
|
|
|
}
|
|
|
|
|
.exportbtn {
|
|
|
|
|
display: flex;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.tableBox {
|
|
|
|
|
// padding: 0 12px;
|
|
|
|
|
height: calc(100% - 50px);
|
|
|
|
|
display: flex;
|
|
|
|
|
.leftTable {
|
|
|
|
|
width: 250px;
|
|
|
|
|
//background: #fcc;
|
|
|
|
|
height: 100%;
|
|
|
|
|
padding-left: 12px;
|
|
|
|
|
.el-checkbox {
|
|
|
|
|
white-space: inherit;
|
|
|
|
|
margin-top: 12px;
|
|
|
|
|
margin-right: 0px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.rightTable {
|
|
|
|
|
margin-left: 8px;
|
|
|
|
|
flex-grow: 1; /* 右边内容自适应剩余空间 */
|
|
|
|
|
overflow-x: hidden;
|
|
|
|
|
.el-table {
|
|
|
|
|
thead {
|
|
|
|
|
color: #333;
|
|
|
|
|
}
|
|
|
|
|
color: #333;
|
|
|
|
|
.el-table__cell {
|
|
|
|
|
text-align: center;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
//分页
|
|
|
|
|
.pageNation {
|
|
|
|
|
margin-top: 6px;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: flex-end;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.echartsBox {
|
|
|
|
|
width: calc(100% - 32px);
|
|
|
|
|
height: calc(100% - 80px);
|
|
|
|
|
padding: 16px;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
color: #333;
|
|
|
|
|
.chartClass {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</style>
|