<template>
|
<div class="main_home">
|
<div class="home_header">
|
<div class="mb10 fs17">下午好,{{ userInfo.realname }}</div>
|
<div class="fs13">
|
今天是 {{ nowDate }} {{ nowWeek }},欢迎访问联合利华事件上报系统管理平台
|
</div>
|
</div>
|
<div class="main">
|
<div class="app_content">
|
<div class="static_card">
|
<div class="card">
|
<div class="header">
|
<div class="left">
|
<div class="fs15">SHE今日提报数量</div>
|
<div class="num">{{ headerData.todaySheNum ||0 }}</div>
|
</div>
|
<!-- <img src="@/assets/icons/home_icon1.png" alt="" />-->
|
</div>
|
<div class="content">
|
<!-- <div>未解决:{{ headerData.sheNum || 0}}</div>-->
|
<!-- <div>已解决:{{ headerData.sheNum || 0}}</div>-->
|
<div>总工单量:{{ headerData.sheNum || 0}}</div>
|
</div>
|
</div>
|
<div class="card">
|
<div class="header">
|
<div class="left">
|
<div class="fs15">跌绊滑今日工单数量</div>
|
<div class="num">{{ headerData.todayDbhNum ||0 }}</div>
|
</div>
|
<!--
|
<img src="@/assets/icons/home_icon2.png" alt="" />
|
-->
|
</div>
|
<div class="content">
|
<div>未解决:{{ headerData.dbhYesNum || 0}}</div>
|
<div>已解决:{{ headerData.dbhNoNum || 0}}</div>
|
<div>总工单量:{{ headerData.dbhNum || 0}}</div>
|
</div>
|
</div>
|
<div class="card">
|
<div class="header">
|
<div class="left">
|
<div class="fs15">DCA今日提交数量</div>
|
<div class="num">{{ headerData.todayDcaNum ||0 }}</div>
|
</div>
|
<!-- <img src="@/assets/icons/home_icon3.png" alt="" />-->
|
</div>
|
<div class="content">
|
<div>符合项:{{ headerData.dcaYesNum || 0}}</div>
|
<div>不符合项:{{ headerData.dcaNoNum || 0}}</div>
|
<div>总提交量:{{ headerData.dcaNum || 0}}</div>
|
</div>
|
</div>
|
<div class="card">
|
<div class="header">
|
<div class="left">
|
<div class="fs15">DCA今日工单数量</div>
|
<div class="num">{{ headerData.todayDcaChildNum ||0 }}</div>
|
</div>
|
<!-- <img src="@/assets/icons/home_icon3.png" alt="" />-->
|
</div>
|
<div class="content">
|
<div>未解决:{{ headerData.dcaChildYesNum || 0}}</div>
|
<div>已解决:{{ headerData.dcaChildNoNum || 0}}</div>
|
<div>总工单量:{{ headerData.dcaChildNum || 0}}</div>
|
</div>
|
</div>
|
</div>
|
<div class="static_wrap">
|
<div class="df mb10">
|
<div class="wrap static1">
|
<div class="header">
|
<div class="home_title">1.SHE事件上报</div>
|
</div>
|
<div class="echart" >
|
<div id="echart0"></div>
|
<div id="echart01"></div>
|
</div>
|
</div>
|
<div class="wrap static2">
|
<div class="header">
|
<div class="home_title">2.深度符合性审查DCA上报记录</div>
|
</div>
|
<div class="echart" >
|
<div id="echart1"> </div>
|
<div id="echart11"> </div>
|
</div>
|
</div>
|
</div>
|
<div class="df">
|
<div class="wrap static3">
|
<div class="header">
|
<div class="home_title">3.深度符合性审查DCA事件工单</div>
|
</div>
|
<div class="echart" >
|
<div id="echart2"> </div>
|
<div id="echart21"> </div>
|
</div>
|
</div>
|
<div class="wrap static4">
|
<div class="header">
|
<div class="home_title">4.跌绊滑风险上报</div>
|
</div>
|
<div class="echart" >
|
<div id="echart3"> </div>
|
<div id="echart31"> </div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</template>
|
|
<script>
|
import dayjs from 'dayjs'
|
import * as echarts from 'echarts'
|
import { weeks } from '@/utils/config'
|
import { getIndexData, getWorkOrderData } from '@/api/business/workorder'
|
const colors = ['#52a4f7', '#7678f7', '#5fc6d5']
|
export default {
|
components: {
|
},
|
data () {
|
return {
|
colors,
|
nowDate: '',
|
nowWeek: '',
|
headerData: {},
|
staticData0: {},
|
staticData01: {},
|
staticData1: {},
|
staticData2: {},
|
staticData3: {},
|
staticData4: {},
|
manningRatio: []
|
}
|
},
|
computed: {
|
userInfo () {
|
return this.$store.state.userInfo
|
}
|
},
|
created () {
|
this.initData()
|
},
|
mounted () {
|
this.updateDate()
|
// this.initData()
|
},
|
methods: {
|
initData () {
|
this.updateDate()
|
this.getWorkHead()
|
this.getWorkBody0()
|
this.getWorkBody1()
|
this.getWorkBody2()
|
this.getWorkBody3()
|
// this.getWorkBody()
|
},
|
getWorkBody0 () {
|
getWorkOrderData({ queryType: 0, orderType: 0 }).then(res => {
|
this.staticData0 = res || []
|
this.initEchart0()
|
})
|
getWorkOrderData({ queryType: 1, orderType: 0 }).then(res => {
|
this.staticData01 = res || []
|
this.initEchart01()
|
})
|
},
|
getWorkBody1 () {
|
getWorkOrderData({ queryType: 0, orderType: 1 }).then(res => {
|
this.staticData1 = res || []
|
this.initEchart1()
|
})
|
getWorkOrderData({ queryType: 1, orderType: 1 }).then(res => {
|
this.staticData11 = res || []
|
this.initEchart11()
|
})
|
},
|
getWorkBody2 () {
|
getWorkOrderData({ queryType: 0, orderType: 2 }).then(res => {
|
this.staticData2 = res || []
|
this.initEchart2()
|
})
|
getWorkOrderData({ queryType: 1, orderType: 2 }).then(res => {
|
this.staticData21 = res || []
|
this.initEchart21()
|
})
|
},
|
getWorkBody3 () {
|
getWorkOrderData({ queryType: 0, orderType: 3 }).then(res => {
|
this.staticData3 = res || []
|
this.initEchart3()
|
})
|
getWorkOrderData({ queryType: 1, orderType: 3 }).then(res => {
|
this.staticData31 = res || []
|
this.initEchart31()
|
})
|
},
|
getWorkHead () {
|
getIndexData({ }).then(res => {
|
this.headerData = res || {}
|
})
|
},
|
updateDate () {
|
this.nowDate = dayjs().format('YYYY年M月D日')
|
this.nowWeek = weeks[new Date().getDay()]
|
},
|
initEchart0 () {
|
this.initEchartDataDo('echart0', this.staticData0.map(i => i.dateStr), this.staticData0.map(i => i.total),'单','bar')
|
},
|
initEchart01 () {
|
this.initEchartDataDo('echart01', this.staticData01.map(i => i.dateStr), this.staticData01.map(i => i.total),'单','line')
|
},
|
initEchart1 () {
|
this.initEchartDataDo('echart1', this.staticData1.map(i => i.dateStr), this.staticData1.map(i => i.total),'次','bar')
|
},
|
initEchart11 () {
|
this.initEchartDataDo('echart11', this.staticData11.map(i => i.dateStr), this.staticData11.map(i => i.total),'次','line')
|
},
|
initEchart2 () {
|
this.initEchartDataDo('echart2', this.staticData2.map(i => i.dateStr), this.staticData2.map(i => i.total),'单','bar')
|
},
|
initEchart21 () {
|
this.initEchartDataDo('echart21', this.staticData21.map(i => i.dateStr), this.staticData21.map(i => i.total),'单','line')
|
},
|
initEchart3 () {
|
this.initEchartDataDo('echart3', this.staticData3.map(i => i.dateStr), this.staticData3.map(i => i.total),'单','bar')
|
},
|
initEchart31 () {
|
this.initEchartDataDo('echart31',this.staticData31.map(i => i.dateStr), this.staticData31.map(i => i.total),'单','line')
|
},
|
initEchartDataDo (id, xdata,ydata,unit,type) {
|
const myChart = echarts.init(document.getElementById(id))
|
myChart.setOption({
|
tooltip: {
|
trigger: 'axis',
|
axisPointer: {
|
type: type || 'line'
|
},
|
formatter: function (params) {
|
return `
|
<div style="background-color: #15323f;margin: -12px;padding: 14px;border: 2px solid rgba(1,217,254,0.5);color: #fff;">
|
<div>${params[0].name}</div>
|
<div style="display: flex;align-items: center;">
|
<div style="width: 10px;height: 10px;border-radius: 50%;background-color: #6feef0;"></div>
|
<span style="margin-left: 6px;">${params[0].value}</span>
|
<div>${unit}</div>
|
</div>
|
</div>
|
`
|
}
|
},
|
xAxis: {
|
type: 'category',
|
boundaryGap: false,
|
data: xdata
|
},
|
yAxis: {
|
type: 'value',
|
name: '',
|
nameTextStyle: {
|
padding: [0, 0, 4, -30] // 四个数字分别为上右下左与原位置距离
|
},
|
splitLine: {
|
show: true,
|
lineStyle: {
|
// 这里输入线条的样式
|
color: 'rgba(255,255,255,0.14)'
|
}
|
}
|
},
|
grid: {
|
top: '16%',
|
left: '2%',
|
right: '8%',
|
bottom: '2%',
|
containLabel: true
|
},
|
series: [
|
{
|
data: ydata,
|
type: type || 'line',
|
areaStyle: {
|
normal: {
|
color: {
|
x: 0,
|
y: 0,
|
x2: 0,
|
y2: 1,
|
colorStops: [{
|
offset: 0,
|
color: '#207FF7' // 0% 处的颜色
|
}, {
|
offset: 1,
|
color: 'rgba(255,255,255,.2)' // 100% 处的颜色
|
}],
|
globalCoord: false // 缺省为 false
|
}
|
}
|
},
|
lineStyle: { // 线条样式
|
color: {
|
type: 'linear',
|
x: 0,
|
y: 0,
|
x2: 0,
|
y2: 1,
|
colorStops: [{
|
offset: 0, color: '#207FF7' // 0% 处的颜色
|
}, {
|
offset: 1, color: '#207FF7' // 100% 处的颜色
|
}]
|
},
|
width: 2 // 线条粗细
|
},
|
symbol: 'circle',
|
symbolSize: 10,
|
itemStyle: {
|
borderWidth: 1,
|
borderColor: '#fff',
|
color: '#207FF7'
|
},
|
smooth: false
|
}
|
]
|
})
|
window.addEventListener('resize', function () { // 执行
|
myChart.resize()
|
})
|
},
|
}
|
}
|
</script>
|
|
<style lang="scss" scoped>
|
div {
|
box-sizing: border-box;
|
}
|
|
.home_title {
|
font-weight: 600;
|
font-size: 16px;
|
color: #222222;
|
line-height: 22px;
|
}
|
|
.main {
|
display: flex;
|
position: relative;
|
z-index: 99;
|
|
.app_content {
|
flex: 1;
|
|
.static_card {
|
height: 187px;
|
color: #fff;
|
display: flex;
|
justify-content: space-between;
|
|
.card {
|
flex: 1;
|
height: 187px;
|
background: linear-gradient(270deg, #29aeff 0%, #207ff7 100%);
|
box-shadow: 0px 2px 10px 0px rgba(32, 127, 247, 0.4);
|
border-radius: 8px;
|
margin-right: 14px;
|
|
&:nth-of-type(2) {
|
background: linear-gradient(270deg, #8383ff 0%, #6b6eff 100%);
|
}
|
|
&:nth-of-type(3) {
|
background: linear-gradient(270deg, #42d49d 0%, #12bb8b 100%);
|
}
|
|
&:nth-of-type(4) {
|
margin-right: 0;
|
background: linear-gradient(270deg, #c430dee3 0%, #cd04b9cf 100%);
|
//linear-gradient(270deg, #de3049b8 0%, #cd0421d4 100%);
|
//background: linear-gradient(270deg, #30d3de 0%, #04b7cd 100%);
|
}
|
|
.header {
|
height: 103px;
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
padding: 20px 20px 12px;
|
border-bottom: 1px solid rgba(255, 255, 255, 0.2);
|
|
img {
|
width: 40px;
|
height: 40px;
|
}
|
|
.num {
|
font-weight: 600;
|
font-size: 30px;
|
margin-top: 12px;
|
}
|
}
|
|
.content {
|
height: 82px;
|
display: flex;
|
flex-direction: column;
|
justify-content: space-between;
|
font-size: 13px;
|
padding: 15px 20px 20px;
|
}
|
}
|
}
|
|
.funcs {
|
height: 149px;
|
padding: 20px;
|
background: #fff;
|
margin: 10px 0;
|
|
.list {
|
display: flex;
|
padding-top: 20px;
|
|
.item {
|
display: flex;
|
flex-direction: column;
|
align-items: center;
|
justify-content: center;
|
margin-right: 24px;
|
cursor: pointer;
|
|
img {
|
width: 44px;
|
height: 44px;
|
}
|
}
|
}
|
}
|
}
|
|
.app_side {
|
width: 408px;
|
margin-left: 10px;
|
|
.task {
|
background: #fff;
|
border-radius: 2px;
|
border: 1px solid #eeeeee;
|
padding: 20px;
|
height: 346px;
|
margin-bottom: 10px;
|
|
.header {
|
.num {
|
position: relative;
|
top: 3px;
|
height: 16px;
|
line-height: 16px;
|
font-size: 12px;
|
color: #ffffff;
|
padding: 0 6px;
|
font-weight: 400;
|
background: red;
|
border-radius: 8px;
|
margin-left: 13px;
|
}
|
|
.more {
|
font-size: 13px;
|
color: #999999;
|
}
|
}
|
|
.list {
|
.item {
|
display: flex;
|
align-items: center;
|
margin-top: 15px;
|
|
.content {
|
flex: 1;
|
|
.title {
|
color: #222222;
|
margin-bottom: 5px;
|
}
|
|
.time {
|
color: #999999;
|
font-size: 12px;
|
}
|
}
|
|
.btn {
|
margin-left: 10px;
|
width: 58px;
|
text-align: center;
|
height: 30px;
|
line-height: 30px;
|
background: #ffffff;
|
border-radius: 2px;
|
border: 1px solid #207ff7;
|
font-size: 13px;
|
color: #207ff7;
|
cursor: pointer;
|
}
|
}
|
}
|
}
|
|
.warnning {
|
background: #fff;
|
border-radius: 2px;
|
border: 1px solid #eeeeee;
|
padding: 20px;
|
height: 508px;
|
|
.header {
|
.num {
|
position: relative;
|
top: 3px;
|
height: 16px;
|
line-height: 16px;
|
font-size: 12px;
|
color: #ffffff;
|
padding: 0 6px;
|
font-weight: 400;
|
background: red;
|
border-radius: 8px;
|
margin-left: 13px;
|
}
|
|
.more {
|
font-size: 13px;
|
color: #999999;
|
}
|
}
|
|
.list {
|
padding-top: 6px;
|
|
.item {
|
margin-top: 10px;
|
padding: 15px;
|
width: 100%;
|
height: 140px;
|
background: rgba(32, 127, 247, 0.05);
|
border-radius: 4px;
|
|
.name_wrap {
|
margin-bottom: 10px;
|
|
.name {
|
font-weight: 600;
|
color: #222222;
|
}
|
|
.identity {
|
font-size: 13px;
|
color: #207ff7;
|
}
|
}
|
|
.line {
|
color: #666666;
|
margin-bottom: 8px;
|
font-size: 13px;
|
}
|
|
.auth {
|
.time {
|
font-weight: 600;
|
font-size: 13px;
|
color: #ee3821;
|
}
|
|
.btn {
|
margin-left: 10px;
|
width: 58px;
|
text-align: center;
|
height: 30px;
|
cursor: pointer;
|
line-height: 30px;
|
background: #ffffff;
|
border-radius: 2px;
|
border: 1px solid #207ff7;
|
font-size: 13px;
|
color: #207ff7;
|
}
|
}
|
}
|
}
|
}
|
|
.more {
|
cursor: pointer;
|
}
|
|
.empty {
|
height: 300px;
|
display: flex;
|
justify-content: center;
|
align-items: center;
|
|
img {
|
width: 140px;
|
}
|
}
|
}
|
|
.static_wrap {
|
.wrap {
|
background: #fff;
|
padding: 20px 20px 10px;
|
border-radius: 2px;
|
border: 1px solid #eeeeee;
|
height: 250px;
|
flex: 1;
|
|
&:nth-of-type(2n) {
|
margin-left: 10px;
|
}
|
.echart {
|
width: 100%;
|
height: 190px;
|
position: relative;
|
display: flex;
|
div{
|
flex: 1;
|
height: 190px;
|
}
|
}
|
|
.header {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
|
.more {
|
font-size: 13px;
|
color: #999999;
|
}
|
}
|
}
|
|
.static1 {
|
.content {
|
display: flex;
|
justify-content: center;
|
align-items: center;
|
height: 100%;
|
|
.echart_wrap {
|
position: relative;
|
|
.pie_text {
|
position: absolute;
|
left: 50%;
|
top: 50%;
|
transform: translate(-50%, -50%);
|
z-index: 999;
|
}
|
}
|
|
.echart {
|
width: 150px;
|
height: 150px;
|
}
|
|
.list {
|
margin-left: 36px;
|
|
.item {
|
display: flex;
|
align-items: center;
|
margin: 8px 0;
|
|
.icon {
|
width: 16px;
|
height: 16px;
|
border-radius: 50%;
|
margin-right: 6px;
|
background: linear-gradient(270deg, #29aeff 0%, #207ff7 100%);
|
}
|
|
.text {
|
margin-right: 6px;
|
}
|
}
|
}
|
}
|
}
|
}
|
}
|
|
.main_home {
|
background: #f4f7fc;
|
position: relative;
|
width: 100%;
|
height: 100%;
|
overflow: auto;
|
padding: 92px 20px 20px;
|
.home_header {
|
position: absolute;
|
top: 0;
|
left: 0;
|
width: 100%;
|
height: 200px;
|
padding: 20px;
|
color: #fff;
|
background: linear-gradient(180deg, #076ae5 0%, rgba(32, 127, 247, 0) 100%);
|
}
|
}
|
</style>
|