factory_web/src/views/enm_pack/report.vue

1058 lines
30 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<div class="app-container">
<el-header>
<div class="left-panel">
<el-select
v-model="query.type"
placeholder="查询类型"
clearable
class="headerSearch"
@change="typeCange"
>
<el-option
v-for="item in options"
:key="item.id"
:label="item.name"
:value="item.id"
></el-option>
</el-select>
<el-date-picker
v-model="query.day"
type="date"
value-format="YYYY-MM-DD"
format="YYYY-MM-DD"
placeholder="天"
v-if="query.type==0"
style="margin-right: 6px"
/>
<el-date-picker
v-model="query.month"
type="month"
value-format="YYYY-MM"
format="YYYY-MM"
placeholder="查询月份"
v-if="query.type==1"
class="headerSearch"
/>
<el-date-picker
v-model="query.year"
type="year"
value-format="YYYY"
format="YYYY"
placeholder="查询年份"
v-if="query.type==2"
class="headerSearch"
/>
<el-button
type="primary"
icon="el-icon-search"
@click="dateChange"
></el-button>
<el-button
type="primary"
@click="exportExcel()"
:loading="exportLoading"
v-auth="'export_excel'"
>导出xlsx
</el-button>
<el-button type="primary" @click="handlePrint">打印 </el-button>
</div>
</el-header>
<el-card style="margin-top: 5px">
<div class="printWrap">
<div ref="print" id="myReport" class="printContainer">
<table
border="1"
width="1035"
cellspacing="0"
:key="timeStamp"
id="myTable"
class="myTable"
>
<thead class="myTableHead">
<tr>
<th colspan="6">水泥包装工序生产报告</th>
</tr>
<tr>
<th colspan="2">参数</th>
<th>昨日</th>
<th>本日</th>
<th>本月</th>
<th>本年</th>
</tr>
</thead>
<tbody>
<tr v-for="(item, index) in tableDatas" :key="item">
<td rowspan="11" v-if="index == 0" class="numCell">{{ item[0] }}</td>
<td v-else-if="index==11" class="numCell">{{ item[0] }}</td>
<td v-else-if="index==12" class="numCell"
rowspan="2"
>{{ item[0] }}</td>
<td class="numCell">{{ item[1] }}</td>
<td
class="numCell hoursItem"
@click="itemClick('day_s', item)"
>
{{ item[2] }}
</td>
<td
class="numCell daysItem"
@click="itemClick('month_s', item)"
>
{{ item[3] }}
</td>
<td
class="numCell monthItem"
@click="itemClick('year_s', item)"
>
{{ item[4] }}
</td>
<td class="numCell">{{ item[5] }}</td>
<!-- <td class="numCell">{{ item[6] }}</td>
<td class="numCell">{{ item[7] }}</td>
<td class="numCell">{{ item[8] }}</td> -->
</tr>
</tbody>
</table>
<!-- <div class="radioWrap">
<el-radio-group
v-model="typeRadio"
@change="typeRadioChange"
>
<el-radio-button label="month">按日</el-radio-button>
<el-radio-button label="year">按月</el-radio-button>
</el-radio-group>
<div style="position: absolute; right: 20px">
<el-date-picker
v-model="searchDate"
type="month"
value-format="YYYY-MM"
formatter="YYYY-MM"
placeholder="选择月"
v-if="typeRadio == 'month'"
@change="dateChange"
></el-date-picker>
<el-date-picker
v-if="typeRadio == 'year'"
v-model="searchDate"
type="year"
value-format="YYYY"
formatter="YYYY"
placeholder="选择年"
@change="dateChange"
></el-date-picker>
</div>
</div> -->
<!-- <div class="chartWrap" v-show="query.type == 0">
<div class="chartTitle">本日生产参数统计图</div>
<scEcharts
height="400px"
width="1033px"
:option="optionHours"
></scEcharts>
</div> -->
<div class="chartWrap" v-show="query.type == 1">
<div class="chartTitle">本月生产参数统计图</div>
<scEcharts
height="400px"
width="1033px"
:option="optionDay"
></scEcharts>
</div>
<div class="chartWrap" v-show="query.type == 2">
<div class="chartTitle">本年生产参数统计图</div>
<scEcharts
height="400px"
width="1033px"
:option="optionMonth"
></scEcharts>
</div>
</div>
</div>
<!-- <sc-dialog v-model="chartShow" draggable title="水泥包装工序">
<div class="searchHead" v-if="type == 'hours'">
<el-date-picker
v-model="query.start_time"
type="date"
placeholder="选择时间"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD"
:picker-options="pickerOptions"
/>
<span class="middleText">至</span>
<el-date-picker
v-model="query.end_time"
type="date"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD"
start-placeholder="结束日期"
:picker-options="pickerOptions"
/>
<el-button
type="primary"
class="searchBtn"
@click="dataSearch"
>查询</el-button
>
</div>
<div class="searchHead" v-if="type == 'days'">
<el-date-picker
v-model="query.start_time"
type="date"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD"
start-placeholder="开始日期"
:picker-options="pickerOptions"
/>
<el-date-picker
v-model="query.end_time"
type="date"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD"
start-placeholder="结束日期"
:picker-options="pickerOptions"
/>
<el-button
type="primary"
class="searchBtn"
@click="dataSearch"
>查询</el-button
>
</div>
<div class="searchHead" v-if="type == 'month'">
<el-date-picker
v-model="query.start_time"
type="month"
format="YYYY-MM"
value-format="YYYY-MM"
start-placeholder="开始月份"
:picker-options="pickerOptions"
/>
<el-date-picker
v-model="query.end_time"
type="month"
format="YYYY-MM"
value-format="YYYY-MM"
start-placeholder="结束月份"
:picker-options="pickerOptions"
/>
<el-button
type="primary"
class="searchBtn"
@click="dataSearch"
>查询</el-button
>
</div>
<div class="searchHead" v-if="type == 'year'">
<el-date-picker
v-model="query.start_time"
type="year"
format="YYYY"
value-format="YYYY"
start-placeholder="开始日期"
:picker-options="pickerOptions"
/>
<el-date-picker
v-model="query.end_time"
type="year"
format="YYYY"
value-format="YYYY"
start-placeholder="结束日期"
:picker-options="pickerOptions"
/>
<el-button
type="primary"
class="searchBtn"
@click="dataSearch"
>查询</el-button
>
</div>
<scEcharts
height="360px"
:option="myOption"
v-if="chartShow"
></scEcharts>
</sc-dialog> -->
<charts
v-if="asynDialog"
:type="type"
:title="title"
:cate="cate"
:apiObj="apiObj"
:mgroup="query.mgroup"
:modelValue="modelValue"
:showClose="showClose"
:echartType="echartType"
@closed="asynDialog = false"
></charts>
</el-card>
</div>
</template>
<script>
const colors = ["#5b9bd5", "#cbd3fe", "#B79C2C", "#EE6666", "#CC00CC", "#7DDA58", "#BCB69D","#0AF2FA", "#48D311"];
const colors1 = ["#5b9bd5", "#cbd3fe", "#B79C2C", "#EE6666", "#CC00CC", "#726691", "#48D311"];
let tooltip = {
show: true,
trigger: "axis",
axisPointer: {
type: "cross",
},
confine: false,
showContent: true,
triggerOn: "mousemove",
};
let grid = {
right: "11%",
left: "11%",
top: "24%",
};
let toolbox = {
right: 0,
feature: {
dataView: { show: true, readOnly: false },
saveAsImage: { show: true },
},
orient: "vertical",
};
let legend = {
selector: [
{
type: 'all',
title: '全选'
},
{
type: 'inverse',
title: '反选'
}
],
top: "2%",
data: ["袋装合计", "散装合计", "熟料出厂合计", "出厂水泥合计", "复合水泥合计"],}
let yAxis = [
{
type: "value",
name: "产量 (t)",
position: "left",
alignTicks: true,
axisLine: {
show: true,
lineStyle: {
color: colors[7],
},
},
axisLabel: {
formatter: "{value}",
},
nameRotate: 50,
},
{
type: "value",
name: "分布电耗(kW·h/t)",
position: "right",
alignTicks: true,
axisLine: {
show: true,
lineStyle: {
color: colors[8],
},
},
axisLabel: {
formatter: "{value}",
},
nameRotate: 50,
},
];
import scEcharts from "@/components/scEcharts";
import { defineAsyncComponent } from "vue";
export default {
components: {
scEcharts,
charts: defineAsyncComponent(() =>
import("@/components/scEnm/lineChartsdialog.vue")
),
},
data() {
return {
searchDate: "",
typeRadio: "month",
exportLoading: false,
chartShow: false,
timeStamp: null,
myOption: null,
optionDay: {},
optionMonth: {},
goal_list:[],
year: 2023,
month: 1,
days: 1,
listQuery: {
belong_dept: "",
task2__year: "",
page: 0,
},
options: [
{id:1,name:'月统计'},
{id:2,name:'年统计'}
],
query: {
mgroup: "",
type:1,
},
tableDatas: [
["出厂水泥", "P.O42.5R 散装t", 0,0, 0, 0],
["出厂水泥", "P.O42.5R 袋装t", 0, 0,0, 0],
["出厂水泥", "P.O42.5 袋装t", 0, 0,0, 0],
["出厂水泥", "P.O42.5 散装t", 0, 0,0, 0],
["出厂水泥", "复合硅酸盐水泥;42.5R;袋装水泥(t)", 0, 0, 0, 0],
["出厂水泥", "复合硅酸盐水泥;42.5R;散装水泥(t)", 0, 0, 0, 0],
["出厂水泥", "普通硅酸盐水泥;52.5;散装水泥(t)", 0,0, 0, 0],
["出厂水泥", "普通硅酸盐水泥;42.5:散装缓凝水泥(t)", 0,0, 0, 0],
["出厂水泥", "散装水泥(t)", 0,0, 0, 0],
["出厂水泥", "袋装水泥(t)", 0,0, 0, 0],
["出厂水泥", "出厂水泥合计t", 0,0, 0, 0, 0, 0, 0, 0],
["出厂熟料", "熟料t", 0,0, 0, 0],
["能耗", "包装单位产品分布电耗kW·h/t", 0,0, 0, 0],
["能耗", "包装工序总电量kW·h", 0,0, 0, 0],
],
tableName: "生产报告",
modelValue: true,
type: "hour_s",
title: "水包装工段",
cate: "",
apiObj: this.$API.enm.enstat,
showClose: true,
echartType: "line",
asynDialog: false,
option1: {
color: colors,
tooltip: tooltip,
grid: grid,
toolbox: toolbox,
legend: legend,
xAxis: {
axisTick: {
show: true,
length: 5,
inside: true,
},
data: [],
},
yAxis: yAxis,
selector:[{
type: 'all',
title: '全选'
},
{
type: 'inverse',
title: '反选'
}],
selector: true,
series: [
{
name: "袋装合计",
type: "bar",
yAxisIndex: 0,
data: [],
},
{
name: "散装合计",
type: "bar",
yAxisIndex: 0,
data: [],
},
{
name: "熟料出厂合计",
type: "bar",
yAxisIndex: 0,
data: [],
},
{
name: "出厂水泥合计",
type: "bar",
yAxisIndex: 0,
data: [],
},
{
name: "复合水泥合计",
type: "bar",
yAxisIndex: 0,
data: [],
},
{
name: "分布电耗",
type: "bar",
yAxisIndex: 1,
data: [],
},
],
},
option2: {
color: colors1,
tooltip: tooltip,
legend: Object.assign(legend, {data:["袋装合计", "散装合计", "熟料出厂合计", "出厂水泥合计", "复合水泥合计", "分布电耗目标值","分布电耗"]}),
grid: grid,
toolbox: toolbox,
xAxis: {
axisTick: {
show: true,
length: 5,
inside: true,
},
data: [],
},
selector:[{
// 全选
type: 'all',
// 可以是任意你喜欢的标题
title: '全选'
},
{
// 反选
type: 'inverse',
// 可以是任意你喜欢的标题
title: '反选'
}],
selector: true,
yAxis: yAxis,
series: [
{
name: "袋装合计",
type: "bar",
yAxisIndex: 0,
data: [],
},
{
name: "散装合计",
type: "bar",
yAxisIndex: 0,
data: [],
},
{
name: "熟料出厂合计",
type: "bar",
yAxisIndex: 0,
data: [],
},
{
name: "出厂水泥合计",
type: "bar",
yAxisIndex: 0,
data: [],
},
{
name: "复合水泥合计",
type: "bar",
yAxisIndex: 0,
data: [],
},
{
name: "分布电耗目标值",
type: "line",
yAxisIndex: 0,
data: [],
},
{
name: "分布电耗",
type: "bar",
yAxisIndex: 1,
data: [],
},
],
},
};
},
mounted() {
function precen(a, b) {
if (b !== 0 && b !== null && a !== null) {
let precen = (a / b)* 100;
return precen.toFixed(2) + "%";
} else {
return "/";
}
}
let that = this;
var myDate = new Date();
let year = (that.year = myDate.getFullYear());
let month = (that.month = myDate.getMonth() + 1);
let days = (that.days = myDate.getDate());
let hours = myDate.getHours();
let timeDate = myDate.getTime();
let dayTime = 24 * 60 * 60 * 1000;
//昨天的计算
let year_d = year,
month_d = month,
days_d = days;
if (hours < 21) {
//21点前查找昨日数据为前一天数据
let newDate = timeDate - dayTime;
let lastDate = new Date(newDate);
year_d = lastDate.getFullYear();
month_d = lastDate.getMonth() + 1;
days_d = lastDate.getDate();
}
this.$API.mtm.mgroup.list
.req({ page: 0, search: "水泥包装" })
.then((res) => {
that.query.mgroup = res[0].id;
//年
let params1 = {};
params1.page = 0;
params1.year_s = year;
params1.type = "year_s";
params1.mgroup = that.query.mgroup;
this.$API.enm.mpointstat.list.req(params1).then((res1) => {
if (res1.length > 0) {
res1.forEach((item) => {
if (item.mpoint_nickname == "水泥+P.O42.5R 散装") {
that.tableDatas[0][5] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5R 袋装"){
that.tableDatas[1][5] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 袋装") {
that.tableDatas[2][5] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 散装") {
that.tableDatas[3][5] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;袋装水泥") {
that.tableDatas[4][5] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;散装水泥") {
that.tableDatas[5][5] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O52.5 散装") {
that.tableDatas[6][5] = item.val;
}else if (item.mpoint_nickname == "水泥+P.C42.5 散装"){
that.tableDatas[7][5] = item.val;
}else if (item.mpoint_nickname == "散装水泥总和"){
that.tableDatas[8][5] = item.val;
}else if (item.mpoint_nickname == "袋装水泥总和") {
that.tableDatas[9][5] = item.val;
}
else if (item.mpoint_nickname == "出厂水泥") {
that.tableDatas[10][5] = item.val;
}else if (item.mpoint_nickname == "出厂熟料"){
that.tableDatas[11][5] = item.val;
}else if (item.mpoint_nickname == "水泥包装用电合计") {
that.tableDatas[12][5] = item.elec_consume_unit;
that.tableDatas[13][5] = item.val;
}
}
)}
}).then(()=>{
//月
let params2 = {};
params2.page = 0;
params2.year_s = year;
params2.month_s = month;
params2.type = "month_s";
params2.mgroup = that.query.mgroup;
this.$API.enm.mpointstat.list.req(params2).then((res2) => {
if (res2.length > 0) {
res2.forEach((item) => {
if (item.mpoint_nickname == "水泥+P.O42.5R 散装") {
that.tableDatas[0][4] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5R 袋装"){
that.tableDatas[1][4] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 袋装") {
that.tableDatas[2][4] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 散装") {
that.tableDatas[3][4] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;袋装水泥") {
that.tableDatas[4][4] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;散装水泥") {
that.tableDatas[5][4] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O52.5 散装") {
that.tableDatas[6][4] = item.val;
}
else if (item.mpoint_nickname == "水泥+P.C42.5 散装"){
that.tableDatas[7][4] = item.val;
}else if (item.mpoint_nickname == "散装水泥总和"){
that.tableDatas[8][4] = item.val;
}else if (item.mpoint_nickname == "袋装水泥总和") {
that.tableDatas[9][4] = item.val;
}
else if (item.mpoint_nickname == "出厂水泥") {
that.tableDatas[10][4] = item.val;
}else if (item.mpoint_nickname == "出厂熟料"){
that.tableDatas[11][4] = item.val;
}else if (item.mpoint_nickname == "水泥包装用电合计") {
that.tableDatas[12][4] = item.elec_consume_unit;
that.tableDatas[13][4] = item.val;
}
}
)
}
}).then(() => {
//昨日
let params3 = {};
params3.page = 0;
params3.year_s = year_d;
params3.month_s = month_d;
params3.day_s = days_d;
params3.type = "day_s";
params3.mgroup = that.query.mgroup;
this.$API.enm.mpointstat.list.req(params3).then((res3) => {
if (res3.length > 0) {
res3.forEach((item) => {
if (item.mpoint_nickname == "水泥+P.O42.5R 散装") {
that.tableDatas[0][2] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5R 袋装"){
that.tableDatas[1][2] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 袋装") {
that.tableDatas[2][2] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 散装") {
that.tableDatas[3][2] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;袋装水泥") {
that.tableDatas[4][2] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;散装水泥") {
that.tableDatas[5][2] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O52.5 散装") {
that.tableDatas[6][2] = item.val;
}else if (item.mpoint_nickname == "水泥+P.C42.5 散装"){
that.tableDatas[7][2] = item.val;
}else if (item.mpoint_nickname == "散装水泥总和"){
that.tableDatas[8][2] = item.val;
}else if (item.mpoint_nickname == "袋装水泥总和") {
that.tableDatas[9][2] = item.val;
}
else if (item.mpoint_nickname == "出厂水泥") {
that.tableDatas[10][2] = item.val;
}else if (item.mpoint_nickname == "出厂熟料"){
that.tableDatas[11][2] = item.val;
}else if (item.mpoint_nickname == "水泥包装用电合计") {
that.tableDatas[12][2] = item.elec_consume_unit;
that.tableDatas[13][2] = item.val;
}
}
)}
});
}).then(() => {
//当日
let params4 = {};
params4.page = 0;
params4.year_s = year_d;
params4.month_s = month_d;
params4.day_s = days;
params4.type = "day_s";
params4.mgroup = that.query.mgroup;
this.$API.enm.mpointstat.list.req(params4).then((res3) => {
if (res3.length > 0) {
res3.forEach((item) => {
if (item.mpoint_nickname == "水泥+P.O42.5R 散装") {
that.tableDatas[0][3] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5R 袋装"){
that.tableDatas[1][3] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 袋装") {
that.tableDatas[2][3] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 散装") {
that.tableDatas[3][3] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;袋装水泥") {
that.tableDatas[4][3] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;散装水泥") {
that.tableDatas[5][3] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O52.5 散装") {
that.tableDatas[6][3] = item.val;
}else if (item.mpoint_nickname == "水泥+P.C42.5 散装"){
that.tableDatas[7][2] = item.val;
}else if (item.mpoint_nickname == "散装水泥总和"){
that.tableDatas[8][3] = item.val;
}else if (item.mpoint_nickname == "袋装水泥总和") {
that.tableDatas[9][3] = item.val;
}
else if (item.mpoint_nickname == "出厂水泥") {
that.tableDatas[10][3] = item.val;
}else if (item.mpoint_nickname == "出厂熟料"){
that.tableDatas[11][3] = item.val;
}else if (item.mpoint_nickname == "水泥包装用电合计") {
that.tableDatas[12][3] = item.elec_consume_unit;
that.tableDatas[13][3] = item.val;
}
}
)}
});
})
}
);
that.getDayData(year, month);
that.getMonthData(year);
});
},
methods: {
typeRadioChange() {
this.searchDate = "";
},
dateChange() {
let that = this;
if(that.query.type==1 && that.query.month) {
let year = that.query.month.split("-")[0];
let month = that.query.month.split("-")[1];
month = Number(month);
this.getDayData(year, month);
this.get_months(year, month);
}else if (that.query.type==2 && that.query.year ) {
let year = that.query.year;
this.getMonthData(year);
this.get_year(year);
}
},
get_year(year){
let that = this;
let params1 = {};
params1.page = 0;
params1.year_s = year;
params1.type = "year_s";
params1.mgroup = that.query.mgroup;
this.$API.enm.mpointstat.list.req(params1).then((res1) => {
if (res1.length > 0) {
res1.forEach((item) => {
if (item.mpoint_nickname == "水泥+P.O42.5R 散装") {
that.tableDatas[0][5] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5R 袋装"){
that.tableDatas[1][5] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 袋装") {
that.tableDatas[2][5] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 散装") {
that.tableDatas[3][5] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;袋装水泥") {
that.tableDatas[4][5] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;散装水泥") {
that.tableDatas[5][5] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O52.5 散装") {
that.tableDatas[6][5] = item.val;
}
else if (item.mpoint_nickname == "水泥+P.C42.5 散装"){
that.tableDatas[7][5] = item.val;
}else if (item.mpoint_nickname == "散装水泥总和"){
that.tableDatas[8][5] = item.val;
}else if (item.mpoint_nickname == "袋装水泥总和") {
that.tableDatas[9][5] = item.val;
}
else if (item.mpoint_nickname == "出厂水泥") {
that.tableDatas[10][5] = item.val;
}else if (item.mpoint_nickname == "出厂熟料"){
that.tableDatas[11][5] = item.val;
}else if (item.mpoint_nickname == "水泥包装用电合计") {
that.tableDatas[12][5] = item.elec_consume_unit;
that.tableDatas[13][5] = item.val;
}
})}
})
},
get_months(year, month){
let that = this;
let params2 = {};
params2.page = 0;
params2.year_s = year;
params2.month_s = month;
params2.type = "month_s";
params2.mgroup = that.query.mgroup;
this.$API.enm.mpointstat.list.req(params2).then((res2) => {
if (res2.length > 0) {
res2.forEach((item) => {
if (item.mpoint_nickname == "水泥+P.O42.5R 散装") {
that.tableDatas[0][4] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5R 袋装"){
that.tableDatas[1][4] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 袋装") {
that.tableDatas[2][4] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O42.5 散装") {
that.tableDatas[3][4] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;袋装水泥") {
that.tableDatas[4][4] = item.val;
}else if (item.mpoint_nickname == "复合硅酸盐水泥;42.5R;散装水泥") {
that.tableDatas[5][4] = item.val;
}else if (item.mpoint_nickname == "水泥+P.O52.5 散装") {
that.tableDatas[6][4] = item.val;
}else if (item.mpoint_nickname == "水泥+P.C42.5 散装"){
that.tableDatas[7][4] = item.val;
}else if (item.mpoint_nickname == "散装水泥总和"){
that.tableDatas[8][4] = item.val;
}else if (item.mpoint_nickname == "袋装水泥总和") {
that.tableDatas[9][4] = item.val;
}
else if (item.mpoint_nickname == "出厂水泥") {
that.tableDatas[10][4] = item.val;
}else if (item.mpoint_nickname == "出厂熟料"){
that.tableDatas[11][4] = item.val;
}else if (item.mpoint_nickname == "水泥包装用电合计") {
that.tableDatas[12][4] = item.elec_consume_unit;
that.tableDatas[13][4] = item.val;
}
})
}
})
},
//获取天数据-图表
getDayData(year, month) {
let that = this;
let query1 = {};
query1.page = 0;
query1.year_s = year;
query1.month_s = month;
query1.type = "day_s";
query1.mgroup = this.query.mgroup;
this.$API.enm.mpointstat.list.req(query1).then((response) => {
let seriesData1 = [],
seriesData2 = [],
seriesData3 = [],
seriesData4 = [],
seriesData5 = [],
seriesData6 = [];
let data = response;
data.forEach((item) => {
let ind = item.day_s - 1;
if (item.mpoint_nickname == "袋装水泥总和") {
seriesData1[ind] = item.val;
}else if (item.mpoint_nickname == "散装水泥总和"){
seriesData2[ind] = item.val;
}else if (item.mpoint_nickname == "出厂熟料") {
seriesData3[ind] = item.val;
}else if (item.mpoint_nickname == "出厂水泥") {
seriesData4[ind] = item.val;
}else if (item.mpoint_nickname == "复合水泥合计" || item.mpoint_nickname == "复合硅酸盐水泥;42.5R;袋装水泥") {
seriesData5[ind] = item.val;
}else if(item.mpoint_nickname == "水泥包装用电合计"){
seriesData6[ind] = item.elec_consume_unit;
}
});
let options = { ...that.option1 };
options.series[0].data = seriesData1;
options.series[1].data = seriesData2;
options.series[2].data = seriesData3;
options.series[3].data = seriesData4;
options.series[4].data = seriesData5;
options.series[5].data = seriesData6;
let dayXAxis = [];
for (let i = 1; i <= that.days; i++) {
let item = i + "日";
dayXAxis.push(item);
}
options.xAxis.data = dayXAxis;
that.optionDay = options;
});
},
//获取月数据-图表
getMonthData(year) {
let that = this;
let params5 = {};
params5.page = 0;
params5.year = year;
params5.mgroup = that.query.mgroup;
this.$API.mtm.goal.list
.req(params5)
.then((res5) => {
if (res5.length > 0) {
let data5 = res5;
data5.forEach((item5) => {
if (
item5.goal_cate_name ==
"单位产品分布电耗kW·h/t"
) {
that.goal_list.push(item5);
}
});
}
}).then(() => {
let query2 = {};
query2.page = 0;
query2.year_s = year;
query2.type = "month_s";
query2.mgroup = that.query.mgroup;
this.$API.enm.mpointstat.list.req(query2).then((response) => {
let
seriesData1 = [],
seriesData2 = [],
seriesData3 = [],
seriesData4 = [],
seriesData5 = [],
seriesData6 = [],
seriesData7 = [];
let data = response;
data.forEach((item) => {
let goal_index = 'goal_val_' + item.month_s;
let ind = item.month_s - 1;
if (item.mpoint_nickname == "袋装水泥总和") {
seriesData1[ind] = item.val;
}else if (item.mpoint_nickname == "散装水泥总和"){
seriesData2[ind] = item.val;
}else if (item.mpoint_nickname == "出厂熟料") {
seriesData3[ind] = item.val;
}else if (item.mpoint_nickname == "出厂水泥") {
seriesData4[ind] = item.val;
}else if (item.mpoint_nickname == "复合水泥合计" || item.mpoint_nickname == "复合硅酸盐水泥;42.5R;袋装水泥") {
console.log(item.mpoint_nickname, item.val);
seriesData5[ind] = item.val;
}else if(item.mpoint_nickname == "水泥包装用电合计"){
seriesData7[ind] = item.elec_consume_unit;
}
seriesData6[ind] = that.goal_list[0][goal_index];
});
let options = { ...that.option2 };
options.series[0].data = seriesData1;
options.series[1].data = seriesData2;
options.series[2].data = seriesData3;
options.series[3].data = seriesData4;
options.series[4].data = seriesData5;
options.series[5].data = seriesData6;
options.series[6].data = seriesData7;
let monthXAxis = [];
if (year < that.year){
that.month = 12;
}
for (let i = 1; i <= that.month; i++) {
let item = i + "月";
monthXAxis.push(item);
}
options.xAxis.data = monthXAxis;
that.optionMonth = options;
});
})
},
itemClick(type, item) {
this.type = type;
this.cate = item[1];
this.asynDialog = true;
},
itemClick1(type, item) {
this.chartShow = false;
this.$API.bi.dataset.exec.req("3322567213885833216").then((res) => {
this.myOption = JSON.parse(res.echart_options);
debugger;
this.chartShow = true;
});
},
handlePrint() {
this.$PRINT("#myReport");
},
exportExcel() {
this.exportLoading = true;
this.$XLSX("#myTable", this.tableName);
this.exportLoading = false;
},
},
};
</script>
<style scoped>
.printContainer {
padding-left: 20px;
}
.printWrap {
overflow-x: auto;
}
.radioWrap {
display: flex;
justify-content: center;
padding-top: 10px;
position: relative;
}
</style>