let barImg =
'data:image/png;base64,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'
let app = new Vue({
el: '#app',
data () {
return {
imgPop:'',
// paymentShow:false, // 定薪酬弹窗
echartC1: {
national: 100,
province: 200
},
echartC2: {
national: 100,
province: 200
},
app_token: '',
twinkle7: [],
twinkle8: [],
twinkleR6: [],
showTip: false,
showTip2: false,
showTip3: false,
showTip4: false,
titleShow: false,
tipNum: '',
tipData: tipData,
titleData: titleData,
time: '',
year: '2022',
config1: {
number: [100],
content: '{nt}个',
},
centerData: '',
storageRecordConfig: {
header: ['', '公司名称', '工作情况'],
headerBGC: '#05507b33',
oddRowBGC: '#69c0ff0f',
// waitTime: '50000',
evenRowBGC: '',
headerHeight: '60',
columnWidth: [150, 150],
rowNum: 4,
align: ['right', 'center', 'center', 'center'],
data: [],
},
storageRecordConfig2: {
header: ['', '预警内容', '未获取数据天数'],
headerBGC: '#05507b33',
oddRowBGC: '#05507b33',
evenRowBGC: '',
headerHeight: '60',
columnWidth: [150, 800, 200],
rowNum: 4,
align: ['center', 'center', 'center', 'center', 'center'],
data: []
},
companyList: companyList,
commonOption: {
title: {
text: 'xxx',
x: 'center',
y: '3%',
textStyle: {
color: '#69C0FF',
fontSize: 24,
},
},
tooltip: {
trigger: 'axis',
textStyle: { fontSize: 18 },
axisPointer: {
type: 'cross',
label: {
fontSize: 18,
},
},
},
grid: {
top: '22%',
right: '5%',
left: '8%',
bottom: '20%',
},
legend: {
data: '',
top: '12%',
right: '5%',
textStyle: {
color: 'rgba(250,250,250,0.6)',
fontSize: 16,
},
},
xAxis: {
data: companyList.map(item => item.name),
axisLine: {
show: false, //隐藏X轴轴线
lineStyle: {
color: '#005094',
width: 1,
},
},
axisTick: {
show: false, //隐藏X轴刻度
},
axisLabel: {
show: true,
rotate: 50,
textStyle: {
color: 'rgba(255,255,255,0.6)', //X轴文字颜色
fontSize: 16,
},
},
},
yAxis: [
{
type: 'value',
nameTextStyle: {
color: '#ebf8ac',
fontSize: 16,
},
splitLine: {
show: true,
lineStyle: {
color: '#68b4dd66',
type: 'dashed',
},
},
axisLine: {
show: false,
},
axisLabel: {
show: true,
textStyle: {
color: 'rgba(250,250,250,0.6)',
fontSize: 16,
},
},
},
],
},
}
},
beforeMount () {
},
mounted () {
if (!sessionStorage.getItem('accounts', this.accounts)) {
window.location.href = './login/login.html'
return
}
this.getAppToken()
this.time = formatDate()
this.timer = setInterval(() => {
this.time = formatDate()
}, 1000)
this.centerData = data
// this.generateEcharts()
},
beforeDestroy () {
if (this.timer) {
clearInterval(this.timer)
}
},
methods: {
// 获取token
getAppToken () {
let value = {
// dev环境
// "appId": "cockpitScreen",
// "appSecuret": "JSCdpsjgl@123456",
// "tenantid": "gydev",
// "accountId": "1614416231203341312",
// "language": "zh_CN"
// SIT环境
// "appId": "CockpitScreen",
// "appSecuret": "JSCdpsjgl@539126",
// "tenantid": "test",
// "accountId": "1484008912330950656",
// "language": "zh_CN"
// UAT环境
// "appId": "CockpitScreen",
// "appSecuret": "JSCdpsjgl@539126",
// "tenantid": "uatierp",
// "accountId": "1490670568960163840",
// "language": "zh_CN"
// 生产环境
"appId": "CockpitScreen",
"appSecuret": "JSCdpsjgl@539126",
"tenantid": "ierp",
"accountId": "1504594026697850880",
"language": "zh_CN"
}
post('/ierp/api/getAppToken.do', value).then(res => {
this.app_token = res.data.app_token
this.getAccessToken()
})
},
// 获取AccessToken
getAccessToken () {
let value = {
// dev环境
// "user": "jiashicangjiekou",
// "apptoken": this.app_token,
// "tenantid": "gydev",
// "accountId": "1614416231203341312",
// "usertype": "UserName"
// SIT环境
// "user": "jiashicangjiekou",
// "apptoken": this.app_token,
// "tenantid": "test",
// "accountId": "1484008912330950656",
// "usertype": "UserName"
// UAT环境
// "user": "jiashicangjiekou",
// "apptoken": this.app_token,
// "tenantid": "uatierp",
// "accountId": "1490670568960163840",
// "usertype": "UserName"
// 生产环境
"user": "jiashicangjiekou",
"apptoken": this.app_token,
"tenantid": "ierp",
"accountId": "1504594026697850880",
"usertype": "UserName"
}
post('/ierp/api/login.do', value).then(res => {
this.access_token = res.data.access_token
// Promise.all([this.getData(), this.getInstitutional()])
// .then((arr) => {
// // 生成图表
// this.generateEcharts()
// })
// .catch((err) => console.log(err));
this.getInstitutional()
})
},
// 获取组织机构
getInstitutional () {
return new Promise((resolve, err) => {
let value = {
access_token: this.access_token,
"Data": {
"paramType": "ORG",
"orgNumber": "100000"
}
}
post('/ierp/kapi/v2/mdnb/mdnb_das/Data/CockpitScreen', value).then(res => {
this.companyList = res.data.map(item => {
return { name: item.orgName, id: item.orgNumber, orgLogoNum: item.orgLogoNum }
})
this.commonOption.xAxis.data = this.companyList.map(item => item.name)
this.getData()
resolve(1);
})
});
},
generateEcharts () {
this.initChartL1()
this.initChartL2()
this.initChartL3()
this.initChartL4()
this.initChartL5()
this.initChartL6()
this.initChartL7()
this.initChartL8()
// 中间图表
this.initChartC1()
this.initChartC2()
// 右侧图表
this.initChartR1()
this.initChartR2()
this.initChartR3()
this.initChartR4()
this.initChartR5()
this.initChartR6()
this.initChartR7()
this.initChartR8()
},
getData () {
return new Promise((resolve, err) => {
let value = {
access_token: this.access_token,
"Data": {
"paramType": "DATA",
"orgNumber": "100000"
}
}
post('/ierp/kapi/v2/mdnb/mdnb_das/Data/CockpitScreen', value).then(res => {
res.orgData = res.data[0]
// 定机构
// 弹窗
// return
// 左侧图表
// tipData.focus[0] = res.orgData.area1.keyPoint
tipData.analysis[0] = res.orgData.area1.intAnalysis.map(item => item.analysis)
//各省属企业总部机构数
dataL1[1] = []
dataL1[0] = []
dataL1[2] = []
res.orgData.area1.card1.forEach(item => {
dataL1[1].push(item['ZBPZ0032'])
dataL1[0].push(item['ZBPZ0042'])
dataL1[2].push(item['ZBPZ0043'])
})
// 各省属企业共享服务中心/事业部数
dataL2[0] = []
dataL2[1] = []
dataL2[2] = []
res.orgData.area1.card2.forEach(item => {
dataL2[1].push(item['ZBPZ0045'])
dataL2[0].push(item['ZBPZ0024'])
dataL2[2].push(item['ZBPZ0044'])
})
// 定职数
// 弹窗
// tipData.focus[1] = res.orgData.area2.keyPoint
tipData.analysis[1] = res.orgData.area2.intAnalysis.map(item => item.analysis)
// 各省属企业管理人员数
dataL3[0] = []
dataL3[1] = []
res.orgData.area2.card1.forEach(item => {
dataL3[0].push(item['ZBPZ0031'])
dataL3[1].push(item['ZBPZ0049'])
})
// 各省属企业总部中层管理人数
dataL4[1] = []
dataL4[0] = []
dataL4[2] = []
res.orgData.area2.card2.forEach(item => {
dataL4[1].push(item['ZBPZ0046'])
dataL4[0].push(item['ZBPZ0047'])
dataL4[2].push(item['ZBPZ0048'])
})
// 定员额
// 弹窗
// tipData.focus[2] = res.orgData.area3.keyPoint
tipData.analysis[2] = res.orgData.area3.intAnalysis.map(item => item.analysis)
// 各省属企业总人数
dataL5[0] = []
dataL5[1] = []
res.orgData.area3.card1.forEach(item => {
dataL5[0].push(item['ZBPZ0006'])
dataL5[1].push(item['ZBPZ0050'])
})
// 各省属企业总部员额数
dataL6[0] = []
dataL6[1] = []
dataL6[2] = []
res.orgData.area3.card2.forEach(item => {
dataL6[0].push(item['ZBPZ0033'])
dataL6[1].push(item['ZBPZ0053'])
dataL6[2].push(item['ZBPZ0052'])
})
// 人数变化和全员劳动生产率变化分析
dataL7[0] = []
dataL7[1] = []
res.orgData.area3.card3.forEach(item => {
dataL7[0].push(item['ZBPZ0050'])
dataL7[1].push(item['ZBPZ0039'])
})
// 人数变化和人工成本利润率变化分析
dataL8[0] = []
dataL8[1] = []
res.orgData.area3.card4.forEach(item => {
dataL8[0].push(item['ZBPZ0050'])
dataL8[1].push(item['ZBPZ0041'])
})
// 中间
// 架岗人
this.centerData.info.value1 = res.orgData.area7.ZBPZ0037
this.centerData.info.value2 = res.orgData.area7.ZBPZ0038
this.centerData.info.value3 = res.orgData.area7.ZBPZ0006
// 六定改革成效
this.centerData.changeInfo[0].value1 = res.orgData.area8.ZBPZ0067
this.centerData.changeInfo[0].value2 = res.orgData.area8.ZBPZ0068
this.centerData.changeInfo[0].value3 = res.orgData.area8.ZBPZ0069
this.centerData.changeInfo[2].value1 = res.orgData.area8.ZBPZ0074
this.centerData.changeInfo[2].value2 = res.orgData.area8.ZBPZ0075
this.centerData.changeInfo[2].value3 = res.orgData.area8.ZBPZ0076
this.centerData.changeInfo[1].value1 = res.orgData.area8.ZBPZ0071
this.centerData.changeInfo[1].value2 = res.orgData.area8.ZBPZ0072
this.centerData.changeInfo[1].value3 = res.orgData.area8.ZBPZ0073
// 核心指标监测
// 弹窗
// tipData.focus[3] = res.orgData.area9.keyPoint
tipData.analysis[3] = res.orgData.area9.intAnalysis.map(item => item.analysis)
// 劳动生产各省属企业全员率
c1[0] = []
c1[1] = []
res.orgData.area9.card1.forEach(item => {
c1[0].push(item['ZBPZ0035'])
c1[1].push(item['ZBPZ0039'])
})
// 各省属企业人工成本利润率
c2[1] = []
c2[0] = []
res.orgData.area9.card2.forEach(item => {
c2[1].push(item['ZBPZ0040'])
c2[0].push(item['ZBPZ0041'])
})
this.echartC1.national = res.orgData.area9.card1[0].ZBPZ0097
this.echartC1.province = res.orgData.area9.card1[0].ZBPZ0096
this.echartC2.national = res.orgData.area9.card2[0].ZBPZ0099
this.echartC2.province = res.orgData.area9.card2[0].ZBPZ0098
// 分析预警中心
// 工作台分析
this.storageRecordConfig.data = []
res.orgData.area10.card1.forEach(item => {
this.storageRecordConfig.data.push(['', item.enterprise, item.work])
})
this.storageRecordConfig = { ...this.storageRecordConfig }
// 数据库预警
this.storageRecordConfig2.data = []
res.orgData.area10.card2.forEach(item => {
this.storageRecordConfig2.data.push(['', item.warning, item.date])
})
this.storageRecordConfig2 = { ...this.storageRecordConfig2 }
// 左边
// 定机制
// 弹窗
// tipData.focus[4] = res.orgData.area4.keyPoint
tipData.analysis[4] = res.orgData.area4.intAnalysis.map(item => item.analysis)
// 各省属企业招聘需求公示人次
dataR1[0] = []
dataR1[1] = []
res.orgData.area4.card1.forEach(item => {
dataR1[0].push(item['ZBPZ0057'])
dataR1[1].push(item['ZBPZ0058'])
})
// 各省属企业录用结果公示人次
dataR2[0] = []
dataR2[1] = []
res.orgData.area4.card2.forEach(item => {
dataR2[0].push(item['ZBPZ0059'])
dataR2[1].push(item['ZBPZ0060'])
})
// 各省属企业年利润与当年累计招聘人数
dataR3[0] = []
dataR3[1] = []
res.orgData.area4.card3.forEach(item => {
dataR3[0].push(item['ZBPZ0054'])
dataR3[1].push(item['ZBPZ0055'])
})
// 各省属企业"退二进一"完成情况
dataR4[0] = []
dataR4[1] = []
res.orgData.area4.card4.forEach(item => {
dataR4[0].push(item['ZBPZ0056'])
dataR4[1].push(item['ZBPZ0055'])
})
// 定薪酬
// 弹窗
// tipData.focus[5] = res.orgData.area5.keyPoint
tipData.analysis[5] = res.orgData.area5.intAnalysis.map(item => item.analysis)
// 各省属企业在岗职工平均薪酬
fjxdataL1[0] = []
fjxdataL1[1] = []
res.orgData.area5.card1.forEach(item => {
fjxdataL1[0].push(item['ZBPZ0063'])
fjxdataL1[1].push(item['ZBPZ0064'])
})
// 各省属企业利润与薪酬变动情况
fjxdataL2[0] = []
fjxdataL2[1] = []
res.orgData.area5.card2.forEach(item => {
fjxdataL2[0].push(item['ZBPZ0061'])
fjxdataL2[1].push(item['ZBPZ0062'])
})
// 定任期
// 弹窗
// tipData.focus[5] = res.orgData.area6.keyPoint
tipData.analysis[5] = res.orgData.area6.intAnalysis.map(item => item.analysis)
// 各省属企业全员绩效考核
fjxdataL3[0] = []
res.orgData.area6.card1.forEach(item => {
fjxdataL3[0].push(item['ZBPZ0066'])
})
// 各省属企业全员绩效考核
fjxdataL4[0] = []
res.orgData.area6.card2.forEach(item => {
fjxdataL4[0].push(item['ZBPZ0065'])
})
// 数据整理
dataL7[0].forEach((item, index) => {
if (dataL7[1][index] < 0 && dataL7[0][index] > 0) {
let obj = { value: [this.companyList[index].name, dataL7[0][index]], symbolSize: 15 }
this.twinkle7.push(obj)
}
})
// if (dataL8[1][params.dataIndex] < 0 && params.value > 0) {
dataL8[0].forEach((item, index) => {
if (dataL8[1][index] < 0 && dataL8[0][index] > 0) {
let obj = { value: [this.companyList[index].name, dataL8[0][index]], symbolSize: 15 }
this.twinkle8.push(obj)
}
})
// params.value > 0 && fjxdataL2[0][params.dataIndex] < 0
fjxdataL2[0].forEach((item, index) => {
if (fjxdataL2[1][index] > 0 && fjxdataL2[0][index] < 0) {
let obj = { value: [this.companyList[index].name, fjxdataL2[1][index]], symbolSize: 15 }
this.twinkleR6.push(obj)
}
})
this.generateEcharts()
resolve(1)
})
});
},
handleTitleShow (e) {
this.imgPop = e
this.titleShow = true
this.showTip = false
this.showTip2 = false
},
// handlepaymentShow () {
// this.paymentShow = true
// this.titleShow = false
// this.showTip = false
// this.showTip2 = false
// },
showTipClose () {
// this.paymentShow = false
this.showTip = false
this.showTip2 = false
this.titleShow = false
},
handleShowTip (index, type) {
if (type == 'analysis') {
this.tipData = tipData.analysis
} else if (type == 'focus') {
this.tipData = tipData.focus
} else if (type == 'topThree') {
this.tipData = tipData.topThree
} else if (type == 'totlePeople') {
this.tipData = tipData.totlePeople
} else if (type == 'beforeReform') {
this.tipData = tipData.beforeReform
} else if (type == 'reformRegistered') {
this.tipData = tipData.reformRegistered
} else if (type == 'reforAveRemuneration') {
this.tipData = tipData.reforAveRemuneration
}
this.showTip2 = false
this.showTip = true
this.titleShow = false
this.tipNum = index
},
handleShowTip2 (index) {
this.showTip = false
this.showTip2 = true
this.titleShow = false
this.tipNum = index
},
handleGoPage (id, name) {
if (name == '晋能控股') {
window.location.href = './index2JNKG.html?id=' + id + `&access_token=${this.access_token}` + `&name=${name}`
} else {
window.location.href = './index2.html?id=' + id + `&access_token=${this.access_token}` + `&name=${name}`
}
},
numFormat (value) {
if (!value) return '0'
// var intPart = Number(value).toFixed(0) // 获取整数部分
var intPart = parseInt(value)// 获取整数部分
var intPartFormat = intPart.toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,') // 将整数部分逢三一断
var floatPart = '.00' // 预定义小数部分
var value2Array = value.toString().split('.')
// =2表示数据有小数位
if (value2Array.length === 2) {
floatPart = value2Array[1].toString() // 拿到小数部分
if (floatPart.length === 1) {
// 补0
return intPartFormat + '.' + floatPart + '0'
} else {
return intPartFormat + '.' + floatPart
}
} else {
return intPartFormat
}
},
initChartL1 () {
let myChart = echarts.init(this.$refs['echartL1'])
let option = {
..._.cloneDeep(this.commonOption),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#5e7ae9',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '总部机构数核定上限',
type: 'line',
// yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 8, //标记的大小
smooth: false,
itemStyle: {
//折线拐点标志的样式
color: '#fbe138',
borderColor: '#fbe138',
width: 2,
shadowColor: '#fbe138',
shadowBlur: 4,
},
lineStyle: {
color: '#fbe138',
width: 2,
},
data: dataL1[2],
},
{
name: '六定改革前总部机构数',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#43ede3',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataL1[0],
},
{
name: '当前各省属企业总部机构数',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: params => {
if (params.value > dataL1[2][params.dataIndex]) {
return 'red'
} else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#5e7ae9',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
},
data: dataL1[1],
},
],
// tooltip: {
// trigger: 'item',
// position: 'top'
// },
}
option.title.text = '各省属企业总部机构数'
option.legend.data = ['六定改革前总部机构数', '当前各省属企业总部机构数', '总部机构数核定上限']
option.yAxis.push({
splitLine: {
show: false,
},
axisLine: {
show: false,
},
})
myChart.setOption(option)
},
initChartL2 () {
let myChart = echarts.init(this.$refs['echartL2'])
let option = {
..._.cloneDeep(this.commonOption),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '当前总部共享服务中心/事业部数',
type: 'bar',
barWidth: 15,
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: '#69c0ff',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '华阳新材') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
color: params => {
if (params.value > dataL2[1][params.dataIndex]) {
return 'red'
} else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
data: dataL2[0],
},
{
name: '六定改革前总部共享服务中心/事业部核定上限',
type: 'bar',
barWidth: 15,
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: '#69c0ff',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '华阳新材') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#5e7ae9',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataL2[2],
},
{
name: '总部共享服务中心/事业部核定上限',
type: 'line',
// yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 8, //标记的大小
smooth: false,
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: '#fbe138',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '华阳新材') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
//折线拐点标志的样式
color: '#fbe138',
borderColor: '#fbe138',
width: 2,
shadowColor: '#fbe138',
shadowBlur: 4,
},
lineStyle: {
color: '#fbe138',
width: 2,
},
data: dataL2[1],
},
],
}
option.title.text = '各省属企业总部共享服务中心/事业部数'
option.legend.data = ['当前总部共享服务中心/事业部数', '总部共享服务中心/事业部核定上限', '六定改革前总部共享服务中心/事业部核定上限']
option.yAxis.push({
splitLine: {
show: false,
},
axisLine: {
show: false,
},
})
myChart.setOption(option)
},
initChartL3 () {
let myChart = echarts.init(this.$refs['echartL3'])
let option = {
..._.cloneDeep(this.commonOption),
series: [
{
name: '当前管理人员数',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#5e7ae9',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataL3[0],
},
{
name: '管理人员数占总人数比值',
type: 'line',
yAxisIndex: 1,
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 8, //标记的大小
smooth: false,
itemStyle: {
//折线拐点标志的样式
color: '#fbe138',
borderColor: '#fbe138',
width: 2,
shadowColor: '#fbe138',
shadowBlur: 4,
},
lineStyle: {
color: '#fbe138',
width: 2,
},
markLine: {
data: [
{
name: '管理人员数占总人数的合理比值线',
yAxis: 15,
lineStyle: {
color: '#fff',
},
label: {
formatter: '{b}',
position: 'middle',
color: '#fff',
fontSize: 16,
},
},
],
label: {
distance: [20, 8],
},
},
data: dataL3[1],
},
],
}
option.title.text = '各省属企业管理人员数'
option.legend.data = ['当前管理人员数', '管理人员数占总人数比值']
option.yAxis[0] = {
type: 'log',
min: 1,
logBase: 10,
axisLine: {
show: false,
},
splitLine: {
show: true,
lineStyle: {
color: '#68b4dd66',
type: 'dashed',
},
},
axisLabel: {
show: true,
formatter: function (value) {
return value === 1 ? 0 : value
},
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
}
option.yAxis.push({
type: 'value',
axisLine: {
show: false,
},
splitLine: {
show: false,
},
axisLabel: {
show: true,
formatter: '{value} %',
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
})
option.tooltip.formatter = '{a0}:{c0}' + '
' + '{a1}:{c1}' + '%'
myChart.setOption(option)
},
initChartL4 () {
let myChart = echarts.init(this.$refs['echartL4'])
let option = {
..._.cloneDeep(this.commonOption),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#6480f3',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '六定改革前总部中层管理人数',
type: 'bar',
barWidth: 15,
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: '#69c0ff',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '云时代') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataL4[0],
},
{
name: '当前总部中层管理人数',
type: 'bar',
barWidth: 15,
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: '#6480f3',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '云时代') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
normal: {
color: params => {
if (params.value > dataL4[2][params.dataIndex] || params.value > dataL4[0][params.dataIndex]) {
return 'red'
} else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#6480f3',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
},
data: dataL4[1],
},
{
name: '总部中层管理人数核定上限',
type: 'line',
// yAxisIndex: 1,
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 8, //标记的大小
smooth: false,
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: '#fbe138',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '云时代') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
//折线拐点标志的样式
color: '#fbe138',
borderColor: '#fbe138',
width: 2,
shadowColor: '#fbe138',
shadowBlur: 4,
},
lineStyle: {
color: '#fbe138',
width: 2,
},
data: dataL4[2],
},
],
}
option.title.text = '各省属企业总部中层管理人数'
option.legend.data = ['六定改革前总部中层管理人数', '当前总部中层管理人数', '总部中层管理人数核定上限']
option.legend.show = true
// option.yAxis.push({
// splitLine: {
// show: false,
// },
// axisLine: {
// show: false,
// },
// })
myChart.setOption(option)
},
initChartL5 () {
let myChart = echarts.init(this.$refs['echartL5'])
let option = {
..._.cloneDeep(this.commonOption),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '各省属企业总人数',
type: 'bar',
barWidth: 15,
label: {
normal: {
show: true,
position: 'top',
lineHeight: '25',
textStyle: {
color: '#69c0ff',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '华阳新材' || data.name == '华舰体育') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
normal: {
color: params => {
if (params.dataIndex > 0 && Math.abs(params.value - dataL5[0][params.dataIndex - 1]) > params.value * 0.1) {
return 'yellow'
} else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
])
}
}
},
},
data: dataL5[0],
},
{
name: '总人数同比变化',
type: 'line',
yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 8, //标记的大小
smooth: false,
label: {
normal: {
show: true,
position: 'bottom',
lineHeight: '25',
textStyle: {
color: '#b889ea',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '华阳新材' || data.name == '华舰体育') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
//折线拐点标志的样式
color: '#b889ea',
borderColor: '#b889ea',
width: 2,
shadowColor: '#b889ea',
shadowBlur: 4,
},
lineStyle: {
color: '#b889ea',
width: 2,
},
data: dataL5[1],
},
],
}
option.title.text = '各省属企业总人数'
option.legend.data = ['各省属企业总人数', '总人数同比变化']
option.legend.show = true
option.yAxis[0] = {
type: 'value',
// type: 'log',
min: 1,
// logBase: 10,
axisLine: {
show: false,
},
splitLine: {
show: true,
lineStyle: {
color: '#68b4dd66',
type: 'dashed',
},
},
axisLabel: {
show: true,
formatter: function (value) {
return value === 1 ? 0 : value
},
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
}
option.yAxis.push({
type: 'value',
axisLine: {
show: false,
},
splitLine: {
show: false,
},
axisLabel: {
show: true,
formatter: '{value} %',
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
})
option.tooltip.formatter = '{a0}:{c0}' + '
' + '{a1}:{c1}' + '%'
myChart.setOption(option)
},
initChartL6 () {
let myChart = echarts.init(this.$refs['echartL6'])
let option = {
..._.cloneDeep(this.commonOption),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#43ede3',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '总部员额数',
type: 'bar',
barWidth: 15,
itemStyle: {
color: params => {
if (params.value > dataL6[1][params.dataIndex]) {
return 'red'
} else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#43ede3',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
data: dataL6[0],
},
{
name: '六定改革前总部员额数',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#5e7ae9',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataL6[2],
},
{
name: '总部员额数核定上限',
type: 'line',
yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 8, //标记的大小
smooth: false,
itemStyle: {
//折线拐点标志的样式
color: '#fbe138',
borderColor: '#fbe138',
width: 2,
shadowColor: '#fbe138',
shadowBlur: 4,
},
lineStyle: {
color: '#fbe138',
width: 2,
},
data: dataL6[1],
},
],
}
option.title.text = '各省属企业总部员额数'
option.legend.data = ['六定改革前总部员额数', '总部员额数', '总部员额数核定上限']
option.legend.show = true
option.yAxis.push({
splitLine: {
show: false,
},
axisLine: {
show: false,
},
})
myChart.setOption(option)
},
initChartL7 () {
let myChart = echarts.init(this.$refs['echartL7'])
let that = this
let option = {
..._.cloneDeep(this.commonOption),
color: ['#43ede3'],
series: [
{
name: '人数变化',
type: 'line',
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 15, //标记的大小
smooth: false,
label: {
normal: {
show: true,
position: 'bottom',
lineHeight: '35',
textStyle: {
color: '#43ede3',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '文旅集团' || data.name == "大地控股" || data.name == '华舰体育') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
color: params => {
if (dataL7[1][params.dataIndex] < 0 && params.value > 0) {
return 'red'
} else if (params.value < 0 && dataL7[1][params.dataIndex] > 0) {
return 'green'
}
else {
return '#43ede3'
}
},
},
lineStyle: {
color: '#43ede3',
width: 2,
},
data: dataL7[0],
},
{
name: '劳动生产率同比变化',
type: 'line',
yAxisIndex: 1,
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 8, //标记的大小
smooth: false,
label: {
normal: {
show: true,
position: 'top',
lineHeight: '25',
textStyle: {
color: '#b889ea',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '文旅集团' || data.name == "大地控股" || data.name == '华舰体育') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
//折线拐点标志的样式
color: '#b889ea',
borderColor: '#b889ea',
width: 2,
shadowColor: '#b889ea',
shadowBlur: 4,
},
data: dataL7[1],
},
{
type: 'effectScatter',
coordinateSystem: 'cartesian2d',
showEffectOn: 'render',
rippleEffect: {
period: 10,
scale: 4,
brushType: 'stroke'
},
hoverAnimation: true,
itemStyle: {
color: 'red'
},
lineStyle: {
color: '#43ede3',
width: 2,
},
data: that.twinkle7,
},
],
}
option.title.text = '人数变化和全员劳动生产率变化分析'
option.legend.data = ['人数变化', '劳动生产率同比变化']
option.legend.show = true
option.yAxis[0].axisLabel.formatter = '{value} %'
option.tooltip.formatter = '{a0}:{c0}' + '%' + '
' + '{a1}:{c1}' + '%'
option.yAxis.push({
type: 'value',
axisLine: {
show: false,
},
splitLine: {
show: false,
},
axisLabel: {
show: true,
formatter: '{value} %',
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
splitLine: {
show: false,
},
axisLabel: {
show: true,
formatter: '{value} %',
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
},
})
myChart.setOption(option)
},
initChartL8 () {
let myChart = echarts.init(this.$refs['echartL8'])
let option = {
..._.cloneDeep(this.commonOption),
color: ['#43ede3'],
series: [
{
name: '人数变化',
type: 'line',
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 15, //标记的大小
smooth: false,
label: {
normal: {
show: true,
position: 'bottom',
lineHeight: '20',
textStyle: {
color: '#43ede3',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '文旅集团' || data.name == '大地控股') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
color: params => {
if (dataL8[1][params.dataIndex] < 0 && params.value > 0) {
return 'red'
} else if (params.value < 0 && dataL8[1][params.dataIndex] > 0) {
return 'green'
}
else {
return '#43ede3'
}
},
},
lineStyle: {
color: '#43ede3',
width: 2,
},
data: dataL8[0],
},
{
name: '人工成本利润率同比变化',
type: 'line',
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 15, //标记的大小
smooth: false,
label: {
normal: {
show: true,
position: 'top',
lineHeight: '30',
textStyle: {
color: '#b889ea',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '文旅集团' || data.name == '大地控股') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
//折线拐点标志的样式
color: '#b889ea',
borderColor: '#b889ea',
width: 2,
shadowColor: '#b889ea',
shadowBlur: 4,
},
lineStyle: {
color: '#b889ea',
width: 2,
},
data: dataL8[1],
},
{
type: 'effectScatter',
coordinateSystem: 'cartesian2d',
showEffectOn: 'render',
rippleEffect: {
period: 10,
scale: 4,
brushType: 'stroke'
},
hoverAnimation: true,
itemStyle: {
color: 'red'
},
lineStyle: {
color: '#43ede3',
width: 2,
},
data: this.twinkle8,
},
// {
// type: 'effectScatter',
// coordinateSystem: 'cartesian2d',
// showEffectOn: 'render',
// rippleEffect: {
// period: 10,
// scale: 4,
// brushType: 'stroke'
// },
// hoverAnimation: true,
// itemStyle: {
// color: 'red'
// },
// lineStyle: {
// color: '#43ede3',
// width: 2,
// },
// data: that.twinkle,
// },
],
// tooltip: {
// trigger: 'axis',
// formatter(params){
// console.log(params)
// return params[0]
// }
// }
}
option.title.text = '人数变化和人工成本利润率变化分析'
option.legend.data = ['人数变化', '人工成本利润率同比变化']
option.legend.show = true
option.yAxis[0].axisLabel.formatter = '{value} %'
option.tooltip.formatter = '{a0}:{c0}' + '%' + '
' + '{a1}:{c1}' + '%'
myChart.setOption(option)
},
// 中间图表---------------------------------------------开始
initChartC1 () {
let myChart = echarts.init(this.$refs['echartC1'])
let option = {
..._.cloneDeep(this.commonOption),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '全员劳动生产率(万/人)',
type: 'bar',
barWidth: 15,
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: '#69c0ff',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '国际能源' || data.name == '汾酒集团') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
color: params => {
if (params.value < 0 && c1[1][params.dataIndex] < 0) {
return 'red'
} else if (params.value > this.echartC1.province) {
return 'green'
} else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
markLine: {
data: [
{
name: '省属企业平均水平',
yAxis: this.echartC1.national,
lineStyle: {
color: '#fff',
},
label: {
formatter: '{b}',
position: 'middle',
padding: [20, 100, 10, 10],
fontSize: 16,
color: '#fff',
},
},
{
name: '央企平均水平',
yAxis: this.echartC1.province,
lineStyle: {
color: '#fff',
},
label: {
formatter: '{b}',
position: 'end',
padding: [-4, 150, 10, 10],
color: '#fff',
fontSize: 16,
},
},
],
label: {
distance: [50, 0],
},
},
data: c1[0],
},
{
name: '全员劳动生产率同比',
type: 'line',
yAxisIndex: 1,
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 8, //标记的大小
smooth: false,
itemStyle: {
//折线拐点标志的样式
color: '#B889EA',
borderColor: '#B889EA',
width: 2,
shadowColor: '#B889EA',
shadowBlur: 4,
},
lineStyle: {
color: '#B889EA',
width: 2,
},
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: '#B889EA',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '国际能源' || data.name == '汾酒集团') {
return data.value + '%'
} else {
return ''
}
}
}
},
data: c1[1],
},
],
}
option.title.text = '各省属企业全员劳动生产率'
option.legend.show = true
option.grid.right = '15%'
option.tooltip.formatter = '{a0}:{c0}' + '
' + '{a1}:{c1}' + '%'
option.yAxis.push({
type: 'value',
axisLine: {
show: false,
},
splitLine: {
show: false,
},
axisLabel: {
show: true,
formatter: '{value} %',
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
})
myChart.setOption(option)
// tools.loopShowTooltip(myChart, option, {
// nterval: 2000,
// loopSeries: true,
// })
},
initChartC2 () {
let myChart = echarts.init(this.$refs['echartC2'])
let option = {
..._.cloneDeep(this.commonOption),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '人工成本利润率',
type: 'bar',
barWidth: 15,
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: '#fff',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '国际能源' || data.name == '文旅集团' || data.name == '航产集团' || data.name == '华舰体育') {
return data.value
} else {
return ''
}
}
}
},
markLine: {
data: [
{
name: '省属企业平均水平',
yAxis: this.echartC2.province,
lineStyle: {
color: '#fff',
},
label: {
formatter: '{b}',
position: 'end',
padding: [24, 100, 10, 10],
fontSize: 16,
color: '#fff',
},
},
{
name: '央企平均水平',
yAxis: this.echartC2.national,
lineStyle: {
color: '#fff',
},
label: {
formatter: '{b}',
position: 'middle',
padding: [-24, 200, 10, 10],
color: '#fff',
fontSize: 16,
},
},
],
label: {
distance: [50, 0],
},
},
itemStyle: {
color: params => {
if (params.value < 0 && c2[0][params.dataIndex] < 0) {
return 'red'
} else if (params.value > this.echartC2.province) {
return 'green'
} else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
data: c2[1],
},
{
name: '人工成本利润率同比',
type: 'line',
yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 8, //标记的大小
smooth: false,
label: {
normal: {
show: true,
position: 'top',
lineHeight: '30',
textStyle: {
color: '#b889ea',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '国际能源' || data.name == '文旅集团' || data.name == '航产集团' || data.name == '华舰体育') {
return data.value + '%'
} else {
return ''
}
}
}
},
itemStyle: {
//折线拐点标志的样式
color: '#B889EA',
borderColor: '#B889EA',
width: 2,
shadowColor: '#B889EA',
shadowBlur: 4,
},
lineStyle: {
color: '#B889EA',
width: 2,
},
data: c2[0],
},
],
}
option.title.text = '各省属企业人工成本利润率'
option.legend.show = true
option.grid.right = '15%'
option.yAxis[0].axisLabel.formatter = '{value} %'
option.tooltip.formatter = '{a0}:{c0}' + '%' + '
' + '{a1}:{c1}' + '%'
option.yAxis.push({
type: 'value',
axisLine: {
show: false,
},
splitLine: {
show: false,
},
axisLabel: {
show: true,
formatter: '{value} %',
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
})
myChart.setOption(option)
// tools.loopShowTooltip(myChart, option, {
// nterval: 2000,
// loopSeries: true,
// })
},
// 右侧图表---------------------------------------------开始
initChartR1 () {
let myChart = echarts.init(this.$refs['echartR1'])
let commonOptions = this.commonOption
commonOptions.yAxis[0].splitNumber = 2
let dataTemp = []
let dataTemp2 = []
dataR1[0].forEach(item => {
dataTemp.push(item)
})
dataR1[1].forEach(item => {
dataTemp2.push(item)
})
let option = {
..._.cloneDeep(commonOptions),
series: [
{
name: '招聘需求公告次数',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataTemp,
},
{
name: '招聘需求公告累计公开招聘人数',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#43ede3',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataTemp2,
},
],
}
option.title.text = '各省属企业招聘需求公示人次'
option.legend.data = ['招聘需求公告次数', '招聘需求公告累计公开招聘人数']
option.legend.show = true
// option.tooltip.formatter = function (value) {
// return value[0].axisValue + ':' + (value[0].value - 1) + '
' + value[1].axisValue + ':' + (value[1].value - 1)
// }
option.yAxis[0] = {
type: 'log',
min: 1,
logBase: 10,
axisLine: {
show: false,
},
splitLine: {
show: true,
lineStyle: {
color: '#68b4dd66',
type: 'dashed',
},
},
axisLabel: {
show: true,
formatter: function (value) {
return value === 1 ? 0 : value
},
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
}
myChart.setOption(option)
},
initChartR2 () {
let myChart = echarts.init(this.$refs['echartR2'])
let commonOptions = this.commonOption
commonOptions.yAxis[0].splitNumber = 2
let dataTemp = []
let dataTemp2 = []
dataR2[0].forEach(item => {
dataTemp.push(item)
})
dataR2[1].forEach(item => {
dataTemp2.push(item)
})
let option = {
..._.cloneDeep(commonOptions),
series: [
{
name: '录用结果公示次数',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataTemp,
},
{
name: '录用结果公示累计公示人数',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#45DAD1',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataTemp2,
},
],
}
option.title.text = '各省属企业录用结果公示人次'
option.legend.data = ['录用结果公示次数', '录用结果公示累计公示人数']
option.legend.show = true
// option.tooltip.formatter = function (value) {
// return value[0].axisValue + ':' + (value[0].value - 1) + '
' + value[1].axisValue + ':' + (value[1].value - 1)
// }
option.yAxis[0] = {
type: 'log',
min: 1,
logBase: 10,
axisLine: {
show: false,
},
splitLine: {
show: true,
lineStyle: {
color: '#68b4dd66',
type: 'dashed',
},
},
axisLabel: {
show: true,
formatter: function (value) {
return value === 1 ? 0 : value
},
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
}
myChart.setOption(option)
},
initChartR3 () {
let myChart = echarts.init(this.$refs['echartR3'])
let commonOptions = this.commonOption
commonOptions.yAxis[0].splitNumber = 2
let option = {
..._.cloneDeep(commonOptions),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#45DAD1',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '年利润(万)',
type: 'bar',
barWidth: 15,
label: {
normal: {
show: true,
position: 'bottom',
textStyle: {
color: '#69c0ff',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 14,
},
formatter: function (data) {
if (data.name == "国际能源" || data.name == '文旅集团' || data.name == '航产集团' || data.name == '华舰体育') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataR3[0],
},
{
name: '2022年招聘人数和2023年当前累计招聘人数之和',
type: 'bar',
barWidth: 15,
yAxisIndex: 1,
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: '#45DAD1',
fontStyle: 'normal',
textAlign: 'right',
fontSize: 14,
},
formatter: function (data) {
if (data.name == "国际能源" || data.name == '文旅集团' || data.name == '航产集团' || data.name == '华舰体育') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
color: params => {
if (params.value > 0 && dataR3[0][params.dataIndex] < 0) {
return 'red'
} else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#45DAD1',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
// itemStyle: {
// normal: {
// color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
// {
// offset: 0,
// color: '#45DAD1',
// },
// {
// offset: 1,
// color: '#082550',
// },
// ]),
// },
// },
data: dataR3[1],
},
],
}
option.title.text = '各省属企业年利润与当年累计招聘人数'
option.legend.data = ['年利润(万)', '2022年招聘人数和2023年当前累计招聘人数之和']
option.legend.show = true
option.yAxis[0] = {
max: function (value) {
if (Math.abs(value.max) > Math.abs(value.min)) {
return (Math.abs(value.max) * 1.2).toFixed(2)
} else {
return (Math.abs(value.min) * 1.2).toFixed(2)
}
},
min: function (value) {
if (Math.abs(value.max) > Math.abs(value.min)) {
return (-Math.abs(value.max) * 1.2).toFixed(2)
} else {
return (-Math.abs(value.min) * 1.2).toFixed(2)
}
},
type: 'value',
axisLine: {
show: false,
},
splitLine: {
show: true,
lineStyle: {
color: '#68b4dd66',
type: 'dashed',
},
},
axisLabel: {
show: true,
formatter: function (value) {
return value === 1 ? 0 : value
},
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
}
option.yAxis.push({
splitLine: {
show: false,
},
axisLine: {
show: false,
},
axisLabel: {
show: true,
formatter: '{value}',
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
max: function (value) {
if (Math.abs(value.max) > Math.abs(value.min)) {
return (Math.abs(value.max) * 1.2).toFixed(2)
} else {
return (Math.abs(value.min) * 1.2).toFixed(2)
}
},
min: function (value) {
if (Math.abs(value.max) > Math.abs(value.min)) {
return (-Math.abs(value.max) * 1.2).toFixed(2)
} else {
return (-Math.abs(value.min) * 1.2).toFixed(2)
}
},
})
myChart.setOption(option)
},
initChartR4 () {
let myChart = echarts.init(this.$refs['echartR4'])
let commonOptions = this.commonOption
commonOptions.yAxis[0].splitNumber = 2
let option = {
..._.cloneDeep(commonOptions),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#6480f3',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '2022年退出人数和2023年当前累计退出人数之和',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: dataR4[0],
},
{
name: '2022年招聘人数和2023年当前累计招聘人数之和',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: params => {
// if (params.value / dataR4[0][params.dataIndex] > 3) {
// return 'green'
// } else if (params.value / 2 < dataR4[0][params.dataIndex]) {
// return 'yellow'
// }
if (dataR4[0][params.dataIndex] / 2 < params.value) {
return 'red'
}
else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#6480f3',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
},
data: dataR4[1],
},
],
}
option.title.text = '各省属企业"退二进一"完成情况'
option.legend.data = ['2022年退出人数和2023年当前累计退出人数之和', '2022年招聘人数和2023年当前累计招聘人数之和']
option.legend.show = true
option.yAxis[0] = {
//type: 'log',
//min: 1,
//logBase: 3,
axisLine: {
show: false,
},
splitLine: {
show: true,
lineStyle: {
color: '#68b4dd66',
type: 'dashed',
},
},
axisLabel: {
show: true,
formatter: function (value) {
return value === 1 ? 0 : value
},
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
},
}
myChart.setOption(option)
},
initChartR5 () {
let myChart = echarts.init(this.$refs['echartR5'])
let option = {
..._.cloneDeep(this.commonOption),
series: [
{
name: '去年同期在岗职工平均薪酬',
type: 'bar',
barWidth: 15,
markLine: {
data: [
{
name: '省属企业平均水平',
yAxis: 9333.33,
lineStyle: {
color: '#fff',
},
label: {
formatter: '{b}',
position: 'middle',
fontSize: 16,
color: '#fff',
},
}
],
label: {
distance: [50, 0],
},
},
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#6682F5',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: fjxdataL1[1],
},
{
name: '在岗职工平均薪酬',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
]),
},
},
data: fjxdataL1[0],
},
],
}
option.title.text = '各省属企业在岗职工平均薪酬'
option.legend.data = ['去年同期在岗职工平均薪酬', '在岗职工平均薪酬']
option.legend.show = true
option.yAxis.push({
splitLine: {
show: false,
},
axisLine: {
show: false,
},
})
myChart.setOption(option)
},
initChartR6 () {
let myChart = echarts.init(this.$refs['echartR6'])
let option = {
..._.cloneDeep(this.commonOption),
color: ['#69c0ff'],
series: [
{
name: '月利润总额同期变化率',
type: 'line',
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 8, //标记的大小
smooth: false,
label: {
normal: {
show: true,
lineHeight: '20',
position: 'top',
textStyle: {
color: '#B889EA',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '文旅集团') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
//折线拐点标志的样式
color: '#B889EA',
borderColor: '#B889EA',
width: 2,
shadowColor: '#B889EA',
shadowBlur: 4,
},
lineStyle: {
color: '#B889EA',
width: 2,
},
data: fjxdataL2[0],
},
{
name: '月薪酬总额同期变化率',
type: 'line',
smooth: true, //平滑曲线显示
showAllSymbol: true, //显示所有图形。
symbol: 'circle', //标记的图形为实心圆
symbolSize: 12, //标记的大小
smooth: false,
label: {
normal: {
show: true,
position: 'top',
lineHeight: '35',
textStyle: {
color: '#69c0ff',
fontStyle: 'normal',
textAlign: 'left',
fontSize: 16,
},
formatter: function (data) {
if (data.name == '文旅集团') {
return data.value
} else {
return ''
}
}
}
},
itemStyle: {
color: params => {
if (params.value > 0 && fjxdataL2[0][params.dataIndex] < 0) {
return 'yellow'
} else if (params.value < 0 && fjxdataL2[0][params.dataIndex] > 0) {
return 'green'
}
else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#69c0ff',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
lineStyle: {
color: '#69C0FF',
width: 2,
},
data: fjxdataL2[1],
},
{
type: 'effectScatter',
coordinateSystem: 'cartesian2d',
showEffectOn: 'render',
rippleEffect: {
period: 10,
scale: 4,
brushType: 'stroke'
},
hoverAnimation: true,
itemStyle: {
color: 'yellow'
},
lineStyle: {
color: '#43ede3',
width: 2,
},
data: this.twinkleR6,
},
],
}
option.title.text = '各省属企业利润与薪酬变动情况'
option.legend.data = ['月利润总额同期变化率', '月薪酬总额同期变化率']
option.tooltip.formatter = '{a0}:{c0}' + '%' + '
' + '{a1}:{c1}' + '%'
option.yAxis[0].axisLabel.formatter = '{value} %'
myChart.setOption(option)
},
initChartR7 () {
let myChart = echarts.init(this.$refs['echartR7'])
let option = {
..._.cloneDeep(this.commonOption),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#B889EA',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '全员绩效考核完成率',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: params => {
if (params.value < 50) {
return 'yellow'
}
else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#B889EA',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
},
data: fjxdataL3[0],
},
],
}
option.title.text = '各省属企业全员绩效考核'
option.legend.show = true
option.tooltip = {
trigger: 'axis',
formatter: '{a0}:{c0}' + '%'
},
option.yAxis[0].axisLabel = {
show: true,
formatter: '{value} %',
textStyle: {
color: 'rgba(250,250,250,0.6)',
},
}
myChart.setOption(option)
},
initChartR8 () {
let myChart = echarts.init(this.$refs['echartR8'])
let option = {
..._.cloneDeep(this.commonOption),
color: [
{
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0,
color: '#43ede3',
},
{
offset: 1,
color: '#082550',
},],
}
],
series: [
{
name: '任期制契约化考核完成率',
type: 'bar',
barWidth: 15,
itemStyle: {
normal: {
color: params => {
if (params.value < 50) {
return 'yellow'
}
else {
return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#43ede3',
},
{
offset: 1,
color: '#082550',
},
])
}
},
},
},
data: fjxdataL4[0],
},
],
}
option.title.text = '各省属企业任期制契约化管理'
option.legend.show = true
option.tooltip.formatter = '{a0}:{c0}' + '%'
option.yAxis[0].axisLabel.formatter = '{value} %'
myChart.setOption(option)
},
},
})