|
|
|
<template>
|
|
|
|
<div class="warning-box">
|
|
|
|
<cpt-card>
|
|
|
|
<div class="card-title">
|
|
|
|
<img class="title-icon" src="../../../../assets/img/shuju/title-tip.png" />
|
|
|
|
<div class="title-label">
|
|
|
|
党员信息统计
|
|
|
|
<!-- <el-cascader
|
|
|
|
v-model="selectAgency"
|
|
|
|
:options="propTree"
|
|
|
|
:props="{ checkStrictly: true }"
|
|
|
|
:show-all-levels="false"
|
|
|
|
:getCheckedNodes="getCheckedNodes"
|
|
|
|
clearable @change="handleCascader">
|
|
|
|
</el-cascader> -->
|
|
|
|
<el-cascader
|
|
|
|
v-model="partyOrgs"
|
|
|
|
:options="partyOrgList"
|
|
|
|
:props="{
|
|
|
|
label: 'partyOrgName',
|
|
|
|
value: 'id',
|
|
|
|
checkStrictly: true
|
|
|
|
}"
|
|
|
|
:show-all-levels="false"
|
|
|
|
clearable @change="handlePartyCascader">
|
|
|
|
</el-cascader>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="card-echart">
|
|
|
|
<div class="card-left">
|
|
|
|
<div class="card-left-title">党员年龄统计</div>
|
|
|
|
<div class="card-flex">
|
|
|
|
<div class="echart-wr">
|
|
|
|
<!-- <div class="echart-cicle"></div> -->
|
|
|
|
<screen-echarts-frame class="echart-org"
|
|
|
|
@myChartMethod="pieInitOk"
|
|
|
|
ref="ageChart"></screen-echarts-frame>
|
|
|
|
<!-- <div id="echartOrg" class="echart-org"></div> -->
|
|
|
|
</div>
|
|
|
|
<div class="echarts-tips echarts-tips-wd50">
|
|
|
|
<div class="tips-lists">
|
|
|
|
<div v-for="(item, index) in ageItem" :key="index" class="tips-items">
|
|
|
|
<div class="tips-items-title" :class="'tips-items-title' + item.code">
|
|
|
|
{{ item.name }}
|
|
|
|
</div>
|
|
|
|
<div class="tips-items-num">
|
|
|
|
<div class="tips-item-count">{{item.value}}</div>
|
|
|
|
<div class="tips-item-has">{{ item.radio }}</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
<div class="ecahrts-button">
|
|
|
|
<el-button type="warning" size="small" @click="handleExport('age')">导出</el-button>
|
|
|
|
</div>
|
|
|
|
<div class="warning-box-bottom">
|
|
|
|
<screen-table
|
|
|
|
:headerList="headerList"
|
|
|
|
:tableData="ageList"
|
|
|
|
:headerStyle="headerStyle"
|
|
|
|
:tableContentStyle="headerStyle"
|
|
|
|
:visibleLoading="visibleAgeLoading"
|
|
|
|
:operate="false"
|
|
|
|
@row="handleClickRow"
|
|
|
|
></screen-table>
|
|
|
|
<div class="pagination">
|
|
|
|
<el-pagination
|
|
|
|
:current-page="agePageNo"
|
|
|
|
:page-size="agePageSize"
|
|
|
|
background
|
|
|
|
layout="prev, pager, next"
|
|
|
|
@size-change="pageSizeChangeHandleAge"
|
|
|
|
@current-change="pageCurrentChangeHandleAge"
|
|
|
|
:total="ageTotal"
|
|
|
|
>
|
|
|
|
</el-pagination>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="card-left">
|
|
|
|
<div class="card-left-title">党员学历统计</div>
|
|
|
|
<div class="card-flex">
|
|
|
|
<div class="echart-wr echart-wr100">
|
|
|
|
<!-- <div class="echart-cicle echart-cicle0"></div> -->
|
|
|
|
<!-- <div id="echartType" class="echart-org"></div> -->
|
|
|
|
<screen-echarts-frame class="echart-org"
|
|
|
|
@myChartMethod="pieInitOks"
|
|
|
|
ref="eduChart"></screen-echarts-frame>
|
|
|
|
</div>
|
|
|
|
<div v-if="false" class="echarts-tips">
|
|
|
|
<div class="tips-list">
|
|
|
|
<div v-for="item in eduItem" :key="item.value" class="tips-item">
|
|
|
|
<div class="tips-item-icon" :style="'background:' + item.color"></div>
|
|
|
|
<div class="tips-item-text">{{item.name}}</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="ecahrts-button">
|
|
|
|
<el-button type="warning" size="small" @click="handleExport('edu')">导出</el-button>
|
|
|
|
</div>
|
|
|
|
<div class="warning-box-bottom">
|
|
|
|
<screen-table
|
|
|
|
:headerList="headerEduList"
|
|
|
|
:tableData="eduList"
|
|
|
|
:headerStyle="headerStyle"
|
|
|
|
:tableContentStyle="headerStyle"
|
|
|
|
:visibleLoading="visibleLoading"
|
|
|
|
:operate="false"
|
|
|
|
@row="handleClickRow"
|
|
|
|
></screen-table>
|
|
|
|
<div class="pagination">
|
|
|
|
<el-pagination
|
|
|
|
:current-page="pageNo"
|
|
|
|
:page-size="pageSize"
|
|
|
|
background
|
|
|
|
layout="prev, pager, next"
|
|
|
|
@size-change="pageSizeChangeHandleNew"
|
|
|
|
@current-change="pageCurrentChangeHandleNew"
|
|
|
|
:total="total"
|
|
|
|
>
|
|
|
|
</el-pagination>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
</cpt-card>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import { requestPost, requestGet } from "@/js/dai/request";
|
|
|
|
import screenTable from "../components/screen-table/index";
|
|
|
|
import cptCard from "@/views/modules/visual/cpts/card";
|
|
|
|
import nextTick from "dai-js/tools/nextTick";
|
|
|
|
import screenEchartsFrame from "../components/screen-echarts-frame";
|
|
|
|
import { pieOption } from './options'
|
|
|
|
|
|
|
|
import * as echarts from 'echarts';
|
|
|
|
export default {
|
|
|
|
name: "warning-box",
|
|
|
|
components: {
|
|
|
|
cptCard,
|
|
|
|
screenTable,
|
|
|
|
screenEchartsFrame
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
headerList: [
|
|
|
|
{ title: "序号", coulmn: 'index' },
|
|
|
|
{ title: "姓名", coulmn: 'name' },
|
|
|
|
{ title: "年龄", coulmn: 'age' },
|
|
|
|
{ title: "手机号码", coulmn: 'mobile' }
|
|
|
|
],
|
|
|
|
headerStyle: [
|
|
|
|
{
|
|
|
|
'max-width': '60px'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'min-width': '100px'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'min-width': '100px'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'min-width': '160px'
|
|
|
|
}
|
|
|
|
],
|
|
|
|
headerEduList: [
|
|
|
|
{ title: "序号", coulmn: 'index' },
|
|
|
|
{ title: "姓名", coulmn: 'name' },
|
|
|
|
{ title: "学历", coulmn: 'education' },
|
|
|
|
{ title: "手机号码", coulmn: 'mobile' }
|
|
|
|
],
|
|
|
|
tableData: [
|
|
|
|
// [1,'商丘路社区第一网格','商丘路小区','2号楼','杨颖、王平、刘佳敏、丁辉、杨萍'],
|
|
|
|
],
|
|
|
|
noInit: false,
|
|
|
|
noEduInit: false,
|
|
|
|
selectAgency: null,
|
|
|
|
ageTotalCount: 0,
|
|
|
|
eduTotalCount: 0,
|
|
|
|
propTree: [],
|
|
|
|
value2: '',
|
|
|
|
visibleAgeLoading: true,
|
|
|
|
visibleLoading: true,
|
|
|
|
agencyId: '',
|
|
|
|
orgType: '',
|
|
|
|
ageCode: '',
|
|
|
|
eduCode: '',
|
|
|
|
pageNo: 1,
|
|
|
|
pageSize: 10,
|
|
|
|
agePageNo: 1,
|
|
|
|
agePageSize: 10,
|
|
|
|
total: 0,
|
|
|
|
ageTotal: 0,
|
|
|
|
eduItem: [
|
|
|
|
{
|
|
|
|
name: '小学',
|
|
|
|
value: 0,
|
|
|
|
color: 'rgba(27, 81, 255, 1)'
|
|
|
|
}, {
|
|
|
|
name: '初中',
|
|
|
|
value: 1,
|
|
|
|
color: 'rgba(0, 229, 237, 1)'
|
|
|
|
}, {
|
|
|
|
name: '高中',
|
|
|
|
value: 2,
|
|
|
|
color: 'rgba(120, 0, 255, 1)'
|
|
|
|
}, {
|
|
|
|
name: '中专',
|
|
|
|
value: 3,
|
|
|
|
color: 'rgba(255, 120, 0, 1)'
|
|
|
|
}, {
|
|
|
|
name: '大专',
|
|
|
|
value: 4,
|
|
|
|
color: 'rgba(255, 186, 0, 1)'
|
|
|
|
}, {
|
|
|
|
name: '本科',
|
|
|
|
value: 5,
|
|
|
|
color: 'rgba(22, 215, 131, 1)'
|
|
|
|
}, {
|
|
|
|
name: '硕士',
|
|
|
|
value: 6,
|
|
|
|
color: 'rgba(42, 0, 255, 1)'
|
|
|
|
}, {
|
|
|
|
name: '博士',
|
|
|
|
value: 7,
|
|
|
|
color: 'rgba(198, 0, 255, 1)'
|
|
|
|
}, {
|
|
|
|
name: '其他',
|
|
|
|
value: 8,
|
|
|
|
color: 'rgba(255, 42, 0, 1)'
|
|
|
|
}
|
|
|
|
],
|
|
|
|
ageItem: [
|
|
|
|
{
|
|
|
|
name: '50岁以下',
|
|
|
|
value: 1,
|
|
|
|
color: 'rgba(27, 81, 255, 1)'
|
|
|
|
}, {
|
|
|
|
name: '50-59岁',
|
|
|
|
value: 2,
|
|
|
|
color: 'rgba(0, 229, 237, 1)'
|
|
|
|
}, {
|
|
|
|
name: '60-69岁',
|
|
|
|
value: 3,
|
|
|
|
color: 'rgba(120, 0, 255, 1)'
|
|
|
|
}, {
|
|
|
|
name: '70-79岁',
|
|
|
|
value: 4,
|
|
|
|
color: 'rgba(255, 120, 0, 1)'
|
|
|
|
}, {
|
|
|
|
name: '80岁以上',
|
|
|
|
value: 5,
|
|
|
|
color: 'rgba(255, 186, 0, 1)'
|
|
|
|
}
|
|
|
|
],
|
|
|
|
partyOrgs: [],
|
|
|
|
ageList: [],
|
|
|
|
eduList: [],
|
|
|
|
partyOrgList: [],
|
|
|
|
pieAgeChartS: null,
|
|
|
|
pieEduChartSs: null,
|
|
|
|
pieAgeOptions: null,
|
|
|
|
pieEduOptions: null
|
|
|
|
};
|
|
|
|
},
|
|
|
|
async mounted() {
|
|
|
|
await nextTick(100);
|
|
|
|
// await this.getAgencyList()
|
|
|
|
await this.getPartyOggList()
|
|
|
|
// this.getAgeCount(this.$store.state.user.agencyId, 'agency')
|
|
|
|
// this.getEduCount(this.$store.state.user.agencyId, 'agency')
|
|
|
|
// this.getAgeList(this.$store.state.user.agencyId, 'agency')
|
|
|
|
// this.getEduList(this.$store.state.user.agencyId, 'agency')
|
|
|
|
this.getAgeCount()
|
|
|
|
this.getEduCount()
|
|
|
|
this.getAgeList()
|
|
|
|
this.getEduList()
|
|
|
|
// this.initAgeCharts()
|
|
|
|
// this.initEduCharts()
|
|
|
|
|
|
|
|
// this.initChartType()
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
pieInitOk (dom) {
|
|
|
|
console.log('pie准备好了', dom)
|
|
|
|
this.pieAgeChartS = dom
|
|
|
|
// this.pieInitState = true
|
|
|
|
|
|
|
|
},
|
|
|
|
pieInitOks (dom) {
|
|
|
|
console.log('pies准备好了', dom)
|
|
|
|
this.pieEduChartS = dom
|
|
|
|
// this.pieInitState = true
|
|
|
|
|
|
|
|
},
|
|
|
|
initAgeCharts() {
|
|
|
|
// const eId = document.getElementById('echartOrg')
|
|
|
|
// let _charts = echarts.init(eId)
|
|
|
|
let option = {
|
|
|
|
|
|
|
|
}
|
|
|
|
this.pieAgeOptions = pieOption(this.pieAgeChartS)
|
|
|
|
this.clickAgePie(0)
|
|
|
|
let fun = params => {
|
|
|
|
if (params.seriesIndex == 0 || params.seriesIndex == 2) {
|
|
|
|
this.ageCode = ''
|
|
|
|
this.getAgeList()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
this.clickAgePie(params.dataIndex)
|
|
|
|
}
|
|
|
|
this.$refs.ageChart.handleClick(fun)
|
|
|
|
// option && this.$refs.pieChart.setOption(option);
|
|
|
|
|
|
|
|
},
|
|
|
|
initEduCharts() {
|
|
|
|
// const eId = document.getElementById('echartOrg')
|
|
|
|
// let _charts = echarts.init(eId)
|
|
|
|
let option = {
|
|
|
|
|
|
|
|
}
|
|
|
|
let legend = {
|
|
|
|
show: true,
|
|
|
|
orient: 'vertical',
|
|
|
|
top: '20%',
|
|
|
|
right: 0,
|
|
|
|
textStyle: {
|
|
|
|
width: 90,
|
|
|
|
color: '#fff',
|
|
|
|
rich: {
|
|
|
|
a: {
|
|
|
|
width: 90
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
formatter: name => {
|
|
|
|
for (let a = 0; a < this.eduItem.length; a++) {
|
|
|
|
// this.data 这个数据中有名称和次数
|
|
|
|
if (this.eduItem[a].name === name) {
|
|
|
|
//两个名称进行对比,取出对应的次数
|
|
|
|
let params1 = name + "\n"; //然后return你需要的legend格式即可
|
|
|
|
console.log(params1);
|
|
|
|
let tmp = params1.split("\n");
|
|
|
|
let res = "" + params1;
|
|
|
|
for (let i in tmp) {
|
|
|
|
res = res.replace(tmp[i], "");
|
|
|
|
}
|
|
|
|
return res + params1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
this.pieEduOptions = pieOption(this.pieEduChartS)
|
|
|
|
this.pieEduOptions.legend = { ...legend }
|
|
|
|
// this.pieEduOptions.series[1].width = 400
|
|
|
|
this.clickEduPie(0)
|
|
|
|
let fun = params => {
|
|
|
|
if (params.seriesIndex == 0 || params.seriesIndex == 2) {
|
|
|
|
this.eduCode = ''
|
|
|
|
this.getEduList()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
this.clickEduPie(params.dataIndex)
|
|
|
|
}
|
|
|
|
this.$refs.eduChart.handleClick(fun)
|
|
|
|
// this.noInit = true
|
|
|
|
// option && this.$refs.pieChart.setOption(option);
|
|
|
|
|
|
|
|
},
|
|
|
|
initChartType() {
|
|
|
|
const eId = document.getElementById('echartType')
|
|
|
|
let _charts = echarts.init(eId)
|
|
|
|
|
|
|
|
let option = {
|
|
|
|
tooltip: {
|
|
|
|
trigger: 'item'
|
|
|
|
},
|
|
|
|
legend: {
|
|
|
|
show: true,
|
|
|
|
orient: 'vertical',
|
|
|
|
top: '20%',
|
|
|
|
right: 0,
|
|
|
|
textStyle: {
|
|
|
|
width: 90,
|
|
|
|
color: '#fff',
|
|
|
|
rich: {
|
|
|
|
a: {
|
|
|
|
width: 90
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
formatter: name => {
|
|
|
|
for (let a = 0; a < this.eduItem.length; a++) {
|
|
|
|
// this.data 这个数据中有名称和次数
|
|
|
|
if (this.eduItem[a].name === name) {
|
|
|
|
//两个名称进行对比,取出对应的次数
|
|
|
|
let params1 = name + "\n"; //然后return你需要的legend格式即可
|
|
|
|
console.log(params1);
|
|
|
|
let tmp = params1.split("\n");
|
|
|
|
let res = "" + params1;
|
|
|
|
for (let i in tmp) {
|
|
|
|
res = res.replace(tmp[i], "");
|
|
|
|
}
|
|
|
|
return res + params1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
title: {
|
|
|
|
text: '12000', //图形标题,配置在中间对应效果图的80%
|
|
|
|
subtext: '总数',
|
|
|
|
left: 196,
|
|
|
|
top: "center",
|
|
|
|
textAlign: 'center',
|
|
|
|
textStyle: {
|
|
|
|
color: "#fff",
|
|
|
|
fontSize: 28,
|
|
|
|
align: "center"
|
|
|
|
},
|
|
|
|
subtextStyle: {
|
|
|
|
fontSize: 16,
|
|
|
|
color: '#fff',
|
|
|
|
align: 'center'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
series: [
|
|
|
|
{
|
|
|
|
// name: 'Access From',
|
|
|
|
type: 'pie',
|
|
|
|
// center: ['50%', '50%'],
|
|
|
|
radius: ['40%', '60%'],
|
|
|
|
avoidLabelOverlap: true,
|
|
|
|
// top: top + '%',
|
|
|
|
// height: '80%',
|
|
|
|
// left: 0,
|
|
|
|
width: 400,
|
|
|
|
label: {
|
|
|
|
position: 'outside',
|
|
|
|
alignTo: 'edge',
|
|
|
|
formatter: '{a|{c}}\n{r|}\n{name|{b}}',
|
|
|
|
minMargin: 5,
|
|
|
|
edgeDistance: 20,
|
|
|
|
lineHeight: 15,
|
|
|
|
color: '#fff',
|
|
|
|
fontSize: 15,
|
|
|
|
rich: {
|
|
|
|
name: {
|
|
|
|
padding: [0, 6, 0, 6]
|
|
|
|
},
|
|
|
|
a: {
|
|
|
|
fontSize: 15,
|
|
|
|
color: '#fff',
|
|
|
|
padding: [0, 6, 0, 6]
|
|
|
|
},
|
|
|
|
r: {
|
|
|
|
backgroundColor: 'auto',
|
|
|
|
borderRadius: 6,
|
|
|
|
width: 6,
|
|
|
|
height: 6,
|
|
|
|
// padding: [3, 3, 0, -12]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
emphasis: {
|
|
|
|
label: {
|
|
|
|
show: true,
|
|
|
|
fontSize: '14',
|
|
|
|
fontWeight: 'bold'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
labelLine: {
|
|
|
|
show: true,
|
|
|
|
length: 20,
|
|
|
|
length2: 0,
|
|
|
|
maxSurfaceAngle: 80
|
|
|
|
},
|
|
|
|
labelLayout: function (params) {
|
|
|
|
const isLeft = params.labelRect.x < _charts.getWidth() / 2;
|
|
|
|
const points = params.labelLinePoints;
|
|
|
|
// Update the end point.
|
|
|
|
points[2][0] = isLeft
|
|
|
|
? params.labelRect.x
|
|
|
|
: params.labelRect.x + params.labelRect.width;
|
|
|
|
return {
|
|
|
|
labelLinePoints: points
|
|
|
|
};
|
|
|
|
},
|
|
|
|
data: this.eduItem
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
option && _charts.setOption(option);
|
|
|
|
|
|
|
|
},
|
|
|
|
clickAgePie (seriesIndex) {
|
|
|
|
let _code = ''
|
|
|
|
let isClick = false
|
|
|
|
console.log('seriesIndex---', seriesIndex)
|
|
|
|
this.ageItem.forEach((element, index) => {
|
|
|
|
if (index === seriesIndex) {
|
|
|
|
_code = element.code
|
|
|
|
|
|
|
|
if (!this.noInit) isClick = false
|
|
|
|
else {
|
|
|
|
element.isClick = !element.isClick
|
|
|
|
isClick = element.isClick
|
|
|
|
}
|
|
|
|
|
|
|
|
element.label = {
|
|
|
|
show: true,
|
|
|
|
|
|
|
|
};
|
|
|
|
element.labelLine = {
|
|
|
|
show: true,
|
|
|
|
lineStyle: {
|
|
|
|
opacity: 1,
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
console.log('zlcm', element)
|
|
|
|
} else {
|
|
|
|
element.isClick = false
|
|
|
|
element.label = {
|
|
|
|
show: false,
|
|
|
|
|
|
|
|
};
|
|
|
|
element.labelLine = {
|
|
|
|
show: false,
|
|
|
|
lineStyle: {
|
|
|
|
opacity: 0,
|
|
|
|
color: 'rgba(255,255,255,0)'
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
});
|
|
|
|
this.ageCode = isClick && _code || ''
|
|
|
|
this.pieAgeOptions.title.text = this.ageTotalCount
|
|
|
|
this.pieAgeOptions.series[1].data = this.ageItem
|
|
|
|
// this.$refs.pieChart.hideLoading()
|
|
|
|
this.$refs.ageChart.setOption(this.pieAgeOptions)
|
|
|
|
if (this.noInit) {
|
|
|
|
// const _arr = this.selectAgency[this.selectAgency.length - 1].split('-')
|
|
|
|
// const orgType = _arr[1] !== 'grid' ? 'agency': 'grid'
|
|
|
|
// console.log('zlcm---isClick', isClick)
|
|
|
|
// this.agePageNo = 1
|
|
|
|
// this.getAgeList(_arr[0], orgType, isClick && _code || '')
|
|
|
|
const i = this.partyOrgs.length - 1
|
|
|
|
this.agePageNo = 1
|
|
|
|
this.getAgeList(this.partyOrgs[i], '', isClick && _code || '')
|
|
|
|
}
|
|
|
|
this.noInit = true
|
|
|
|
|
|
|
|
},
|
|
|
|
clickEduPie (seriesIndex) {
|
|
|
|
let _code = ''
|
|
|
|
let isClick = false
|
|
|
|
this.eduItem.forEach((element, index) => {
|
|
|
|
if (index === seriesIndex) {
|
|
|
|
_code = element.code
|
|
|
|
|
|
|
|
if (!this.noEduInit) isClick = false
|
|
|
|
else {
|
|
|
|
element.isClick = !element.isClick
|
|
|
|
isClick = element.isClick
|
|
|
|
}
|
|
|
|
|
|
|
|
element.label = {
|
|
|
|
show: true,
|
|
|
|
|
|
|
|
};
|
|
|
|
element.labelLine = {
|
|
|
|
show: true,
|
|
|
|
lineStyle: {
|
|
|
|
opacity: 1,
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
console.log('zlcm')
|
|
|
|
} else {
|
|
|
|
element.isClick = false
|
|
|
|
element.label = {
|
|
|
|
show: false,
|
|
|
|
|
|
|
|
};
|
|
|
|
element.labelLine = {
|
|
|
|
show: false,
|
|
|
|
lineStyle: {
|
|
|
|
opacity: 0,
|
|
|
|
color: 'rgba(255,255,255,0)'
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
});
|
|
|
|
this.eduCode = isClick && _code || ''
|
|
|
|
this.pieEduOptions.title.text = this.eduTotalCount
|
|
|
|
this.pieEduOptions.series[1].data = this.eduItem
|
|
|
|
// this.$refs.pieChart.hideLoading()
|
|
|
|
this.$refs.eduChart.setOption(this.pieEduOptions)
|
|
|
|
if (this.noEduInit) {
|
|
|
|
// const _arr = this.selectAgency[this.selectAgency.length - 1].split('-')
|
|
|
|
// const orgType = _arr[1] !== 'grid' ? 'agency': 'grid'
|
|
|
|
// this.pageNo = 1
|
|
|
|
// this.getEduList(_arr[0], orgType, isClick && _code || '')
|
|
|
|
const i = this.partyOrgs.length - 1
|
|
|
|
this.pageNo = 1
|
|
|
|
this.getEduList(this.partyOrgs[i], '', isClick && _code || '')
|
|
|
|
|
|
|
|
}
|
|
|
|
this.noEduInit = true
|
|
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
async getAgeCount(orgId, orgType) {
|
|
|
|
// const url = "/epmetuser/icresiuser/partymemberagestatistics";
|
|
|
|
const url = '/resi/partymember/icPartyMember/partymemberagestatistics'
|
|
|
|
let params = {
|
|
|
|
orgId: orgId || '',
|
|
|
|
orgType
|
|
|
|
};
|
|
|
|
const { data, code, msg } = await requestPost(url, params);
|
|
|
|
if (code === 0) {
|
|
|
|
const colorList = [
|
|
|
|
{
|
|
|
|
name: '50岁以下',
|
|
|
|
value: 1,
|
|
|
|
color: '#FAC126'
|
|
|
|
}, {
|
|
|
|
name: '50-59岁',
|
|
|
|
value: 2,
|
|
|
|
color: '#3DDA83'
|
|
|
|
}, {
|
|
|
|
name: '60-69岁',
|
|
|
|
value: 3,
|
|
|
|
color: '#A800FF'
|
|
|
|
}, {
|
|
|
|
name: '70-79岁',
|
|
|
|
value: 4,
|
|
|
|
color: '#2865FA'
|
|
|
|
}, {
|
|
|
|
name: '80岁以上',
|
|
|
|
value: 5,
|
|
|
|
color: '#00DAD2'
|
|
|
|
}
|
|
|
|
]
|
|
|
|
this.ageItem = data.map((item, index) => {
|
|
|
|
return {
|
|
|
|
...item,
|
|
|
|
name: item.label,
|
|
|
|
isClick: false,
|
|
|
|
itemStyle: {
|
|
|
|
color: colorList[index].color
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
this.ageTotalCount = 0
|
|
|
|
data.forEach(item => {
|
|
|
|
this.ageTotalCount += Number(item.value)
|
|
|
|
})
|
|
|
|
this.initAgeCharts()
|
|
|
|
} else {
|
|
|
|
}
|
|
|
|
},
|
|
|
|
async getEduCount(orgId, orgType) {
|
|
|
|
// const url = "/epmetuser/icresiuser/partymembereducationstatistics";
|
|
|
|
const url = '/resi/partymember/icPartyMember/partymembereducationstatistics'
|
|
|
|
let params = {
|
|
|
|
orgId: orgId || '',
|
|
|
|
orgType
|
|
|
|
};
|
|
|
|
const { data, code, msg } = await requestPost(url, params);
|
|
|
|
if (code === 0) {
|
|
|
|
this.eduItem = data.map(item => {
|
|
|
|
return {
|
|
|
|
...item,
|
|
|
|
name: item.label,
|
|
|
|
isClick: false
|
|
|
|
}
|
|
|
|
})
|
|
|
|
this.eduTotalCount = 0
|
|
|
|
data.forEach(item => {
|
|
|
|
this.eduTotalCount += Number(item.value)
|
|
|
|
})
|
|
|
|
this.initEduCharts()
|
|
|
|
} else {
|
|
|
|
}
|
|
|
|
},
|
|
|
|
async getAgeList(orgId, orgType, _code) {
|
|
|
|
|
|
|
|
this.visibleAgeLoading = true
|
|
|
|
// const url = "/epmetuser/icresiuser/partymemberagelist";
|
|
|
|
const url = '/resi/partymember/icPartyMember/partymemberagelist'
|
|
|
|
let params = {
|
|
|
|
orgId: orgId || '',
|
|
|
|
orgType,
|
|
|
|
code: _code || '',
|
|
|
|
pageNo: this.agePageNo,
|
|
|
|
pageSize: this.agePageSize
|
|
|
|
};
|
|
|
|
const { data, code, msg } = await requestPost(url, params);
|
|
|
|
if (code === 0) {
|
|
|
|
this.ageList = data.list.map((item, index) => {
|
|
|
|
return {
|
|
|
|
...item,
|
|
|
|
index: index + 1
|
|
|
|
}
|
|
|
|
})
|
|
|
|
this.ageTotal = data.total
|
|
|
|
} else {
|
|
|
|
this.$message.error(msg)
|
|
|
|
}
|
|
|
|
// if (_code == 0 || _code) this.noInit = true
|
|
|
|
this.visibleAgeLoading = false
|
|
|
|
},
|
|
|
|
async getEduList(orgId, orgType, _code) {
|
|
|
|
this.visibleLoading = true
|
|
|
|
// const url = "/epmetuser/icresiuser/partymembereducationlist";
|
|
|
|
const url = '/resi/partymember/icPartyMember/partymembereducationlist'
|
|
|
|
let params = {
|
|
|
|
orgId: orgId || '',
|
|
|
|
orgType,
|
|
|
|
code: _code || '',
|
|
|
|
pageNo: this.pageNo,
|
|
|
|
pageSize: this.pageSize
|
|
|
|
};
|
|
|
|
const { data, code, msg } = await requestPost(url, params);
|
|
|
|
if (code === 0) {
|
|
|
|
this.eduList = data.list.map((item, index) => {
|
|
|
|
return {
|
|
|
|
...item,
|
|
|
|
index: index + 1
|
|
|
|
}
|
|
|
|
})
|
|
|
|
console.log('eduList----', this.eduList)
|
|
|
|
this.total = data.total
|
|
|
|
} else {
|
|
|
|
this.$message.error(msg)
|
|
|
|
}
|
|
|
|
this.visibleLoading = false
|
|
|
|
},
|
|
|
|
async getPartyOggList(node, resolve) {
|
|
|
|
// const url = "/gov/org/customeragency/staffinagencylist";
|
|
|
|
// const url = '/gov/org/customeragency/agencygridtree'
|
|
|
|
// const url = '/resi/partymember/icPartyOrg/getTreelist'
|
|
|
|
const url ='/resi/partymember/icPartyOrg/getSearchTreelist'
|
|
|
|
let params = {
|
|
|
|
agencyId: this.$store.state.user.agencyId,
|
|
|
|
};
|
|
|
|
const { data, code, msg } = await requestGet(url, params);
|
|
|
|
console.log('data-orgparty----o', data)
|
|
|
|
if (code === 0) {
|
|
|
|
|
|
|
|
this.partyOrgList = this.deepArrTOnull(data)
|
|
|
|
|
|
|
|
} else {
|
|
|
|
}
|
|
|
|
},
|
|
|
|
deepArrTOnull(arr) {
|
|
|
|
let a = []
|
|
|
|
a = arr.map(item => {
|
|
|
|
return {
|
|
|
|
...item,
|
|
|
|
children: (item.children.length > 0 && this.deepArrTOnull(item.children) )|| null
|
|
|
|
}
|
|
|
|
})
|
|
|
|
return a
|
|
|
|
},
|
|
|
|
async getAgencyList(node, resolve) {
|
|
|
|
// const url = "/gov/org/customeragency/staffinagencylist";
|
|
|
|
const url = '/gov/org/customeragency/agencygridtree'
|
|
|
|
// let params = {
|
|
|
|
// agencyId: this.$store.state.user.agencyId,
|
|
|
|
// };
|
|
|
|
const { data, code, msg } = await requestPost(url);
|
|
|
|
if (code === 0) {
|
|
|
|
console.log('data-org----o', data)
|
|
|
|
this.selectAgency = [`${data.agencyId}-${data.level}`]
|
|
|
|
this.orgType = data.level
|
|
|
|
this.agencyId = data.agencyId
|
|
|
|
let arr = []
|
|
|
|
arr.push(data)
|
|
|
|
this.propTree = arr && this.getTreeData(arr)
|
|
|
|
|
|
|
|
} else {
|
|
|
|
}
|
|
|
|
},
|
|
|
|
getTreeData(data){
|
|
|
|
if (!Array.isArray(data)) return []
|
|
|
|
let arr = data.map(item => {
|
|
|
|
let _item = {}
|
|
|
|
if (item.subAgencyList) {
|
|
|
|
if (item.subAgencyList.length === 0) {
|
|
|
|
_item = {
|
|
|
|
label: item.agencyName,
|
|
|
|
value: item.agencyId + '-' + item.level,
|
|
|
|
level: item.level,
|
|
|
|
children: undefined
|
|
|
|
}
|
|
|
|
} else _item = {
|
|
|
|
label: item.agencyName,
|
|
|
|
value: item.agencyId + '-' + item.level,
|
|
|
|
level: item.level,
|
|
|
|
children: this.getTreeData(item.subAgencyList)}
|
|
|
|
} else {
|
|
|
|
_item = {
|
|
|
|
label: item.agencyName,
|
|
|
|
value: item.agencyId + '-' + item.level,
|
|
|
|
level: item.level,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return _item
|
|
|
|
})
|
|
|
|
return arr
|
|
|
|
},
|
|
|
|
handleClickRow(val) {
|
|
|
|
console.log('click-row----', val)
|
|
|
|
if (!val.icResiUser) {
|
|
|
|
return this.$message.warning('该党员居民信息未完善')
|
|
|
|
}
|
|
|
|
this.$router.push({
|
|
|
|
path: `/main-shuju/visual-basicinfo-people/${val.icResiUser}`,
|
|
|
|
});
|
|
|
|
},
|
|
|
|
handleCascader(val) {
|
|
|
|
console.log('val-vvv', val)
|
|
|
|
const _arr = val[val.length - 1].split('-')
|
|
|
|
const orgType = _arr[1] !== 'grid' ? 'agency': 'grid'
|
|
|
|
this.agencyId = _arr[0]
|
|
|
|
this.orgType = orgType
|
|
|
|
this.noInit = false
|
|
|
|
this.noEduInit = false
|
|
|
|
this.getAgeCount(_arr[0], orgType)
|
|
|
|
this.getEduCount(_arr[0], orgType)
|
|
|
|
this.getAgeList(_arr[0], orgType)
|
|
|
|
this.getEduList(_arr[0], orgType)
|
|
|
|
},
|
|
|
|
handlePartyCascader(val) {
|
|
|
|
console.log('val-vvvpppppp', val)
|
|
|
|
this.noInit = false
|
|
|
|
this.noEduInit = false
|
|
|
|
if (val.length > 0) {
|
|
|
|
const i = val.length - 1
|
|
|
|
this.agencyId = val[i]
|
|
|
|
this.getAgeCount(val[i])
|
|
|
|
this.getEduCount(val[i])
|
|
|
|
this.getAgeList(val[i])
|
|
|
|
this.getEduList(val[i])
|
|
|
|
} else {
|
|
|
|
this.agencyId = ''
|
|
|
|
this.getAgeCount('')
|
|
|
|
this.getEduCount('')
|
|
|
|
this.getAgeList('')
|
|
|
|
this.getEduList('')
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
getCheckedNodes(val) {
|
|
|
|
console.log('val-nnn', val)
|
|
|
|
},
|
|
|
|
lazyLoad(node, resolve) {
|
|
|
|
setTimeout(() => {
|
|
|
|
this.getAgeList(node, resolve)
|
|
|
|
}, 500)
|
|
|
|
},
|
|
|
|
pageSizeChangeHandleAge(val) {
|
|
|
|
this.agePageNo = 1
|
|
|
|
this.agePageSize = val
|
|
|
|
this.getAgeList(this.agencyId, this.orgType, this.ageCode)
|
|
|
|
},
|
|
|
|
pageCurrentChangeHandleAge (val) {
|
|
|
|
this.agePageNo = val
|
|
|
|
this.getAgeList(this.agencyId, this.orgType, this.ageCode)
|
|
|
|
},
|
|
|
|
pageSizeChangeHandleNew(val) {
|
|
|
|
this.pageNo = 1;
|
|
|
|
this.pageSize = val;
|
|
|
|
this.getEduList(this.agencyId, this.orgType, this.eduCode)
|
|
|
|
},
|
|
|
|
pageCurrentChangeHandleNew(val) {
|
|
|
|
this.pageNo = val;
|
|
|
|
this.getEduList(this.agencyId, this.orgType, this.eduCode)
|
|
|
|
},
|
|
|
|
async handleExport(type) {
|
|
|
|
const urls = {
|
|
|
|
age: '/epmetuser/icresiuser/partymemberagelist/export',
|
|
|
|
edu: '/epmetuser/icresiuser/partymembereducationlist/export'
|
|
|
|
}
|
|
|
|
const _arr = this.selectAgency[this.selectAgency.length - 1].split('-')
|
|
|
|
const orgType = _arr[1] !== 'grid' ? 'agency': 'grid'
|
|
|
|
let params = {
|
|
|
|
orgId: _arr[0],
|
|
|
|
orgType: orgType,
|
|
|
|
code: type == 'age' ? this.ageCode : this.eduCode,
|
|
|
|
}
|
|
|
|
// .post('epmetuser/icresiuser/exportExcel', params)
|
|
|
|
await this.$http({
|
|
|
|
method: 'POST',
|
|
|
|
url: urls[type],
|
|
|
|
responseType: 'blob',
|
|
|
|
data: params
|
|
|
|
})
|
|
|
|
.then(res => {
|
|
|
|
console.log('resllll', res)
|
|
|
|
let fileName = window.decodeURI(res.headers["content-disposition"].split(";")[1].split("=")[1])
|
|
|
|
console.log('filename', fileName)
|
|
|
|
let blob = new Blob([res.data], { type: 'application/vnd.ms-excel' })
|
|
|
|
var url = window.URL.createObjectURL(blob)
|
|
|
|
var aLink = document.createElement('a')
|
|
|
|
aLink.style.display = 'none'
|
|
|
|
aLink.href = url
|
|
|
|
aLink.setAttribute('download', fileName)
|
|
|
|
document.body.appendChild(aLink)
|
|
|
|
aLink.click()
|
|
|
|
document.body.removeChild(aLink) //下载完成移除元素
|
|
|
|
window.URL.revokeObjectURL(url) //释放掉blob对象
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log('获取导出失败', err)
|
|
|
|
return this.$message.error('网络错误')
|
|
|
|
})
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style
|
|
|
|
lang="scss"
|
|
|
|
src="@/assets/scss/modules/visual/warning.scss"
|
|
|
|
scoped
|
|
|
|
></style>
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
.card-title {
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
cursor: pointer;
|
|
|
|
.title-icon {
|
|
|
|
display: block;
|
|
|
|
width: 46px;
|
|
|
|
height: 34px;
|
|
|
|
box-sizing: border-box;
|
|
|
|
margin-right: 6px;
|
|
|
|
}
|
|
|
|
::v-deep .el-dropdown {
|
|
|
|
font-size: 18px;
|
|
|
|
color: #fff;
|
|
|
|
font-weight: 800;
|
|
|
|
}
|
|
|
|
.title-time {
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
box-sizing: border-box;
|
|
|
|
margin-left: 30px;
|
|
|
|
font-size: 14px;
|
|
|
|
color: #fff;
|
|
|
|
.title-time-label {
|
|
|
|
margin-right: 10px;
|
|
|
|
}
|
|
|
|
::v-deep .el-date-editor--month {
|
|
|
|
width: 100px;
|
|
|
|
.el-input__inner {
|
|
|
|
width: 100px;
|
|
|
|
height: 24px;
|
|
|
|
box-sizing: border-box;
|
|
|
|
padding: 0;
|
|
|
|
font-size: 14px;
|
|
|
|
color: #fff;
|
|
|
|
line-height: 24px;
|
|
|
|
text-align: center;
|
|
|
|
background: #06186D;
|
|
|
|
border: 1px solid #1A64CC;
|
|
|
|
border-radius: 2px;
|
|
|
|
}
|
|
|
|
.el-input__prefix {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
.el-input__suffix {
|
|
|
|
right: 0;
|
|
|
|
.el-input__icon {
|
|
|
|
line-height: 24px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.title-label {
|
|
|
|
font-size: 20px;
|
|
|
|
font-weight: 800;
|
|
|
|
::v-deep .el-input {
|
|
|
|
|
|
|
|
width: 180px;
|
|
|
|
.el-input__inner {
|
|
|
|
font-size: 18px;
|
|
|
|
// font-weight: 800;
|
|
|
|
color: #fff;
|
|
|
|
background: #06186d;
|
|
|
|
border: 1px solid #1a64cc;
|
|
|
|
}
|
|
|
|
.el-icon-arrow-down::before {
|
|
|
|
content: "\e790";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.card-echart {
|
|
|
|
display: flex;
|
|
|
|
margin-top: 40px;
|
|
|
|
height: 100%;
|
|
|
|
.card-left {
|
|
|
|
position: relative;
|
|
|
|
flex: 1;
|
|
|
|
// display: flex;
|
|
|
|
height: 100%;
|
|
|
|
.card-flex {
|
|
|
|
width: 100%;
|
|
|
|
display: flex;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.card-left-title {
|
|
|
|
position: relative;
|
|
|
|
padding-left: 40px;
|
|
|
|
font-size: 16px;
|
|
|
|
font-weight: 500;
|
|
|
|
color: #fff;
|
|
|
|
}
|
|
|
|
.card-left-title::after {
|
|
|
|
content: '';
|
|
|
|
position: absolute;
|
|
|
|
top: 50%;
|
|
|
|
left: 20px;
|
|
|
|
width: 12px;
|
|
|
|
height: 12px;
|
|
|
|
box-sizing: border-box;
|
|
|
|
margin-top: -6px;
|
|
|
|
background: #2865FA;
|
|
|
|
border-radius: 50%;
|
|
|
|
}
|
|
|
|
.echart-wr {
|
|
|
|
position: relative;
|
|
|
|
flex-shrink: 0;
|
|
|
|
width: 50%;
|
|
|
|
height: 320px;
|
|
|
|
box-sizing: border-box;
|
|
|
|
.echart-org {
|
|
|
|
width: 100%;
|
|
|
|
height: 100%;
|
|
|
|
}
|
|
|
|
.echart-cicle {
|
|
|
|
position: absolute;
|
|
|
|
top: 50%;
|
|
|
|
left: 50%;
|
|
|
|
width: 240px;
|
|
|
|
height: 240px;
|
|
|
|
box-sizing: border-box;
|
|
|
|
margin-top: -120px;
|
|
|
|
margin-left: -120px;
|
|
|
|
border: 1px dashed rgba(0, 96, 240, 1);
|
|
|
|
border-radius: 50%;
|
|
|
|
}
|
|
|
|
.echart-cicle0 {
|
|
|
|
left: 80px;
|
|
|
|
margin-left: 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.echart-wr100 {
|
|
|
|
width: 70%;
|
|
|
|
}
|
|
|
|
.echarts-tips {
|
|
|
|
width: 40%;
|
|
|
|
// flex: 1;
|
|
|
|
display: flex;
|
|
|
|
justify-content: center;
|
|
|
|
align-items: center;
|
|
|
|
}
|
|
|
|
.echarts-tips-wd50 {
|
|
|
|
width: 320px;
|
|
|
|
}
|
|
|
|
.tips-list, .tips-item, .tips-lists, .tips-items-num {
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
}
|
|
|
|
.tips-list {
|
|
|
|
// width: 100%;
|
|
|
|
// height: 100%;
|
|
|
|
flex-wrap: wrap;
|
|
|
|
// justify-content: center;
|
|
|
|
.tips-item {
|
|
|
|
// flex: 1;
|
|
|
|
width: 50%;
|
|
|
|
margin-top: 20px;
|
|
|
|
// margin-right: 40px;
|
|
|
|
cursor: pointer;
|
|
|
|
.tips-item-icon {
|
|
|
|
width: 20px;
|
|
|
|
height: 10px;
|
|
|
|
box-sizing: border-box;
|
|
|
|
margin-right: 8px;
|
|
|
|
background: #1B51FF;
|
|
|
|
border-radius: 2px;
|
|
|
|
}
|
|
|
|
.tips-item-text {
|
|
|
|
font-size: 16px;
|
|
|
|
color: #D2E7FF;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.tips-lists {
|
|
|
|
width: 100%;
|
|
|
|
box-sizing: border-box;
|
|
|
|
padding: 30px 0 0 30px;
|
|
|
|
flex-wrap: wrap;
|
|
|
|
.tips-items {
|
|
|
|
margin-bottom: 30px;
|
|
|
|
margin-right: 40px;
|
|
|
|
// width: 50%;
|
|
|
|
cursor: pointer;
|
|
|
|
.tips-items-title {
|
|
|
|
position: relative;
|
|
|
|
width: 100px;
|
|
|
|
height: 26px;
|
|
|
|
box-sizing: border-box;
|
|
|
|
padding-left: 6px;
|
|
|
|
font-size: 16px;
|
|
|
|
color: #EFF0F1;
|
|
|
|
background: url('../../../../assets/img/shuju/measure/huang@2x.png') no-repeat left bottom;
|
|
|
|
&1 {
|
|
|
|
background: url('../../../../assets/img/shuju/measure/lv@2x.png') no-repeat left bottom;
|
|
|
|
}
|
|
|
|
&2 {
|
|
|
|
background: url('../../../../assets/img/shuju/measure/zi@2x.png') no-repeat left bottom;
|
|
|
|
}
|
|
|
|
&3 {
|
|
|
|
background: url('../../../../assets/img/shuju/measure/lan@2x.png') no-repeat left bottom;
|
|
|
|
}
|
|
|
|
&4 {
|
|
|
|
background: url('../../../../assets/img/shuju/measure/lanlv@2x.png') no-repeat left bottom;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.tips-items-num {
|
|
|
|
justify-content: space-between;
|
|
|
|
box-sizing: border-box;
|
|
|
|
margin-top: 10px;
|
|
|
|
// padding-right: 30px;
|
|
|
|
font-size: 20px;
|
|
|
|
.tips-item-has {
|
|
|
|
font-size: 14px;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
.warning-box-bottom {
|
|
|
|
height: calc(100% - 500px);
|
|
|
|
box-sizing: border-box;
|
|
|
|
margin: 0;
|
|
|
|
padding: 0 30px;
|
|
|
|
// overflow-y: scroll;
|
|
|
|
}
|
|
|
|
.ecahrts-button {
|
|
|
|
width: 100%;
|
|
|
|
padding-right: 30px;
|
|
|
|
text-align: right;
|
|
|
|
::v-deep .el-button--warning {
|
|
|
|
|
|
|
|
background: linear-gradient(90deg, #0863EA, #3B9FFC);
|
|
|
|
border: 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</style>
|