let app = new Vue({ el: "#app", data() { return { config5: { waitTime: 2000, rowNum: 4, header: ["单位名称", "平均工资涨幅", ''], data: [ ["山焦财务", '-12%'], ["山焦担保", '4%'], ["山焦股份", '6%'], ["山焦国华", '20%'], ["山焦国华", '9%'], ["山焦财务", '-1%'], ["山焦担保", '4%'], ["山焦股份", '6%'], ["山焦国华", '20%'], ["山焦国华", '9%'] ], align: ["center", "center"], headerBGC: "#153A62", oddRowBGC: "#061F42", evenRowBGC: "#0C284A", }, config1: { waitTime: 2000, rowNum: 1, data: [ ["山焦财务", '-12%'], ["山焦担保", '4%'], ["山焦股份", '6%'], ["山焦国华", '20%'], ["山焦国华", '9%'], ["山焦财务", '-1%'], ["山焦担保", '4%'], ["山焦股份", '6%'], ["山焦国华", '20%'], ["山焦国华", '9%'] ], align: ["center", "center"], oddRowBGC: "#3B9DEE", evenRowBGC: "#1E5389", }, configLast1: { waitTime: 2000, header: ["项目名称"], rowNum: 2, data: [ ["大型矿井综合掘进机器人",], ["废弃矿山遗留资源及地下空间开发利用关键技术研究",], ["遗留难采煤炭资源安全绿色高回收率开采关键技术研究与示范",], ["山西煤炭资源高效保水开采技术与示范",], ["炼焦煤采洗配销一体化关键技术研究",], ["高瓦斯矿井110工法回采工作面瓦斯与自然发火共治关键技术示范研究",], ], align: ["center", "center"], headerBGC: "#153A62", oddRowBGC: "#061F42", evenRowBGC: "#0C284A", }, configLast2: { waitTime: 2000, header: ["合作高校"], rowNum: 2, data: [ ["太原理工大学",], ["北京大学",], ["安徽理工大学",], ["太原理工大学",], ["中国科学技术大学",], ["太原理工大学",], ["中国矿业大学",], ], align: ["center", "center"], headerBGC: "#153A62", oddRowBGC: "#061F42", evenRowBGC: "#0C284A", }, configLast3: { waitTime: 2000, header: ["合作类型"], rowNum: 2, data: [ ["国家重点研发计划项目",], ["山西省揭榜招标项目",], ["山西省科技重大专项",], ["山西省揭榜招标项目",], ["山西省重点研发项目",], ["山西省重点研发项目",], ], align: ["center", "center"], headerBGC: "#153A62", oddRowBGC: "#061F42", evenRowBGC: "#0C284A", }, configLast4: { waitTime: 2000, header: ["主要成效"], rowNum: 2, data: [ ["综合掘进机器人系统",], ["建立废弃矿山煤层气地面抽采和废弃矿山地下空间利用先导工程",], ["遗留难采煤炭资源赋存状况的全方位勘探新技术,超前注浆封堵新材料、新装置与新工艺。",], ["底板阻水性能评价方法体系,研发承压水突水机理与岩层改性再造技术,形成了一套高效承压水上采煤保水开采方案",], ["开展煤质检测和配煤技术研究,开发配煤模型及智能配煤算法",], ["解决了瓦斯超限问题",], ], align: ["center", "center"], headerBGC: "#153A62", oddRowBGC: "#061F42", evenRowBGC: "#0C284A", }, configOrg: { waitTime: 2000, rowNum: 2, data: [ ["西山煤电", '西山建筑', '组织更名', '2023-07-13'], ["集团本部", '财税共享服务中心', '组织更名', '2023-07-13'], ["焦煤置业", '海南科思实业有限公司', '组织停用', '2023-04-04'], ["焦煤置业", '呼和浩特市城发供热有限责任公司', '组织更名', '2023-04-04'], ["西山煤电", '房城建安有限公司', '组织停用', '2023-04-01'], ["霍州煤电", '建筑建材公司', '组织停用', '2023-03-25'], // ["金融资本公司", '山焦担保', '组织合并', '2023-06-01'], // ["山西焦煤", '焦炭交易中心', '组织新设', '2022-12-29'], // ["集团本部", '综治信访中心', '组织新设', '2022-12-1'], // ["山西焦煤", '实验室', '组织新设', '2022-07-20'], // ["山西焦煤", '招标公司', '组织新设', '2022-05-19'], ], align: ["center", "center", "center", "center", "center"], headerBGC: "#153A62", oddRowBGC: "#061F42", evenRowBGC: "#0C284A", }, configChange: { waitTime: 2000, header: ["姓名", "调出单位", "调入单位", "调动时间", '变动状态',], rowNum: 6, data: [ ["段树成", '山煤国际', '招标公司', '2023-07-04', '调动完成'], ["蒲立志", '焦煤置业', '山煤国际', '2023-07-01', '调动完成'], ["侯利强", '霍州煤电', '西山煤电', '2023-07-01', '调动完成'], ["王国明", '西山煤电', '华晋焦煤', '2023-06-19', '调动完成'], ["梁婧", '西山煤电', '物资装备公司', '2023-06-01', '调动完成'], ["赵越", '山煤国际', '招标公司', '2023-06-01', '调动完成'], ["董然", '西山煤电', '人力资源公司', '2023-06-01', '调动完成'], ["解红梅", '西山煤电', '投资公司', '2023-06-01', '调动完成'], ], align: ["center", "center", "center", "center", "center"], headerBGC: "#153A62", oddRowBGC: "#061F42", evenRowBGC: "#0C284A", }, configMark: { waitTime: 2000, // header: ["单位名称", "人员数量", "月份", "预警项"], header: ["单位名称", "月份", "人员数量", "预警项"], rowNum: 6, data: [ ["西山煤电", "71", "7月", "薪资低于4000元"], ["汾西矿业", "1896", "7月", "薪资低于4000元"], ["霍州煤电", "847", "7月", "薪资低于4000元"], ["山煤国际", "514", "7月", "薪资低于4000元"], ["华晋焦煤", "13", "7月", "薪资低于4000元"], ], align: ["center", "center", "center", "center", "center"], headerBGC: "#153A62", oddRowBGC: "#061F42", evenRowBGC: "#0C284A", }, config2: { waitTime: 2000, header: ["单位名称", "已算薪单位", "未算薪单位", "算薪进度百分比"], rowNum: 4, data: [ ["西山煤电", '84', '0', '100%'], ["汾西矿业", '47', '0', '100%'], ["霍州煤电", '93', '0', '100%'], ["山煤国际", '53', '0', '100%'], ["华晋焦煤", '8', '0', '100%'], ], align: ["center", "center", "center", "center", "center"], headerBGC: "#153A62", oddRowBGC: "#061F42", evenRowBGC: "#0C284A", }, configWarning: { waitTime: 2000, header: ["单位名称", "算薪进度", "算薪周期"], rowNum: 6, data: [ // ["西山煤电铁路公司", '未参与算薪', '2023/6'], // ["西山煤电铁路公司", '未参与算薪', '2023/6'], // ["西山煤电斜沟矿", '未参与算薪', '2023/6'], // ["汾西矿业曙光煤矿", '未参与算薪', '2023/6'], // ["山煤国际霍尔辛赫", '未参与算薪', '2023/6'], // ["霍州煤电-辛置煤矿", '未参与算薪', '2023/6'], // ["华晋焦煤沙曲选煤厂", '未参与算薪', '2023/6'], ], align: ["center", "center", "center", "center", "center"], headerBGC: "#153A62", oddRowBGC: "#061F42", evenRowBGC: "#0C284A", }, fIndex: 0, fList: [{ project: "大型矿井综合掘进机器人", school: "太原理工大学, 北京大学", type: "国家重点研发计划项目", merits: "综合掘进机器人系统" }, { project: "废弃矿山遗留资源及地下空间开发利用关键技术研究", school: "安徽理工大学,太原理工大学,中国科学技术大学", type: "山西省揭榜招标项目", merits: "建立废弃矿山煤层气地面抽采和废弃矿山地下空间利用先导工程" }, { project: "遗留难采煤炭资源安全绿色高回收率开采关键技术研究与示范", school: "太原理工大学", type: "山西省科技重大专项", merits: "遗留难采煤炭资源赋存状况的全方位勘探新技术,超前注浆封堵新材料、新装置与新工艺。" }, { project: "山西煤炭资源高效保水开采技术与示范", school: "中国矿业大学", type: "山西省揭榜招标项目", merits: "底板阻水性能评价方法体系,研发承压水突水机理与岩层改性再造技术,形成了一套高效承压水上采煤保水开采方案" }, { project: "炼焦煤采洗配销一体化关键技术研究", school: "太原理工大学", type: "山西省重点研发项目", merits: "开展煤质检测和配煤技术研究,开发配煤模型及智能配煤算法" }, { project: "高瓦斯矿井110工法回采工作面瓦斯与自然发火共治关键技术示范研究", school: "太原理工大学", type: "山西省重点研发项目", merits: "解决了瓦斯超限问题" }, ], salaryFlag: false, pdfFlag: true, eChartsBig: undefined, LineChart: undefined, LineElse: undefined, time2: undefined, leftEcharts5: undefined, mobilizeFL: undefined, industry: { x: ["矿井", "选煤厂", "火电厂", "清洁电厂", "焦化厂"], y: [151, 50, 6, 32, 4] }, twoBar: undefined, echartTwoList: { x: ["回采", "掘进", "开拓", "运输", "机电", "通风安全", "安拆", "露天", "其他"], y: [11556, 15008, 6073, 10562, 8492, 10776, 1553, 119, 3668] }, echartTwoList2: { x: ["洗选", "化工", "民爆", "金融", "销售"], y: [10115, 6327, 2301, 104, 2604] }, echartsTwoBar2: { y: ["4940", "18170", "51812", "38430", '18329', '17745', '31827'], x: ["5年以下", "6-10年", "11-15年", "16-20年", '21-25年', '26-30年', '30年以上'] }, echartsTwoBar1: { y: ["15990", "38872", "35952", "27063", '31424', '26099', '11401'], x: ["30岁以下", "31-35岁", "36-40岁", "41-45岁", '46-50岁', '51-55岁', '55岁以上'] }, // organizationList: { // x: ["集团机构数", "共享中心数", "事业部数", "二级组织数", "三级组织数", "四级组织数"], // y: [18, 12, 5, 22, 316, 496] // }, orgIndex: 0, organizationList: [{ name: "职能部门", flag: true, value: 18 }, { name: "共享中心", flag: false, value: 12 }, { name: "事业部", flag: false, value: 5 }, { name: "二级单位", flag: false, value: 22 }, { name: "三级单位", flag: false, value: 316 }, { name: "四级单位", flag: false, value: 496 },], twoIndex: 1, time2: 1, time3: 1, time4: 1, isShowMark: false, studioMark: false, changeFlag: false, mobilizeFlag: false, warningFlag: false, userFlag: true, salaryIndex: 1, sx: [], xy: [], fx: [], fy1: [], fy2: [], fy3: [], fy4: [], fy5: [], intervalL: undefined, intervalR: undefined, titleList: ["高校分布", "单位分布"], titleIndex: 0, timeTitle: null, efficiency: null, timeL: null, nx1: [], ny1: [], nx2: [], ny2: [], twoChange: 0, twoTime: null, SAtime: null, levelTime: null, twoTimeIndex: 0, saTimeIndex: 0, levelTimeIndex: 0, saIndex: 1, seniorityListX: [], seniorityListY: [], ageListX: [], ageListY: [], levelListX: [], levelListY: [], echartsLevel: null, levelInterval: null, workEcharts: null, downhole: null, downholeIndex: 1, downholeTime: null, echartsMark: false, loginInfo: { unit: "人", num: 273030 }, mauInfo: { unit: "人", mau: 33755 }, skillIndex: 0, studentIndex: 2, studentTimes: null, studentEcharts: null, studioTitle: "", achievementIndex: 0, honorIndex: 0, listFlag: false, listInterval: null, HumanResourcesList: [{ key: "优化池", value: 276, image: "./images/top-1.png", }, { key: "缓冲池", value: 3733, image: "./images/top-3.png", }, { key: "待岗池", value: 5923, image: "./images/top-4.png", }, { key: "共享池", value: 300, image: "./images/top-2.png", },], schoolList1: [{ name: "实习实训高校", image: "./images/newImage/school.png", value: 35, unit: "所", style: { color: "#65FAFF" } }, { name: "实习实训", image: "./images/newImage/pink.png", value: 1714, unit: "人", style: { color: "#EC8AED" } },], schoolList2: [{ name: "产学研合作高校", image: "./images/newImage/yellow.png", value: 7, unit: "所", style: { color: "#FF9915" } }, { name: "产学研成果", image: "./images/newImage/green.png", value: 120, unit: "个", style: { color: "#39F656" } },], orgChange: true, SalaryCalProgDetail: true, imageList: ["./images/newImage/ppt1.png", "./images/newImage/ppt2.png", "./images/newImage/ppt3.png"], imageIndex: 0, imageFlag: false, pageFlag: true, ml: "ml0", optimize: [{ key: "双选岗位", value: 24, unit: "个" }, { key: "优化人数", value: 14, unit: "人" }], optimizeValue: 4.8, PersonnelResource: [{ name: "用工总数", value: 213185, color: "#92B6FF", src: "./images/newImage/user.png" }, { name: "男性员工", value: 171886, color: "#FFDA92", src: "./images/newImage/man.png" }, { name: "女性员工", value: 41299, color: "#89FFAC", src: "./images/newImage/woman.png" }], downholeObj: { key: "选拔培养", value: 2807 }, staffList: { coal: 97395, noCoal: 81766 }, selectFlag: false, selectYearFlag: false, selectInfo: { total: "08", average: "08" }, selectYearInfo: { total: "2024", average: "2024" }, selectType: "total", selectYearType: "total", markStyle: { position: "absolute", top: "13%", right: "21%", }, markYearStyle: { position: "absolute", top: "13%", right: "21%", }, newSkillList: [], dataFlag: true, isShowRequest: true, isShowPage: true, industryEcharts: null, userListX: [], userListy1: [], userListy2: [], userListy3: [], userIndex: 0, timeUserList: null, stereoscopic: undefined, imageUrl: "./pdf/1.png", defeat: 0, showChange: false, fetchIndex: 0, employsNums: 15308, selectTraining: 2807, technical: null, IndustrydistributionIndex: 0, isShowFlag: false, setTypeFlag: null, gtTotle: 90, userColor: false, monthColor: false, staffSeniority: "", staffAge: "", } }, beforeCreate() { // 跳转地址 setTimeout(() => { let AddUrl = location.protocol + "//" + location.host + "/ierp" return if (!window.location.search) { // alert("链接已失效,请重新打开") window.location.href = AddUrl } console.log(window.location); let arr = window.location.search.split("&") let dataList = [] arr.forEach(item => { dataList.push(item.split("=")[1]) }) window.user = dataList[0] let newDate = new Date().getTime() let authorityType = window.sessionStorage.getItem("authorityType") || false console.log(newDate); console.log(parseInt(dataList[1])); console.log(newDate - parseInt(dataList[1]) < 30000); var diff = Math.abs(newDate - parseInt(dataList[1])); // 获取两个时间戳的差值(以毫秒为单位) var diffInSeconds = Math.floor(diff / 1000); // 将差值转换为秒数 let effective = diffInSeconds <= 300; // 判断差值是否在30秒以内 console.log(diff); console.log(diffInSeconds); console.log(effective); debugger if (!authorityType) { if (!effective) { console.log("链接已失效,请重新打开"); window.location.href = AddUrl } else { console.log("链接未失效") window.sessionStorage.setItem("authorityType", true) } } }) }, beforeDestroy() { window.sessionStorage.removeItem("authorityType") }, watch: { imageIndex() { let that = this if (this.imageIndex == this.imageList.length) { setTimeout(() => { this.echartsLevel.dispose() let level = this.$refs.level let sum = 0 levelList.y.forEach(item => { sum = sum + item }) this.initLineElseEcharts(level, { x: this.levelListX[0], y: this.levelListY[0] }, sum) this.mapChart.dispose() let el = this.$refs.container this.initProvinceChart(el) this.studentEcharts.dispose() let student = this.$refs.student this.initEchartsBar(student, schoolList, "#07ecd9") }) this.imageIndex = 0 this.imageFlag = false } }, }, mounted() { let data if (new Date().getMonth() <= 9) { if(new Date().getMonth() == 0){ data = "12" } else { data = "0" + new Date().getMonth() } } else { data = new Date().getMonth() } this.selectInfo = { total: data, average: data } this.selectYearInfo = { total: new Date().getFullYear(), average: new Date().getFullYear() } this.$nextTick(() => { this.keyDown() // document.documentElement.webitRequestFullScreen() // let organization = this.$refs.organization // this.initOrganization(organization, "", this.organizationList) // let share = this.$refs.share // this.initHorizontalBar(share) // let el = this.$refs.container // // this.initProvinceChart(el) // this.initMap2(el) // this.timeNs() // this.timePractice() // this.timeNt() // this.studentTime() // setInterval(()=>{ // this.workEcharts.dispose() // let works = this.$refs.works // this.initBarCharts(works, worksList) // },16000) // this.timeLevel() // setInterval(_ => { // if (this.fIndex == this.fList.length - 1) { // this.fIndex = 0 // } else { // this.fIndex = this.fIndex + 1 // } // this.organizationList.forEach(item => { // item.flag = false // }) // if (this.orgIndex == this.organizationList.length - 1) { // this.orgIndex = 0 // } else { // this.orgIndex = this.orgIndex + 1 // } // this.organizationList[this.orgIndex].flag = true // skillList.forEach(item => { // item.flag = false // }) // if (this.skillIndex == skillList.length - 1) { // this.skillIndex = 0 // } else { // this.skillIndex = this.skillIndex + 1 // } // skillList[this.skillIndex].flag = true // }, 2000) setTimeout(() => { }, 9000) }) let changeData = setInterval(() => { this.getAccumulatedLogin() this.getMauInfo() console.log("数据更新每五分钟一次"); }, 10000) if (this.isShowRequest) { this.requestFunction() } else { this.noRequestFunction() } setInterval(() => { this.SAtime && clearInterval(this.SAtime); this.levelTime && clearInterval(this.levelTime); this.downholeTime && clearInterval(this.downholeTime); this.twoTime && clearInterval(this.twoTime); this.timeUserList && clearInterval(this.timeUserList); // this.timeTitle && clearInterval(this.timeTitle); this.time2 && clearInterval(this.time2); this.time3 && clearInterval(this.time3); if (this.isShowRequest) { this.requestFunction() } else { this.noRequestFunction() } }, 1000 * 60 * 60) }, methods: { handleChangeData() { this.isShowPage = false; this.SAtime && clearInterval(this.SAtime); this.levelTime && clearInterval(this.levelTime); this.downholeTime && clearInterval(this.downholeTime); this.twoTime && clearInterval(this.twoTime); this.timeUserList && clearInterval(this.timeUserList); // this.timeTitle && clearInterval(this.timeTitle); this.time2 && clearInterval(this.time2); this.time3 && clearInterval(this.time3); this.time4 && clearInterval(this.time4); this.requestFunction() setTimeout(() => { this.isShowPage = true; }, 3) this.dataFlag = !this.dataFlag }, // 监听键盘 keyDown() { let that = this; document.onkeydown = (e) => { //事件对象兼容 if (this.imageFlag) { let e1 = e || event || window.event || arguments.callee.caller.arguments[0] //键盘按键判断:左箭头-37;上箭头-38;右箭头-39;下箭头-40 33 翻页笔的下 34 翻页笔的下 if (e1 && e1.keyCode == 37) { if (that.imageIndex != 0) { that.imageIndex = that.imageIndex - 1 } } else if (e1 && e1.keyCode == 38) { // that.imageIndex = that.imageIndex - 1 if (that.imageIndex != 0) { that.imageIndex = that.imageIndex - 1 } } else if (e1 && e1.keyCode == 33) { // that.imageIndex = that.imageIndex - 1 if (that.imageIndex != 0) { that.imageIndex = that.imageIndex - 1 } } else if (e1 && e1.keyCode == 39) { that.imageIndex = that.imageIndex + 1 } else if (e1 && e1.keyCode == 40) { that.imageIndex = that.imageIndex + 1 } else if (e1 && e1.keyCode == 34) { that.imageIndex = that.imageIndex + 1 } } } }, noRequestFunction() { let that = this; let industry = that.$refs.industry that.initOrganizationElse(industry, "", that.industry, "") let student = this.$refs.student this.initEchartsBar(student, schoolList, "#07ecd9") this.fx = spArr(mobilizeList.x, 6) this.fy1 = spArr(mobilizeList.y1, 6) this.fy2 = spArr(mobilizeList.y2, 6) this.fy3 = spArr(mobilizeList.y3, 6) this.fy4 = spArr(mobilizeList.y4, 6) this.fy5 = spArr(mobilizeList.y5, 6) let mobilize = this.$refs.mobilize this.initEchartStack(mobilize, { x: this.fx[0], y1: this.fy1[0], y2: this.fy2[0], y3: this.fy3[0], y4: this.fy4[0], y5: this.fy5[0] }) this.timeSy() let buffer = that.$refs.buffer this.initStereoscopic(buffer, userList) this.initChartsBig() let level = this.$refs.level let sum = 0 levelList.y.forEach(item => { sum = sum + item }) that.levelListX = spArr(levelList.x, 4) that.levelListY = spArr(levelList.y, 4) that.initLineElseEcharts(level, { x: that.levelListX[0], y: that.levelListY[0] }, sum) let initChartR1 = this.$refs.initChartR1 this.initChartR1(initChartR1) let efficiency = this.$refs.efficiency this.initDownholeEcharts(efficiency, { x: downhole.x, y: [downhole.y[0], downhole.y[1], downhole.y[2], downhole.y[3]] }, 1) this.downholeTimes() let sequence = this.$refs.sequence this.initBarEcharts(sequence, { x: ["管理序列", "技术序列", "操作序列"], y1: [34242, 18547, 134012], y2: [20, 30, 50] }, ["当前数"]) this.nx1 = spArr(this.echartTwoList.x, 5) this.ny1 = spArr(this.echartTwoList.y, 5) this.nx2 = spArr(this.echartTwoList2.x, 5) this.ny2 = spArr(this.echartTwoList2.y, 5) let echartTwo = this.$refs.echartTwo this.initTwoBarEcharts(echartTwo, { x: that.nx1[0], y: that.ny1[0] }) this.ageListX = spArr(this.echartsTwoBar1.x, 4) this.ageListY = spArr(this.echartsTwoBar1.y, 4) this.seniorityListX = spArr(this.echartsTwoBar2.x, 4) this.seniorityListY = spArr(this.echartsTwoBar2.y, 4) let serviceAge = this.$refs.serviceAge this.initLineEcharts(serviceAge, { x: this.ageListX[this.saTimeIndex], y: this.ageListY[this.saTimeIndex] }) this.SAtimeFun() let echarts90 = that.$refs.echarts90 that.sx = spArr(salaryList.x, 6) that.sy = spArr(salaryList.y, 6) that.initLineElseEchartsR(echarts90, { x: that.sx[0], y: that.sy[0] }) let leftEnd = that.$refs.leftEnd that.initBarEchartsElse(leftEnd, leftEndList, ["累计月平均工资", "同期累计月平均工资"]) let el = this.$refs.container // this.initProvinceChart(el) this.initMap2(el) }, requestFunction() { let that = this; localEnvAppToken().then(res => { localStorage.setItem("app_token", res.app_token) getLocalEnvAccessToken().then(res => { localStorage.setItem("access_token", res.access_token) this.getAccumulatedLogin() this.getMauInfo() this.getOrganizationChange() this.getIndustrydistribution(true) this.getHumanResources() this.getSalaryCalProg() this.getCollegeinternAndEnterpriseship() this.getTurnOver() this.getOptimizeResources() this.getHumanOrgAllResources() this.getMapData() this.getPersonnelResource() this.getEduStructure() this.getSkillLevel() this.getRankLevel() this.getGrassRoots() this.getEmploysNums() this.getPositionSequence() this.getDownholeoperationTrue() this.getDownholeoperationFlase() this.getTurnOverDetail() this.getDistributionAttachment() // 算薪预警 this.getSalaryCalProgDetail() this.getDept(true) // 员工年龄 this.getStaffAge() this.getCalSalary() // 均衡工资 this.getCalSalary1() // 薪酬预警 this.getCalSalary2() this.getCollegestudy() // 技能大师 this.getCmasterstudio(1) this.getCmasterstudio(2) this.getCmasterstudio(3) this.getCmasterstudio(4) this.getCmasterstudio(5) }) }).catch(err => { let industry = that.$refs.industry that.initOrganizationElse(industry, "", that.industry, "") let student = this.$refs.student this.initEchartsBar(student, schoolList, "#07ecd9") this.fx = spArr(mobilizeList.x, 6) this.fy1 = spArr(mobilizeList.y1, 6) this.fy2 = spArr(mobilizeList.y2, 6) this.fy3 = spArr(mobilizeList.y3, 6) this.fy4 = spArr(mobilizeList.y4, 6) this.fy5 = spArr(mobilizeList.y5, 6) let mobilize = this.$refs.mobilize this.initEchartStack(mobilize, { x: this.fx[0], y1: this.fy1[0], y2: this.fy2[0], y3: this.fy3[0], y4: this.fy4[0], y5: this.fy5[0] }) this.timeSy() let buffer = that.$refs.buffer this.initStereoscopic(buffer, userList) this.initChartsBig() let level = this.$refs.level let sum = 0 levelList.y.forEach(item => { sum = sum + item }) that.levelListX = spArr(levelList.x, 4) that.levelListY = spArr(levelList.y, 4) that.initLineElseEcharts(level, { x: that.levelListX[0], y: that.levelListY[0] }, sum) let initChartR1 = this.$refs.initChartR1 this.initChartR1(initChartR1) let efficiency = this.$refs.efficiency this.initDownholeEcharts(efficiency, { x: downhole.x, y: [downhole.y[0], downhole.y[1], downhole.y[2], downhole.y[3]] }, 1) this.downholeTimes() let sequence = this.$refs.sequence this.initBarEcharts(sequence, { x: ["管理序列", "技术序列", "操作序列"], y1: [34242, 18547, 134012], y2: [20, 30, 50] }, ["当前数"]) this.nx1 = spArr(this.echartTwoList.x, 5) this.ny1 = spArr(this.echartTwoList.y, 5) this.nx2 = spArr(this.echartTwoList2.x, 5) this.ny2 = spArr(this.echartTwoList2.y, 5) let echartTwo = this.$refs.echartTwo this.initTwoBarEcharts(echartTwo, { x: that.nx1[0], y: that.ny1[0] }) this.ageListX = spArr(this.echartsTwoBar1.x, 4) this.ageListY = spArr(this.echartsTwoBar1.y, 4) this.seniorityListX = spArr(this.echartsTwoBar2.x, 4) this.seniorityListY = spArr(this.echartsTwoBar2.y, 4) let serviceAge = this.$refs.serviceAge this.initLineEcharts(serviceAge, { x: this.ageListX[this.saTimeIndex], y: this.ageListY[this.saTimeIndex] }) this.SAtimeFun() let echarts90 = that.$refs.echarts90 that.sx = spArr(salaryList.x, 6) that.sy = spArr(salaryList.y, 6) that.initLineElseEchartsR(echarts90, { x: that.sx[0], y: that.sy[0] }) let leftEnd = that.$refs.leftEnd that.initBarEchartsElseJM(leftEnd, leftEndList, ["累计月平均工资", "同期累计月平均工资"]) let el = this.$refs.container // this.initProvinceChart(el) this.initMap2(el) }) }, handleSelect(flag = 'total') { if (flag == 'total') { this.markStyle = { position: "absolute", top: "13%", right: "21%", } } else if (flag == 'average') { this.markStyle = { position: "absolute", top: "25.5%", right: "1.5%", } } this.handleMark() this.isShowMark = true; this.selectFlag = true; this.selectType = flag }, handleYearSelect(flag = 'total') { if (flag == 'total') { this.markYearStyle = { position: "absolute", top: "13%", right: "23%", } } else if (flag == 'average') { this.markYearStyle = { position: "absolute", top: "25.5%", right: "3.5%", } } this.handleMark() this.isShowMark = true; this.selectYearFlag = true; this.selectYearType = flag }, selectOption(item) { this.selectInfo[this.selectType] = item console.log(this.selectType); if (this.selectType == "average") { this.getCalSalary(2) } if (this.selectType == "total") { this.getCalSalary1(2) } }, selectYearOption(item) { this.selectYearInfo[this.selectYearType] = item if (this.selectYearType == "average") { this.getCalSalary(2) } if (this.selectYearType == "total") { this.getCalSalary1(2) } }, SAtimeFun() { let that = this; this.SAtime = setInterval(() => { this.SAtime && clearInterval(this.SAtime); this.SAtimeFun() let serviceAge = that.$refs.serviceAge this.LineChart.dispose(); if (that.saIndex == 1) { if (that.saTimeIndex == that.ageListX.length - 1) { that.saTimeIndex = 0 that.saIndex = 2 that.initLineEcharts(serviceAge, { x: that.seniorityListX[that.saTimeIndex], y: that.seniorityListY[that.saTimeIndex] }) return } else { that.saTimeIndex = that.saTimeIndex + 1 } that.initLineEcharts(serviceAge, { x: that.ageListX[that.saTimeIndex], y: that.ageListY[that.saTimeIndex] }) } else { if (that.saTimeIndex == that.seniorityListX.length - 1) { that.saTimeIndex = 0 that.saIndex = 1 that.initLineEcharts(serviceAge, { x: that.ageListX[that.saTimeIndex], y: that.ageListY[that.saTimeIndex] }) return } else { that.saTimeIndex = that.saTimeIndex + 1 } that.initLineEcharts(serviceAge, { x: that.seniorityListX[that.saTimeIndex], y: that.seniorityListY[that.saTimeIndex] }) } }, 8000) }, timeLevel() { let that = this; this.levelTime = setInterval(_ => { this.levelTime && clearInterval(this.levelTime); this.timeLevel() let level = this.$refs.level this.echartsLevel.dispose() if (that.levelTimeIndex == that.levelListX.length - 1) { that.levelTimeIndex = 0 } else { that.levelTimeIndex = that.levelTimeIndex + 1 } let sum = 0 levelList.y.forEach(item => { sum = sum + item }) this.initLineElseEcharts(level, { x: this.levelListX[that.levelTimeIndex], y: this.levelListY[that.levelTimeIndex] }, sum) }, 8000) }, downholeTimes() { let that = this; this.downholeTime = setInterval(() => { this.downholeTime && clearInterval(this.downholeTime); this.downholeTimes() let efficiency = this.$refs.efficiency this.downhole && this.downhole.dispose() if (that.downholeIndex == 1) { this.downholeObj = { key: "集团公司", value: that.employsNums } this.initDownholeEcharts(efficiency, { x: downhole.x, y: [downhole.y[4], downhole.y[5]] }, 2) that.downholeIndex = 2 } else if (that.downholeIndex == 2) { this.downholeObj = { key: "选拔培养", value: that.selectTraining } this.initDownholeEcharts(efficiency, { x: downhole.x, y: [downhole.y[0], downhole.y[1], downhole.y[2], downhole.y[3]] }, 1) that.downholeIndex = 1 } }, 10000) }, timeTwo() { let that = this; this.twoTime = setInterval(() => { this.twoTime && clearInterval(this.twoTime); this.timeTwo() let echartTwo = that.$refs.echartTwo let serviceAge = that.$refs.serviceAge that.twoBar.dispose(); if (that.twoIndex == 1) { if (that.twoTimeIndex == that.nx1.length - 1) { that.twoTimeIndex = 0 that.twoIndex = 2 that.initTwoBarEcharts(echartTwo, { x: that.nx2[that.twoTimeIndex], y: that.ny2[that.twoTimeIndex] }) return } else { that.twoTimeIndex = that.twoTimeIndex + 1 } that.initTwoBarEcharts(echartTwo, { x: that.nx1[that.twoTimeIndex], y: that.ny1[that.twoTimeIndex] }) } else { if (that.twoTimeIndex == that.nx2.length - 1) { that.twoTimeIndex = 0 that.twoIndex = 1 that.initTwoBarEcharts(echartTwo, { x: that.nx1[that.twoTimeIndex], y: that.ny1[that.twoTimeIndex] }) return } else { that.twoTimeIndex = that.twoTimeIndex + 1 } that.initTwoBarEcharts(echartTwo, { x: that.nx2[that.twoTimeIndex], y: that.ny2[that.twoTimeIndex] }) } }, 8000) }, // 人才市场定时器 timeuserList() { let that = this; this.timeUserList = setInterval(() => { this.timeUserList && clearInterval(this.timeUserList); this.timeuserList() let buffer = that.$refs.buffer that.stereoscopic.dispose(); if (that.userIndex >= that.userListX.length - 1) { that.userIndex = 0 // this.userListX = spArr(userList.x,9) // this.userListy1 = spArr(userList.y1,9) // this.userListy2 = spArr(userList.y2,9) // this.userListy3 = spArr(userList.y3,9) that.initStereoscopic(buffer, { x: that.userListX[that.userIndex], y1: that.userListy1[that.userIndex], y2: that.userListy2[that.userIndex], y3: that.userListy3[that.userIndex] }) } else { that.userIndex += 1 that.initStereoscopic(buffer, { x: that.userListX[that.userIndex], y1: that.userListy1[that.userIndex], y2: that.userListy2[that.userIndex], y3: that.userListy3[that.userIndex] }) } }, 18000) }, // 针对学历结构的定时器 timeNt() { let that = this; this.timeTitle = setInterval(() => { this.timeTitle && clearInterval(this.timeTitle); this.timeNt(); that.efficiency.dispose() let efficiency = this.$refs.efficiency if (that.titleIndex > 1) { that.titleIndex = 0 that.initBarChartsElse(efficiency, efficiencyList, "吨/工", { name: "行业线", value: 8.2 }) that.titleList = ["原煤工效", "全员效率"] } else { that.initBarChartsElse(efficiency, wholeList, "吨/人", { name: "标杆矿井线", value: 1800 }) that.titleList = ["全员效率", "原煤工效"] } that.titleIndex = that.titleIndex + 1 }, 12000); }, timeNs() { let that = this; this.time2 = setInterval(() => { this.time2 && clearInterval(this.time2); this.timeNs(); // that.leftEcharts5.dispose(); let initChartsBig = that.$refs.initChartsBig that.initChartsBig(initChartsBig) }, 15000); }, timeSy() { let that = this; this.time4 = setInterval(() => { this.time4 && clearInterval(this.time4); this.timeSy(); that.LineElse.dispose(); that.mobilizeFL.dispose(); let echarts90 = this.$refs.echarts90 let mobilize = this.$refs.mobilize if (that.salaryIndex == that.sx.length) { that.salaryIndex = 0 } this.initLineElseEchartsR(echarts90, { x: that.sx[that.salaryIndex], y: that.sy[that.salaryIndex] }) if (that.salaryIndex < that.fx.length) { this.initEchartStack(mobilize, { x: this.fx[that.salaryIndex], y1: this.fy1[that.salaryIndex], y2: this.fy2[that.salaryIndex], y3: this.fy3[that.salaryIndex], y4: this.fy4[that.salaryIndex], y5: this.fy5[that.salaryIndex] }) } else { this.initEchartStack(mobilize, { x: this.fx[0], y1: this.fy1[0], y2: this.fy2[0], y3: this.fy3[0], y4: this.fy4[0], y5: this.fy5[0] }) } that.salaryIndex += 1 }, 11500); }, // 针对从业人员类别的定时器 timePractice() { let that = this; this.time3 = setInterval(() => { this.time3 && clearInterval(this.time3); this.timePractice(); that.twoBar.dispose(); that.LineChart.dispose(); let echartTwo = that.$refs.echartTwo let serviceAge = that.$refs.serviceAge if (that.twoIndex == 1) { that.initTwoBarEcharts(echartTwo, { x: that.nx1[0], y: that.ny1[0] }) that.initLineEcharts(serviceAge, that.echartsTwoBar1) that.twoIndex = 2 that.twoTimeIndex = 0 } else { that.initTwoBarEcharts(echartTwo, { x: that.nx2[0], y: that.ny2[0] }) that.initLineEcharts(serviceAge, that.echartsTwoBar2) that.twoTimeIndex = 0 that.twoIndex = 1 } this.userFlag = !this.userFlag }, 15000); }, initOrganization(el, title = "", data = { x: ["集团本部", "山焦财务", "山焦担保", "山焦股份", "山焦国华", "山焦机电", "山焦人力", "山焦民爆", "山焦事业", "山焦投资"], y: [0, 680, 562, 268, 717, 843, 987, 126, 723, 569] }, unit = "") { let chart = echarts.init(el); let option = { grid: { top: 25, right: 15, left: "15%", bottom: "27%", }, grid: { top: 30, right: 20, left: 105, bottom: 40, }, tooltip: { backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", show: true, trigger: "axis", textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: "shadow", // 默认为直线,可选为:'line' | 'shadow' }, }, xAxis: { data: data.x, axisTick: { show: false, }, // x轴的字体颜色 axisLabel: { interval: 0, // rotate: 40, textStyle: { fontSize: 30, color: '#A3E2F4', fontWeight: 0, }, }, //y轴线的颜色以及宽度 axisLine: { show: true, lineStyle: { color: "#1E5389", width: 1, type: "solid", }, }, }, yAxis: { name: unit, type: "log", axisTick: { lineStyle: { color: "#18416F", }, }, // y轴的字体颜色 axisLabel: { textStyle: { color: "white", fontSize: 30, }, }, nameTextStyle: { fontSize: 20, }, splitLine: { show: true, lineStyle: { color: "#204561", width: 1, type: "dotted", }, }, //y轴线的颜色以及宽度 axisLine: { show: true, lineStyle: { color: "#1E5389", width: 1, type: "solid", }, }, }, series: [{ name: "", type: "line", smooth: true, showSymbol: true, // 节点长显 symbol: 'image://' + '', symbolSize: 30, data: data.y, areaStyle: { color: new echarts.graphic.LinearGradient( 0, 0, 0, 1, [{ offset: 0, color: "#40A9FF", }, { offset: 1, color: "#051F41", }, ], false ), }, itemStyle: { color: "#40A9FF", }, lineStyle: { width: 2, }, }], }; let that = this; chart.setOption(option); chart.on('click', function (param) { that.isShowMark = true that.salaryFlag = false that.pdfFlag = true }) tools.loopShowTooltip(chart, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // chart.resize(); // }); }, initOrganizationElse(el, title = "", data = { x: ["集团本部", "山焦财务", "山焦担保", "山焦股份", "山焦国华", "山焦机电", "山焦人力", "山焦民爆", "山焦事业", "山焦投资"], y: [0, 680, 562, 268, 717, 843, 987, 126, 723, 569] }, unit = "") { if (this.industryEcharts != null) { this.industryEcharts.dispose() } this.industryEcharts = echarts.init(el); let option = { title: { show: false, top: 5, left: "center", text: title, textStyle: { color: "#5EB7FF", fontSize: 32 } }, grid: { top: 50, right: 40, left: 105, bottom: 40, }, tooltip: { backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", show: true, trigger: "axis", textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: "shadow", // 默认为直线,可选为:'line' | 'shadow' }, formatter: "{c}" }, xAxis: { data: data.x, axisTick: { show: false, }, // x轴的字体颜色 axisLabel: { interval: 0, // rotate: 40, textStyle: { fontSize: 30, color: '#fff', fontWeight: 0, }, }, //y轴线的颜色以及宽度 axisLine: { show: true, lineStyle: { color: "#1E5389", width: 1, type: "solid", }, }, }, yAxis: { name: unit, axisTick: { lineStyle: { color: "#18416F", }, }, // y轴的字体颜色 axisLabel: { textStyle: { color: "white", fontSize: 28, }, }, nameTextStyle: { fontSize: 20, color: "white", }, splitLine: { show: true, lineStyle: { color: "#204561", width: 1, type: "dotted", }, }, //y轴线的颜色以及宽度 axisLine: { show: true, lineStyle: { color: "#1E5389", width: 1, type: "solid", }, }, }, series: [{ name: "", type: "bar", data: data.y, showBackground: true, backgroundStyle: { color: "#18416F", }, barWidth: "20%", itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: "#02355C", }, //柱图渐变色 { offset: 1, color: "#40A9FF", }, ]), }, }], // legend: { // data: ["入池人数", "出池人数"], // textStyle: { // // 图列内容样式 // color: "#fff", // 字体颜色 // // fontSize: "10", // }, // right: 30, // icon: "roundRect", // // 小图标的宽高 // itemHeight: 5, // }, }; let that = this; this.industryEcharts.setOption(option); tools.loopShowTooltip(this.industryEcharts, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // this.industryEcharts.resize(); // }); }, initLineEcharts(el, data) { if (this.intervalL != undefined) { clearInterval(this.intervalL) } this.LineChart = echarts.init(el); let index = 0; let dataList = this.changeOnIndex(data.y, index); let option = { grid: { top: 25, right: 5, left: 100, bottom: 35, }, tooltip: { show: true, trigger: "axis", backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { type: "none", lineStyle: { color: "#ddd", }, }, formatter: "{c}" }, legend: { textStyle: { // 图列内容样式 color: "#fff", // 字体颜色 // fontSize: "10", }, right: 30, icon: "roundRect", // 小图标的宽高 itemHeight: 5 }, xAxis: { type: "category", data: data.x, // boundaryGap: false, splitLine: { show: false, interval: "auto", }, axisTick: { show: false, }, axisLine: { show: false, lineStyle: { fontSize: 30, color: '#fff', fontWeight: 0, }, }, axisLabel: { interval: 0, // rotate: 25, textStyle: { fontSize: 32, color: "#fff", }, }, }, yAxis: { type: "value", splitLine: { show: false, lineStyle: { color: "#204561", width: 1, type: "dotted", }, }, axisTick: { show: false, }, axisLine: { show: false, lineStyle: { color: "#7ECEF4", }, }, axisLabel: { margin: 10, textStyle: { fontSize: 28, color: "#fff", }, }, }, series: [{ name: "", type: "line", smooth: false, showSymbol: true, // 节点长显 data: dataList, areaStyle: { color: new echarts.graphic.LinearGradient( 0, 0, 0, 1, [{ offset: 0, color: "#45DAD1", }, { offset: 1, color: "#051F41", }, ], false ), }, itemStyle: { color: "#45DAD1", }, lineStyle: { width: 2, }, }], }; this.intervalL = setInterval(() => { index = index + 1 if (index == data.y.length) { index = 0 } dataList = this.changeOnIndex(data.y, index); this.LineChart.setOption({ series: [{ type: 'line', data: dataList }] }); }, 2000) this.LineChart.setOption(option); tools.loopShowTooltip(this.LineChart, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function() { // this.LineChart.resize(); // }); }, changeOnIndex(arr = [], i = 0) { let dataY = [] arr.forEach((item, index) => { let obj; if (index == i) { obj = { value: item, symbolSize: 50, symbol: 'image://' + '', } } else { obj = { value: item, symbolSize: 30, symbol: 'image://' + '' } } dataY.push(obj) }) return dataY }, initLineElseEcharts(el, data, sum) { if (this.levelInterval != null) { clearInterval(this.levelInterval) } this.echartsLevel = echarts.init(el); let index = 0; let dataList = this.changeOnIndex(data.y, index); let option = { title: { text: sum != undefined ? '总人数: ' + sum : '总人数: 0', subtext: '', top: 0, right: 0, textStyle: { fontSize: 30, fontWeight: 'bold', color: '#fff' }, }, grid: { top: 25, right: 15, left: 110, bottom: 40, }, tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: "axis", textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { type: "none", lineStyle: { color: "#ddd", }, }, formatter: "{c}" }, legend: { textStyle: { // 图列内容样式 color: "#fff", // 字体颜色 // fontSize: "10", }, right: 30, icon: "roundRect", // 小图标的宽高 itemHeight: 5 }, xAxis: { type: "category", data: data.x, boundaryGap: true, splitLine: { show: false, interval: "auto", }, axisTick: { show: false, }, axisLine: { lineStyle: { color: "#7ECEF4", }, }, axisLabel: { interval: 0, // rotate: 40, margin: 10, textStyle: { fontSize: 30, color: "#fff", }, }, }, yAxis: { type: "value", splitLine: { show: true, lineStyle: { color: "#204561", width: 1, type: "dotted", }, }, axisTick: { show: false, }, axisLine: { lineStyle: { color: "#7ECEF4", }, }, axisLabel: { margin: 10, textStyle: { fontSize: 28, color: "#fff", }, }, }, series: [{ name: "", type: "line", smooth: false, showSymbol: true, // 节点长显 data: dataList, areaStyle: { color: new echarts.graphic.LinearGradient( 0, 0, 0, 1, [{ offset: 0, color: "#40A9FF", }, { offset: 1, color: "#051F41", }, ], false ), }, itemStyle: { color: "#40A9FF", }, emphasis: { itemStyle: { color: '#d4bc1d', symbol: 'image://' + '', }, }, lineStyle: { width: 2, }, }], }; this.levelInterval = setInterval(() => { index = index + 1 if (index == data.y.length) { index = 0 } dataList = this.changeOnIndex(data.y, index); this.echartsLevel.setOption({ series: [{ type: 'line', data: dataList }] }); }, 2000) this.echartsLevel.setOption(option); tools.loopShowTooltip(this.echartsLevel, option, { nterval: 3000, loopSeries: true, }); // window.addEventListener("resize", function() { // this.echartsLevel.resize(); // }); }, initMap2(el, data) { let myChart = echarts.init(el) let img = 'image://images/newImage/data-1619059838735-QE9mBZmhh.png' var geoCoordMap = { 太原市: [112.049248, 37.957014], 大同市: [113.595259, 39.89031], 阳泉市: [113.505474, 38.064652], 长治市: [112.913556, 36.591112], 晋城市: [112.551274, 35.577553], 朔州市: [112.433387, 39.531261], 晋中市: [112.936465, 37.486495], 运城市: [111.003957, 34.99], 忻州市: [112.333538, 38.7769], 临汾市: [111.517973, 36.48415], 吕梁市: [111.134335, 37.524366], } let effectScatterData = [{ itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 534, "山西焦煤机关",], }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 14972, "山煤国际",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 91, "物资装备公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 111, "金土地公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 835, "销售公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 117, "国发公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 582, "投资公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 117, "人力资源公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 10, "金融资本公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 843, "民爆集团",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 47, "新能源公司",] }, { itemStyle: { color: "#fff" }, name: "晋中市", value: [112.936465, 37.696495, 49047, "汾西矿业",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 65704, "西山煤电",] }, { itemStyle: { color: "#fff" }, name: "临汾市", value: [111.517973, 35.88415, 53563, "霍州煤电",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 67, "交易中心",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 48, "招标公司",] }, { itemStyle: { color: "#fff" }, name: "临汾市", value: [111.517973, 35.88415, 9508, "山西焦化",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 13, "油品公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 29, "低碳公司",] }, { itemStyle: { color: "#fff" }, name: "吕梁市", value: [111.134335, 37.524366, 9960, "华晋焦煤",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 10, "云数据公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 218, "焦煤置业",] }, { itemStyle: { color: "#fff" }, name: "吕梁市", value: [111.134335, 37.524366, 9960, "华晋焦煤",] }, ] if (data) { effectScatterData = data } mapDate = [] let iconList = [] const result = effectScatterData.reduce((acc, obj) => { const { name, value } = obj; const existingItem = acc.find(item => item.name === name); if (existingItem) { existingItem.value.push(value[2]); } else { acc.push({ name, value: [value[2]] }); } return acc; }, []); result.forEach(item => { let key = 0 item.value.forEach(i => { key = i + key }) item.key = key }) for (let k in geoCoordMap) { effectScatterData.forEach(item => { if (item.name == k) { item.value[0] = geoCoordMap[k][0] item.value[1] = geoCoordMap[k][1] } }) result.forEach(item => { if (item.name == k) { let obj = { name: k, value: geoCoordMap[k], datas: item.key, img } mapDate.push(obj) } }) let icon = { name: k, value: geoCoordMap[k], img } iconList.push(icon) } var img2 = 'image://images/newImage/bggg.png' echarts.registerMap('shanxi', jsonData); option = { tooltip: { trigger: "item", padding: 15, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", enterable: true, transitionDuration: 1, formatter: (params, ticket, callback) => { // 清空所有轮播 for (var k in geoCoordMap) { myChart.dispatchAction({ type: 'downplay', name: k, }) } // 如果鼠标滑动到线线上面,则返回空 myChart.dispatchAction({ // type: 'geoSelect', type: 'highlight', name: params.name, }) if (params.componentSubType == 'lines') { return } if (params.componentSubType == "scatter") { let tipHtml = `

区域:${params.name}

二级单位:${params.value[3]}

员工总数:${params.value[2]}

` if (params.value[2] == undefined) { return "" } callback(ticket, tipHtml) return tipHtml } if (params.componentSubType == 'effectScatter') { let tipHtml = `

区域:${params.name}

二级单位:${params.value[3]}

员工总数:${params.value[2]}

` if (params.value[2] == undefined) { return "" } callback(ticket, tipHtml) return tipHtml } if (params.componentSubType == 'map') { return } }, }, geo: { map: 'shanxi', zoom: 1.5, layoutCenter: ['51%', '55.5%'], layoutSize: '100%', silent: true, roam: false, z: 1, // itemStyle: { // areaColor: 'rgba(0, 15, 40, 1)', // shadowColor: 'rgba(0, 0, 0, 1)', // shadowBlur: 0, // shadowOffsetX: 0, // shadowOffsetY: 5, // borderColor: 'rgba(0, 0, 0, 1)', // borderWidth: 0.5, // emphasis: { // areaColor: '#2AB8FF', // borderWidth: 1, // color: 'green', // label: { // show: false, // }, // }, // }, itemStyle: { areaColor: '#25B9E9', shadowColor: '#25B9E9', borderWidth: 6, //设置外层边框 borderColor: '#00FFFF', shadowOffsetX: 5, shadowOffsetY: 5, shadowBlur: 5, emphasis: { areaColor: '#013d95', borderColor: '#e7e1a0', borderWidth: 4, //设置外层边框 }, }, }, series: [ { type: 'scatter', coordinateSystem: 'geo', zlevel: 2, rippleEffect: { //涟漪特效 period: 2, //动画时间,值越小速度越快 brushType: 'stroke', //波纹绘制方式 stroke, fill scale: 8, //波纹圆环最大限制,值越大波纹越大 color: '#d4bc1d', }, emphasis: { itemStyle: { color: '#d4bc1d' } }, label: { show: false, }, symbol: 'circle', symbolSize: 0, symbolOffset: [0, -370], data: effectScatterData, // data: series[1].data, }, { type: 'scatter', coordinateSystem: 'geo', label: { show: true, formatter: function (params) { var name = params.name; var value = params.data.datas; var text = `{tline|${name}}`; return text; }, color: '#fff', rich: { fline: { padding: [0, 25], color: '#fff', textShadowColor: '#030615', textShadowBlur: '0', textShadowOffsetX: 1, textShadowOffsetY: 1, fontSize: 45, fontWeight: 800, }, tline: { padding: [0, 35], color: '#ffdd00', fontSize: 40, fontWeight: 800, }, }, emphasis: { show: true, }, }, itemStyle: { color: '#00FFF6', }, symbol: img2, symbolSize: [200, 160], symbolOffset: [0, -200], z: 999, data: iconList, }, { type: 'map', label: { show: false, textStyle: { color: '#fff', }, emphasis: { show: false, textStyle: { color: '#fff', }, }, }, select: { itemStyle: { areaColor: '#1C4FBB', borderColor: 'rgba(5,216,252,0.7)', borderWidth: 6, //隐藏省界线 shadowColor: 'rgba(5,216,252,0.7)', shadowBlur: 90, } }, itemStyle: { areaColor: '#1C4FBB', borderColor: 'rgba(5,216,252,0.7)', borderWidth: 6, //隐藏省界线 shadowColor: 'rgba(5,216,252,0.7)', shadowBlur: 90, emphasis: { areaColor: 'rgba(25,79,183,0.6)', borderColor: '#d4bc1d', shadowColor: '#d4bc1d', shadowBlur: 90, borderWidth: 8, //设置外层边框 label: { color: "#fff" } } }, layoutCenter: ['50%', '55%'], layoutSize: '100%', zoom: 1.5, roam: false, map: 'shanxi', }, { type: 'effectScatter', coordinateSystem: 'geo', rippleEffect: { scale: 10, brushType: 'stroke', color: "#fff" }, showEffectOn: 'render', itemStyle: { shadowColor: '#0ff', shadowBlur: 10, shadowOffsetX: 0, shadowOffsetY: 0, // color: "#fff" color: new echarts.graphic.LinearGradient(1, 0, 0, 0, [ { offset: 0, color: '#64fbc5', }, { offset: 1, color: '#018ace', }, ]), }, label: { color: '#fff', }, symbol: 'circle', symbolSize: [30, 15], data: iconList, zlevel: 9, }, { type: 'scatter', coordinateSystem: 'geo', symbol: function (value, params) { return params.data.img; }, symbolSize: [96, 123], symbolOffset: [0, -75], z: 3, data: iconList, }, ], }; myChart.setOption(option); tools.loopShowTooltip(myChart, option, { interval: 2000, loopSeries: false, }); }, initLineElseEchartsR(el, data) { if (this.intervalR != undefined) { clearInterval(this.intervalR) } this.LineElse = echarts.init(el); let index = 0; let dataList = this.changeOnIndex(data.y, index); let option = { grid: { top: 15, right: "2%", left: "10%", bottom: 60, }, tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: "axis", textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { type: "none", lineStyle: { color: "#ddd", }, }, formatter: "{c} %" }, legend: { textStyle: { // 图列内容样式 color: "#fff", // 字体颜色 // fontSize: "10", }, right: 30, icon: "roundRect", // 小图标的宽高 itemHeight: 5 }, xAxis: { type: "category", data: data.x, boundaryGap: true, splitLine: { show: false, interval: "auto", }, axisTick: { show: false, }, axisLine: { show: false, lineStyle: { color: "#7ECEF4", }, }, axisLabel: { interval: 0, textStyle: { fontSize: 30, color: "#fff", }, // formatter: function(value) { // // 将文字进行换行 // let list = value.split("") // if(list.length == 5){ // list[3] = "" // } // if(list.length > 4){ // list[4] = "" // } // return list[0] + list[1] + "\n" + list[2] + list[3]; // } }, }, yAxis: { type: "value", min: 80, // max: 100, // splitNumber: 3, // interval: 10, splitLine: { show: true, lineStyle: { color: "#204561", width: 1, type: "dotted", }, }, axisTick: { show: false, }, axisLine: { lineStyle: { color: "#7ECEF4", }, }, axisLabel: { textStyle: { fontSize: 28, color: "#fff", }, }, }, series: [{ name: "", type: "line", smooth: false, showSymbol: true, // 节点长显 data: dataList, areaStyle: { color: new echarts.graphic.LinearGradient( 0, 0, 0, 1, [{ offset: 0, color: "#40A9FF", }, { offset: 1, color: "#051F41", }, ], false ), }, itemStyle: { color: "#40A9FF", }, lineStyle: { width: 2, }, }], }; this.intervalR = setInterval(() => { index = index + 1 if (index == data.y.length) { index = 0 } dataList = this.changeOnIndex(data.y, index); this.LineElse.setOption({ series: [{ type: 'line', data: dataList }] }); }, 2000) this.LineElse.setOption(option); tools.loopShowTooltip(this.LineElse, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function() { // this.LineElse.resize(); // }); }, initChartR1(el, data = [{ name: "高级-正高级", value: 146, }, { name: "高级-副高级", value: 4021, }, { name: "中级", value: 17437, }, { name: "初级-助理级", value: 12622, }, { name: "初级-员级", value: 7350, }, ]) { this.technical = echarts.init(el) let objData = {} let sum = 0 data.forEach(item => { objData[item.name] = item.value sum = sum + item.value }) let option = { title: { text: sum || 0, subtext: ' 总人数', left: '15%', top: '39%', textStyle: { color: '#FFAD05', fontSize: 40, }, subtextStyle: { color: '#fff', fontSize: 30, }, }, tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: "item", textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { lineStyle: { color: "#ddd", }, }, formatter: "{b} : {c}({d}%)" }, legend: { top: 'center', orient: 'vertical', left: '50%', textStyle: { fontSize: 30, color: '#9DB9EB', }, formatter: function (name) { return ( "{title|" + name + "} {value|" + objData[name] + "} {title|人}" ); }, textStyle: { rich: { title: { fontSize: 30, lineHeight: 50, color: "#fff", }, value: { fontSize: 30, fontWeight: "bolder", lineHeight: 50, color: "#FFAD05", }, }, }, }, graphic: { elements: [{ type: 'image', //需要填充图片,配置image,如果不需要图片可以配置其他的, text, circle, sector, ring, polygon, polyline, rect, line, bezierCurve, arc, group, style: { image: './images/pie-back.png', //这里添加图片地址 width: 120, height: 120 }, left: '16%', // top: 'middle' //配置图片居中 }] }, series: [{ name: '', type: 'pie', radius: ['40%', '50%'], center: ["25%", "50%"], labelLine: { show: false, length: 20, length2: 55, emphasis: { show: false } }, selectedMode: 'single', selectedOffset: 90, clockwise: true, label: { show: false, formatter: "{b}", textStyle: { fontSize: 28, }, position: 'outside', emphasis: { show: false } }, data: data, emphasis: { scaleSize: 15, // 设置放大倍数 }, itemStyle: { color: function (colors) { var colorList = [ "#DDEBF7", "#BDD7EE", "#9BC2E6", "#2F75B5", "#1F4E78" ]; return colorList[colors.dataIndex]; }, // emphasis: { // // shadowBlur: 50, // shadowOffsetX: 15, // shadowOffsetY: 15, // shadowColor: 'red' // }, } },], } this.technical.setOption(option) tools.loopShowTooltip(this.technical, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // myChart.resize(); // }); }, initChartsBig(arr = [{ name: '研究生及以上', y: 3103, sliced: false, selected: false, }, { name: '大学', y: 42543, sliced: false, selected: false, }, { name: '大专', y: 46669, sliced: false, selected: false, }, { name: '中专、技校', y: 69437, sliced: false, selected: false, }, { name: '初中及以下', y: 25049, sliced: false, selected: false, } ]) { let left5 = arr var chartData = left5 var timer = null; var i = 0; let that = this var option = { colors: [ "#D9E1F2", "#B4C6E7", "#8EA9DB", "#305496", "#203764", ], chart: { type: 'pie', backgroundColor: 'rgba(0,0,0,0)', options3d: { enabled: true, alpha: 45, //beta: 0 }, events: { // load,图表加载完成时触发 load: function () { var chart = this; var points = chart.series[0].points; var len = points.length; timer && clearInterval(timer); timer = setInterval(function () { autoTooltip(points[i]); chartData.forEach((item, index) => { item.sliced = false item.selected = false if (index == i) { item.sliced = true item.selected = true } }) chart.update({ series: [{ type: 'pie', name: '占比', data: chartData }] }) i++; if (i === len) { i = 0; chartData.forEach((item, index) => { item.sliced = false item.selected = false }) chart.update({ series: [{ type: 'pie', name: '占比', data: chartData }] }) } }, 2000); }, legendItemClick: function (event) { return true; } } }, credits: { enabled: false //去掉hightchats水印 }, legend: { align: 'right', //横向位置 verticalAlign: 'middle', // 纵向位置 layout: "vertical", //横排还是竖排 x: 10, y: 100, symbolWidth: 30, itemStyle: { fontSize: '30px', color: '#fff', x: 20, fontWeight: 0, fontFamily: 'Microsoft YaHei' }, }, title: { enabled: false, text: "", }, tooltip: { crosshairs: false, trigger: "axis", backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", style: { fontSize: 30, color: '#A3E2F4', fontWeight: 0, }, axisPointer: { lineStyle: { color: "#ddd", }, }, formatter: function (e) { this.percentage = this.percentage.toFixed(2) //Math.round(this.percentage) return `${this.key}:${this.y}(${this.percentage}%)` }, }, plotOptions: { pie: { allowPointSelect: true, showInLegend: true, // 图例 cursor: 'pointer', size: 350, innerSize: 0, //环形图中间空白,0为饼图 depth: 80, //立体高度 slicedOffset: 40, //动画距离 dataLabels: { enabled: false, // 是否展示指示线 format: '{point.name}: {point.percentage}' } }, }, series: [{ type: 'pie', name: '占比', center: ['50%', '50%'], point: { events: { mouseOver: function (e) { //鼠标移入停止轮播并且找到移入的当前数据设为选中 chartData.forEach((item, index) => { item.sliced = false item.selected = false }) chartData[e.target.index].sliced = true chartData[e.target.index].selected = true chart.update({ series: [{ type: 'pie', name: '占比', point: { events: { click: function (e) { that.showChartLTipDouble(e.point.name) } } }, data: chartData }] }) timer && clearInterval(timer); }, mouseOut: function () { // 鼠标移出后需要继续执行轮播 var points = chart.series[0].points; var len = points.length; timer && clearInterval(timer); timer = setInterval(function () { autoTooltip(points[i]); chartData.forEach((item, index) => { item.sliced = false item.selected = false if (index == i) { item.sliced = true item.selected = true } }) chart.update({ series: [{ type: 'pie', name: '占比', data: chartData }] }) i++; if (i === len) { i = 0; chartData.forEach((item, index) => { item.sliced = false item.selected = false }) chart.update({ series: [{ type: 'pie', name: '占比', data: chartData }] }) } }, 2000); } } }, data: chartData }] } if (chart) { chart.destroy(); } var chart = Highcharts.chart('echartL2', option); function autoTooltip(point) { chart.tooltip.refresh(point); } }, initBarCharts(el, data, markLine = [15.3, 50.8, 69.2]) { this.workEcharts = echarts.init(el); let markLine1 = [] let markLine2 = [] let markLine3 = [] data.x.forEach(item => { markLine1.push(markLine[0]) markLine2.push(markLine[1]) markLine3.push(markLine[2]) }) var option = { tooltip: { //提示框组件 backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: 'axis', formatter: '{b}
{a0}: {c0}
{a1}: {c1}', textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { type: 'shadow', label: { backgroundColor: '#6a7985' } }, textStyle: { color: '#fff', fontFamily: '微软雅黑', fontSize: 30, } }, grid: { left: '9%', right: '9%', bottom: 60, top: 50, }, legend: { //图例组件,颜色和名字 right: 0, top: 0, icon: "circle", data: [{ name: '目标值', }, { name: '实际值', }, { name: "社会平均", }, { name: "省企平均" }, { name: "央企平均" }], textStyle: { color: '#a8aab0', fontFamily: '微软雅黑', fontSize: 30, } }, xAxis: [{ type: 'category', boundaryGap: true, //坐标轴两边留白 data: data.x, axisLabel: { //坐标轴刻度标签的相关设置。 interval: 0, //设置为 1,表示『隔一个标签显示一个标签』 // rotate: 30, textStyle: { color: '#fff', fontFamily: '微软雅黑', fontSize: 30, }, // formatter: function(value) { // // 将文字进行换行 // let list = value.split("") // if(list.length == 5){ // list[3] = "" // } // if(list.length > 4){ // list[4] = "" // } // return list[0] + list[1] + "\n" + list[2] + list[3]; // } }, axisTick: { //坐标轴刻度相关设置。 show: false, }, axisLine: { //坐标轴轴线相关设置 lineStyle: { color: '#fff', opacity: 0.2 } }, splitLine: { //坐标轴在 grid 区域中的分隔线。 show: false, } }], yAxis: [{ name: "万元/人", type: 'value', splitNumber: 5, axisLabel: { textStyle: { color: '#FFF', fontFamily: '微软雅黑', fontSize: 28, } }, nameTextStyle: { color: "#a8aab0", fontSize: 28 }, axisLine: { show: false }, axisTick: { show: false }, splitLine: { show: false, lineStyle: { color: ['#fff'], } } }], series: [{ name: '目标值', type: 'bar', data: data.y2, barWidth: 20, barGap: 0.2, //柱间距离 label: { //图形上的文本标签 show: false, position: 'top', textStyle: { color: '#a8aab0', fontFamily: '微软雅黑', fontSize: 30, }, }, itemStyle: { //图形样式 barBorderRadius: [10, 10, 0, 0], color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#9e65ea', }, { offset: 1, color: '#051F41', } ], false), }, }, { name: '实际值', type: 'bar', data: data.y1, barWidth: 20, barGap: 0, //柱间距离 label: { //图形上的文本标签 show: false, position: 'top', textStyle: { color: '#a8aab0', fontFamily: '微软雅黑', fontSize: 30, }, }, itemStyle: { //图形样式 barBorderRadius: [10, 10, 0, 0], color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 1, color: '#051F41' }, { offset: 0, color: '#84fab0' }], false), }, }, { type: "line", name: "社会平均", smooth: false, showSymbol: false, // 节点长显 lineStyle: { type: "dashed", with: 5, color: "#fff" }, itemStyle: { color: "#fff" }, markLine: { symbol: ['none'], silent: true, data: [{ yAxis: markLine[0], name: markLine[0], lineStyle: { type: "dashed", width: 3, color: '#fff' }, label: { show: true, distance: 10, fontWeight: "lighter", formatter: markLine[0], fontSize: 30, fontWeight: "bolder", color: '#fff' }, }] }, symbolSize: 0, data: markLine1 }, { type: "line", name: "省企平均", data: markLine2, smooth: false, showSymbol: false, // 节点长显 symbolSize: 0, lineStyle: { with: 5, type: "dashed", color: "rgb(0, 255, 242)" }, itemStyle: { color: "rgb(0, 255, 242)" }, markLine: { symbol: ['none'], silent: true, data: [{ yAxis: markLine[1], name: markLine[1], lineStyle: { type: "dashed", width: 3, color: 'rgb(0, 255, 242)' }, label: { show: true, distance: 10, fontWeight: "lighter", formatter: markLine[1], fontSize: 30, fontWeight: "bolder", color: 'rgb(0, 255, 242)' }, }] }, }, { type: "line", name: "央企平均", data: markLine3, symbolSize: 0, smooth: false, showSymbol: false, // 节点长显 lineStyle: { type: "dashed", with: 5, color: "#f9d423" }, itemStyle: { color: "#f9d423" }, markLine: { symbol: ['none'], silent: true, data: [{ yAxis: markLine[2], name: markLine[2], lineStyle: { type: "dashed", width: 3, color: '#f9d423' }, label: { show: true, distance: 10, formatter: markLine[2], fontSize: 30, fontWeight: "bolder", color: '#f9d423' }, }] }, } ] }; this.workEcharts.setOption(option); tools.loopShowTooltip(this.workEcharts, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // this.workEcharts.resize(); // }); }, initBarChartsElse(el, data, name, lineInfo) { this.efficiency = echarts.init(el); let markLine = [] data.x.forEach(item => { markLine.push(lineInfo.value) }) var option = { tooltip: { //提示框组件 backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: 'axis', formatter: '{b}
{a0}: {c0}
{a1}: {c1}', textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { type: 'shadow', label: { backgroundColor: '#6a7985' } }, textStyle: { color: '#fff', fontFamily: '微软雅黑', fontSize: 30, } }, grid: { left: '10%', right: '11%', bottom: 60, top: 50, }, legend: { //图例组件,颜色和名字 right: 10, top: 0, icon: "circle", itemGap: 16, itemWidth: 18, itemHeight: 10, data: [{ name: '目标值', }, { name: '实际值', }, { name: lineInfo.name, }], textStyle: { color: '#a8aab0', fontFamily: '微软雅黑', fontSize: 30, } }, xAxis: [{ type: 'category', boundaryGap: true, //坐标轴两边留白 data: data.x, axisLabel: { //坐标轴刻度标签的相关设置。 interval: 0, textStyle: { color: '#fff', fontFamily: '微软雅黑', fontSize: 30, } }, axisTick: { //坐标轴刻度相关设置。 show: false, }, axisLine: { //坐标轴轴线相关设置 lineStyle: { color: '#fff', opacity: 0.2 } }, splitLine: { //坐标轴在 grid 区域中的分隔线。 show: false, } }], yAxis: [{ name, type: 'value', splitNumber: 5, axisLabel: { textStyle: { color: '#FFF', fontFamily: '微软雅黑', fontSize: 28, } }, nameTextStyle: { color: "#a8aab0", fontSize: 30 }, axisLine: { show: false }, axisTick: { show: false }, splitLine: { show: false, lineStyle: { color: ['#fff'], } } }], series: [{ name: '目标值', type: 'bar', data: data.y2, barWidth: 20, barGap: 0, //柱间距离 label: { //图形上的文本标签 show: false, position: 'top', textStyle: { color: '#a8aab0', fontFamily: '微软雅黑', fontSize: 30, }, }, itemStyle: { //图形样式 barBorderRadius: [10, 10, 0, 0], color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#9e65ea', }, { offset: 1, color: '#051F41', } ], false), }, }, { name: '实际值', type: 'bar', data: data.y1, barWidth: 20, barGap: 0, //柱间距离 label: { //图形上的文本标签 show: false, position: 'top', textStyle: { color: '#a8aab0', fontFamily: '微软雅黑', fontSize: 30, }, }, itemStyle: { //图形样式 barBorderRadius: [10, 10, 0, 0], color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 1, color: '#051F41' }, { offset: 0, color: '#84fab0' }], false), }, markLine: { symbol: ['none'], silent: true, data: [{ yAxis: lineInfo.value, name: lineInfo.name, lineStyle: { type: "dashed", width: 3, color: 'rgb(0, 255, 242)' }, label: { show: true, distance: 20, fontSize: 30, fontWeight: "bolder", color: 'rgb(0, 255, 242)', formatter: lineInfo.value, }, }] }, }, { type: "line", name: lineInfo.name, data: markLine, symbolSize: 0, smooth: false, showSymbol: false, // 节点长显 lineStyle: { type: "dashed", color: "rgb(0, 255, 242)" }, itemStyle: { color: "rgb(0, 255, 242)" } } ] }; this.efficiency.setOption(option); tools.loopShowTooltip(this.efficiency, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // this.efficiency.resize(); // }); }, initBarEcharts(el, data, nameList) { let chart = echarts.init(el); var scale = 2; var singleData = data.y1; var multipleData = [] let max = 0; data.y1.forEach(item => { max = max + item }) data.y1.forEach(item => { let num = ((item / max) * 100).toFixed(2) multipleData.push(num) }) var color = "#fff"; option = { tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: 'axis', textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' }, formatter: "{a}: {c}
{a1}: {c1} %" }, // legend: { // data: nameList, // align: 'left', // itemGap: 50, // // x: 'right', // right: '1%', // y: '1%', // icon: 'rect', // itemWidth: 15 * scale, // 图例图形宽度 // itemHeight: 15 * scale, // 图例图形高度 // textStyle: { // color: "#3fdaff", // fontSize: 16 * scale // } // }, grid: { left: '20%', right: '10%', bottom: '13%', top: "7%", // containLabel: true }, textStyle: { fontSize: 30, color: '#A3E2F4' }, xAxis: [{ type: 'category', data: data.x, axisLabel: { // inside: true, interval: 0, padding: [15, 0, 0, 0], textStyle: { color: "#fff", fontSize: 30, } }, axisTick: { inside: true, length: 8 * scale, lineStyle: { color: color, } }, axisLine: { show: false, lineStyle: { color: color, } }, splitLine: { lineStyle: { color: 'rgba(80,224,255,0.3)', type: 'dashed' } } }], yAxis: [{ type: 'value', // name: "当前数", axisLabel: { // inside: true, padding: [0, 15, 0, 0], textStyle: { color: color, fontSize: 28, } }, axisTick: { show: false, lineStyle: { color: color, } }, axisLine: { show: false, lineStyle: { color: color, } }, splitLine: { lineStyle: { color: '#fff', type: 'dashed' }, show: false, }, nameTextStyle: { show: false, color: "#fff", fontSize: 16 * scale, padding: [0, 0, 10, 0] } }, { type: 'value', // name: "占比", min: 0, max: 100, axisLabel: { // inside: true, padding: [0, 15, 0, 0], textStyle: { color: color, fontSize: 28, } }, axisTick: { show: false, lineStyle: { color: color, } }, axisLine: { lineStyle: { color: color, } }, splitLine: { lineStyle: { color: '#fff', type: 'dashed' }, show: false, }, nameTextStyle: { show: false, color: "#fff", fontSize: 16 * scale, padding: [0, 0, 10, 0] } }], series: [{ name: nameList[0], type: 'bar', barWidth: '15%', barGap: '40%', itemStyle: { color: 'rgba(94,218,255,0.4)', }, data: singleData }, { name: "占比", yAxisIndex: 1, type: 'line', barWidth: '15%', barGap: '40%', itemStyle: { color: '#ffc72b', }, data: multipleData } ] }; chart.setOption(option); tools.loopShowTooltip(chart, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // chart.resize(); // }); }, initBarEchartsElse(el, data, nameList) { let chart = echarts.init(el); var scale = 2; var singleData = data.y1; var multipleData = data.y2; var color = "#fff"; option = { textStyle: { fontSize: 30, color: '#A3E2F4' }, tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: 'axis', textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' }, formatter: '{b}
{a0}: {c0}
{a1}: {c1}', }, legend: { data: nameList, align: 'left', // itemGap: 50, // x: 'right', right: '1%', y: '1%', // icon: 'rect', textStyle: { color: "#fff", fontSize: 30 } }, grid: { top: "10%", left: '6%', right: '4%', bottom: '20%', }, xAxis: [{ type: 'category', data: data.x, axisLabel: { // inside: true, // rotate: 30, interval: 0, padding: [15, 0, 0, 0], textStyle: { color: "#fff", fontSize: 30, }, formatter: function (value) { // 将文字进行换行 let list = value.split("") if (list.length == 5) { list[3] = "" } if (list.length > 4) { list[4] = "" } if(list.length == 3){ list[3] = "" } return list[0] + list[1] + "\n" + list[2] + list[3]; } }, axisTick: { show: false, inside: true, length: 8 * scale, lineStyle: { color: color, } }, axisLine: { show: false, lineStyle: { color: color, } }, splitLine: { show: false, lineStyle: { color: 'rgba(80,224,255,0.3)', type: 'dashed' } } }], yAxis: [{ type: 'value', axisLabel: { // inside: true, padding: [0, 15, 0, 0], textStyle: { color: color, fontSize: 28, } }, axisTick: { show: false, lineStyle: { color: color, } }, axisLine: { show: false, lineStyle: { color: color, } }, splitLine: { show: false, lineStyle: { color: '#fff', type: 'dashed' }, show: false, }, nameTextStyle: { color: "#fff", fontSize: 16 * scale, padding: [0, 0, 10, 0] } }], series: [{ name: nameList[0], type: 'bar', itemStyle: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 1, color: "#02355C", }, //柱图渐变色 { offset: 0, color: "#45DAD1", }, ], false), }, barWidth: 20, label: { show: false, position: "top", align: "center", }, data: singleData }, { name: nameList[1], type: 'line', symbolSize: 20, itemStyle: { color: '#40A9FF', }, smooth: false, showSymbol: true, // 节点长显 barWidth: 20, data: multipleData }, // { // name: nameList[1], // type: 'line', // barWidth: '15%', // barGap: '40%', // label: { // show: false, // position: "top", // align: "center", // }, // itemStyle: { // color: '#ffc72b', // }, // data: multipleData // }, // { // name: nameList[1], // type: 'bar', // barWidth: '15%', // barGap: '40%', // itemStyle: { // color: 'rgba(94,218,255,0.4)', // }, // label: { // show: false, // position: "top", // align: "center", // }, // data: multipleData // }, ] }; chart.setOption(option); tools.loopShowTooltip(chart, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // chart.resize(); // }); }, initBarEchartsElseJM(el, data, nameList) { let chart = echarts.init(el); var scale = 2; var singleData = data.y1; var multipleData = data.y2; var color = "#fff"; option = { textStyle: { fontSize: 30, color: '#A3E2F4' }, tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: 'axis', textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' }, formatter: '{b}
{a0}: ****
{a1}: ****', }, legend: { data: nameList, align: 'left', // itemGap: 50, // x: 'right', right: '1%', y: '1%', // icon: 'rect', textStyle: { color: "#fff", fontSize: 30 } }, grid: { top: "10%", left: '6%', right: '4%', bottom: '20%', }, xAxis: [{ type: 'category', data: data.x, axisLabel: { // inside: true, // rotate: 30, interval: 0, padding: [15, 0, 0, 0], textStyle: { color: "#fff", fontSize: 30, }, formatter: function (value) { // 将文字进行换行 let list = value.split("") if (list.length == 5) { list[3] = "" } if (list.length > 4) { list[4] = "" } if(list.length == 3){ list[3] = "" } return list[0] + list[1] + "\n" + list[2] + list[3]; } }, axisTick: { show: false, inside: true, length: 8 * scale, lineStyle: { color: color, } }, axisLine: { show: false, lineStyle: { color: color, } }, splitLine: { show: false, lineStyle: { color: 'rgba(80,224,255,0.3)', type: 'dashed' } } }], yAxis: [{ type: 'value', show: false, axisLabel: { // inside: true, padding: [0, 15, 0, 0], textStyle: { color: color, fontSize: 28, } }, axisTick: { show: false, lineStyle: { color: color, } }, axisLine: { show: false, lineStyle: { color: color, } }, splitLine: { show: false, lineStyle: { color: '#fff', type: 'dashed' }, show: false, }, nameTextStyle: { color: "#fff", fontSize: 16 * scale, padding: [0, 0, 10, 0] } }], series: [{ name: nameList[0], type: 'bar', itemStyle: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 1, color: "#02355C", }, //柱图渐变色 { offset: 0, color: "#45DAD1", }, ], false), }, barWidth: 20, label: { show: false, position: "top", align: "center", }, data: singleData }, { name: nameList[1], type: 'line', symbolSize: 20, itemStyle: { color: '#40A9FF', }, smooth: false, showSymbol: true, // 节点长显 barWidth: 20, data: multipleData }, // { // name: nameList[1], // type: 'line', // barWidth: '15%', // barGap: '40%', // label: { // show: false, // position: "top", // align: "center", // }, // itemStyle: { // color: '#ffc72b', // }, // data: multipleData // }, // { // name: nameList[1], // type: 'bar', // barWidth: '15%', // barGap: '40%', // itemStyle: { // color: 'rgba(94,218,255,0.4)', // }, // label: { // show: false, // position: "top", // align: "center", // }, // data: multipleData // }, ] }; chart.setOption(option); tools.loopShowTooltip(chart, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // chart.resize(); // }); }, initStereoscopic(el, data) { this.stereoscopic = echarts.init(el); option = { tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: 'axis', textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' } }, grid: { top: 30, bottom: 35, left: 90, right: 10, textStyle: { color: "#fff" } }, legend: { icon: 'circle', right: '4%', top: '4%', textStyle: { color: '#fff', fontSize: 30 }, data: ['缓冲池', '待岗池', '共享池'] }, calculable: true, xAxis: [{ type: "category", axisLine: { show: false, lineStyle: { color: '#fff' } }, splitLine: { show: false }, axisTick: { show: false }, splitArea: { show: false }, axisLabel: { // inside: true, interval: 0, textStyle: { color: "#fff", fontSize: 28, } }, data: data.x, }], yAxis: [{ type: "value", splitLine: { show: false }, axisLine: { show: false, lineStyle: { color: '#fff' } }, axisTick: { show: false }, axisLabel: { textStyle: { color: "#fff", fontSize: 28, } }, splitArea: { show: false }, // data: ['中止合同人员', '双创人员', '考核待岗人员'], }], series: [{ name: "缓冲池", type: "bar", stack: "value", barMaxWidth: 15, barGap: "10%", itemStyle: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#FF9915' }, { offset: 1, color: 'rgba(245,221,111,0)' }]), borderColor: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#FF9915' }, { offset: 1, color: 'rgba(245,221,111,0)' }]), }, data: data.y1, }, { name: "待岗池", type: "bar", stack: "value", barMaxWidth: 15, itemStyle: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#9e65ea' }, { offset: 1, color: 'rgba(24,191,207,0)' }]), borderColor: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#9e65ea' }, { offset: 1, color: 'rgba(24,191,207,0)' }]), }, data: data.y2 }, { name: "共享池", type: "bar", stack: "value", barMaxWidth: 15, itemStyle: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(24,191,207,1)' }, { offset: 1, color: 'rgba(24,191,207,0)' }]), borderColor: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(24,191,207,1)' }, { offset: 1, color: 'rgba(24,191,207,0)' }]), }, data: data.y3 }, ] } this.stereoscopic.setOption(option); tools.loopShowTooltip(this.stereoscopic, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // chart.resize(); // }); }, initHorizontalBar(el) { let chart = echarts.init(el); var bg = 'image://'; var bar = 'image://'; var data = [10, 15]; var barWidth = 20; var maxNum = 0; for (var i = 0; i < data.length; i++) { if (data[i] > maxNum) { maxNum = data[i]; } } option = { grid: { top: '10%', left: '20%', right: '15%', bottom: '0%', }, xAxis: { show: false, }, yAxis: { data: ["共享队伍", "共享单位"], splitLine: { show: false, }, axisLabel: { textStyle: { fontSize: 20, color: '#fff' }, }, axisLine: { show: false, }, axisTick: false, }, series: [{ type: 'pictorialBar', barWidth: barWidth, zlevel: 2, data: data.map(function (item) { return { value: item, symbol: bar, }; }), }, { type: 'pictorialBar', barWidth: barWidth, data: data.map(function (item) { return { realValue: item, value: maxNum, symbol: bg, }; }), label: { show: true, position: 'right', distance: 150, align: "right", formatter: function (params) { if (params.name != "共享队伍") { return params.data.realValue + ' 个'; } else { return params.data.realValue + ' 支'; } }, color: '#fff', fontSize: 35, }, }, ], }; chart.setOption(option); tools.loopShowTooltip(chart, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // chart.resize(); // }); }, initProvinceChart(el, mapData = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]) { var data = [{ name: '大同市', value: mapData[0].value, }, { name: '朔州市', value: mapData[1].value, }, { name: '忻州市', value: mapData[2].value, }, { name: '吕梁市', value: mapData[3].value, }, { name: '太原市', value: 1, }, { name: '阳泉市', value: mapData[5].value, }, { name: '晋中市', value: mapData[6].value, }, { name: '长治市', value: 0, }, { name: '临汾市', value: mapData[8].value, }, { name: '晋城市', value: mapData[9].value, }, { name: '运城市', value: mapData[10].value, } ] for (let i = 0; i < data.length; i++) { const name = data[i].name; const mapDataObj = mapData.find(obj => obj.name === name); if (mapDataObj) { data[i].value = mapDataObj.value; data[i].value2 = mapDataObj.value; } } //  let formdata = '太原' // 中心点 this.geoCoordMap = [] /*获取地图数据*/ this.mapChart = echarts.init(el) echarts.registerMap('shanxi', jsonData) var mapFeatures = echarts.getMap('shanxi').geoJson.features mapFeatures.forEach(v => { // 地区名称 var name = v.properties.name // 地区经纬度 this.geoCoordMap[name] = v.properties.centroid // 按照地图乱序 // data.push({ name: v.properties.name, value: v.properties.centroid[0], value2: v.properties.centroid[1] }) }) // 地图数据 var chinaGeoCoordMap = { 太原市: [111.949248, 38.057014], 大同市: [113.595259, 40.29031], 阳泉市: [113.505474, 37.964652], 长治市: [112.813556, 36.791112], 晋城市: [112.551274, 35.577553], 朔州市: [112.433387, 39.531261], 晋中市: [112.936465, 37.696495], 运城市: [111.003957, 35.59], 忻州市: [112.333538, 38.7769], 临汾市: [111.517973, 36.48415], 吕梁市: [111.134335, 37.524366], } // 飞线点数据 var chinaDatas = [ [{ name: '太原市', value: 0, },], [{ name: '大同市', value: 0, },], [{ name: '阳泉市', value: 0, },], [{ name: '长治市', value: 0, },], [{ name: '晋城市', value: 0, },], [{ name: '朔州市', value: 0, },], [{ name: '晋中市', value: 9, },], [{ name: '运城市', value: 0, },], [{ name: '忻州市', value: 0, },], [{ name: '临汾市', value: 0, },], [{ name: '吕梁市', value: 0, },], ] var convertData = function (data) { var res = [] for (var i = 0; i < data.length; i++) { var dataItem = data[i] var fromCoord = chinaGeoCoordMap[dataItem[0].name] var toCoord = [112.549248, 37.857014] //中心点地理坐标 if (fromCoord && toCoord) { res.push([{ // 飞线从哪里出发 coord: toCoord, }, { // 飞线去往哪里 coord: fromCoord, value: dataItem[0].value, }, ]) } } return res } var series = []; [ [formdata, chinaDatas] ].forEach(function (item) { series.push({ type: 'lines', name: "模拟数据", coordinateSystem: 'geo', zlevel: 2, effect: { show: true, period: 5, //值越小 速度越快 trailLength: 0.3, // 0-1 值越大,越拖 symbol: 'pin', //箭头图标 symbolSize: 8, //图标大小 color: "#E6C50B" }, lineStyle: { show: true, type: 'dashed', width: 2, //尾迹线条宽度 opacity: 0.1, //尾迹线条透明度 curveness: 0.3, //尾迹线条曲直度 color: '#E6C50B', // 飞线颜色 }, data: convertData(item[1]), }, { type: 'effectScatter', coordinateSystem: 'geo', zlevel: 2, rippleEffect: { //涟漪特效 period: 10, //动画时间,值越小速度越快 brushType: 'stroke', //波纹绘制方式 stroke, fill scale: 10, //波纹圆环最大限制,值越大波纹越大 color: '#E6C50B', }, itemStyle: { color: '#E6C50B', shadowBlur: 10, shadowColor: '#E6C50B', }, label: { formatter: '{b}', position: 'right', offset: [15, 0], color: '#fff', show: true }, symbol: 'circle', symbolSize: 9, data: item[1].map(function (dataItem) { return { itemStyle: { color: '#fff' // 修改标点的颜色 }, //在这里定义你所要展示的数据 name: dataItem[0].name, value: chinaGeoCoordMap[dataItem[0].name].concat([dataItem[0].value]), } }), }) }) let effectScatterData = [{ itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 534, "山西焦煤机关",], }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 14972, "山煤国际",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 91, "物资装备公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 111, "金土地公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 835, "销售公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 117, "国发公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 582, "投资公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 117, "人力资源公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 10, "金融资本公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 843, "民爆集团",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 47, "新能源公司",] }, { itemStyle: { color: "#fff" }, name: "晋中市", value: [112.936465, 37.696495, 49047, "汾西矿业",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 65704, "西山煤电",] }, { itemStyle: { color: "#fff" }, name: "临汾市", value: [111.517973, 35.88415, 53563, "霍州煤电",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 67, "交易中心",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 48, "招标公司",] }, { itemStyle: { color: "#fff" }, name: "临汾市", value: [111.517973, 35.88415, 9508, "山西焦化",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 13, "油品公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 29, "低碳公司",] }, { itemStyle: { color: "#fff" }, name: "吕梁市", value: [111.134335, 37.524366, 9960, "华晋焦煤",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 10, "云数据公司",] }, { itemStyle: { color: "#fff" }, name: "太原市", value: [111.949248, 37.957014, 218, "焦煤置业",] }, { itemStyle: { color: "#fff" }, name: "吕梁市", value: [111.134335, 37.524366, 9960, "华晋焦煤",] }, ] series[1].data.forEach(item => { item.img = 'image://https://madeapie.com/asset/get/s/data-1619059838735-QE9mBZmhh.png' }) const result = effectScatterData.reduce((acc, obj) => { const { name, value } = obj; const existingItem = acc.find(item => item.name === name); if (existingItem) { existingItem.values.push(value[2]); } else { acc.push({ name, values: [value[2]] }); } return acc; }, []); result.forEach(item => { data.forEach(i => { if (item.name == i.name) { i.value = item.values.reduce((accumulator, currentValue) => { return accumulator + currentValue; }, 0); } }) }) let option = { tooltip: { trigger: "item", padding: 15, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", enterable: true, transitionDuration: 1, formatter: (params, ticket, callback) => { // 清空所有轮播 for (var k in this.geoCoordMap) { this.mapChart.dispatchAction({ // type: 'geoUnSelect', type: 'downplay', name: k, }) } // 如果鼠标滑动到线线上面,则返回空 this.mapChart.dispatchAction({ // type: 'geoSelect', type: 'highlight', name: params.name, }) if (params.componentSubType == 'lines') { return } if (params.componentSubType == 'effectScatter') { let tipHtml = `

区域:${params.name}

二级单位:${params.value[3]}

员工总数:${params.value[2]}

` callback(ticket, tipHtml) return tipHtml } if (params.componentSubType == 'map') { return } }, }, // visualMap: { // show: true, // min: 0, // max: 30000, // left: '2%', // top: '10%', // calculable: true, // seriesIndex: [2], // inRange: { // color: ['#013d95', '#d4bc1d'] // 蓝绿 // } // }, geo: { show: true, map: 'shanxi', layoutCenter: ['51%', '56%'], //地图位置 layoutSize: '100%', aspectScale: 0.6, regionHeight: 5, zoom: 1.4, //当前视角的缩放比例 // roam: true, //是否开启平游或缩放 scaleLimit: { //滚轮缩放的极限控制 min: 1, max: 2 }, roam: false, itemStyle: { areaColor: '#25B9E9', shadowColor: '#25B9E9', borderWidth: 6, //设置外层边框 borderColor: '#00FFFF', shadowOffsetX: 5, shadowOffsetY: 5, shadowBlur: 5, emphasis: { areaColor: '#013d95', borderColor: '#e7e1a0', borderWidth: 4, //设置外层边框 }, }, }, series: [ // 区域散点图 { type: 'effectScatter', coordinateSystem: 'geo', zlevel: 2, rippleEffect: { //涟漪特效 period: 2, //动画时间,值越小速度越快 brushType: 'stroke', //波纹绘制方式 stroke, fill scale: 8, //波纹圆环最大限制,值越大波纹越大 color: '#d4bc1d', }, emphasis: { itemStyle: { color: '#d4bc1d' } }, label: { show: true, }, symbol: 'circle', symbolSize: 0, data: effectScatterData, // data: series[1].data, }, { type: 'effectScatter', coordinateSystem: 'geo', zlevel: 2, rippleEffect: { //涟漪特效 period: 2, //动画时间,值越小速度越快 brushType: 'stroke', //波纹绘制方式 stroke, fill scale: 8, //波纹圆环最大限制,值越大波纹越大 color: '#d4bc1d', }, emphasis: { itemStyle: { color: '#d4bc1d', } }, label: { show: true, }, symbol: 'circle', symbolSize: 30, data: series[1].data, }, // 地图数据 { type: 'map', mapType: 'shanxi', aspectScale: 0.6, layoutCenter: ["50%", "55%"], //地图位置 layoutSize: '100%', zoom: 1.4, //当前视角的缩放比例 // roam: true, //是否开启平游或缩放 scaleLimit: { //滚轮缩放的极限控制 min: 1, max: 2 }, label: { show: true, position: 'right', formatter: '{b}', color: '#fff', fontSize: 32, fontWeight: "bolder" }, itemStyle: { areaColor: '#1C4FBB', borderColor: 'rgba(5,216,252,0.7)', borderWidth: 6, //隐藏省界线 shadowColor: 'rgba(5,216,252,0.7)', shadowBlur: 90, emphasis: { areaColor: 'rgba(25,79,183,0.6)', borderColor: '#d4bc1d', borderWidth: 8, //设置外层边框 label: { color: "#fff" } } }, data: data, }, // 线 和 点 { type: 'lines', zlevel: 1, //设置这个才会有轨迹线的小尾巴 effect: { show: true, period: 3, trailLength: 0.1, color: '#d4bc1d', //流动点颜色 symbol: 'arrow', symbolSize: 15 }, lineStyle: { color: '#d4bc1d', //线条颜色 show: true, type: "dashed", width: 5, opacity: 0.4, curveness: 0.2 }, data: series[0].data }, ], } let that = this this.mapChart.on('click', function (params) { if (params.name == '太原市') { that.showChartLTipDouble('太原市') } }) tools.loopShowTooltip(this.mapChart, option, { interval: 2000, loopSeries: false, }); this.mapChart.setOption(option) // window.addEventListener("resize", function() { // this.mapChart.resize(); // }); }, initTwoBarEcharts(el, data) { this.twoBar = echarts.init(el); option = { tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: 'axis', textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' }, formatter: "{c}" }, grid: { top: '15%', right: '3%', left: '14%', bottom: 35 }, xAxis: [{ type: 'category', data: data.x, axisLine: { show: false, lineStyle: { color: 'rgba(255,255,255,0.12)' } }, axisLabel: { interval: 0, // rotate: 30, color: '#e2e9ff', textStyle: { fontSize: 30 }, }, }], yAxis: [{ name: '', axisLabel: { formatter: '{value}', color: '#fff', textStyle: { fontSize: 28, }, }, axisTick: { show: false }, axisLine: { show: false, lineStyle: { color: 'rgba(255,255,255,1)' } }, splitLine: { show: false, lineStyle: { color: 'rgba(255,255,255,0.12)' } } }], series: [{ type: 'bar', data: data.y, barWidth: '20px', itemStyle: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 1, color: "#02355C", }, //柱图渐变色 { offset: 0, color: "#45DAD1", }, ], false), shadowColor: 'rgba(0,160,221,1)', shadowBlur: 4, }, }] }; this.twoBar.setOption(option); tools.loopShowTooltip(this.twoBar, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function() { // this.twoBar.resize(); // }); }, initEchartsBar(el, data, color) { this.studentEcharts = echarts.init(el); if (Array.isArray(data.x)) { data.x.forEach(item => { item = item.slice(0, -2) }) } else { return } let xLabel = data.x option = { grid: { top: "15%", bottom: "10%", //也可设置left和right设置距离来控制图表的大小 left: "1%", right: "1%" }, tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: 'axis', textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' }, formatter: '{c0}', }, xAxis: { data: xLabel, axisLine: { show: true, //隐藏X轴轴线 lineStyle: { color: '#11417a' } }, axisTick: { show: false //隐藏X轴刻度 }, axisLabel: { show: true, interval: 0, margin: 14, textStyle: { fontSize: 26, color: "#fff" //X轴文字颜色 } }, }, yAxis: [{ type: "value", gridIndex: 0, // splitNumber: 4, splitLine: { show: false, lineStyle: { color: '#A3C0DF', width: 1 }, }, axisTick: { show: false }, axisLine: { show: false, lineStyle: { color: '#A3C0DF' } }, axisLabel: { show: true, margin: 14, fontSize: 20, textStyle: { color: "#fff" //X轴文字颜色 } }, },], series: [{ name: "实习实训", type: "bar", barWidth: 20, itemStyle: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: color }, { offset: 1, color: "#034881" } ]) }, data: data.y, z: 10, zlevel: 0, "label": { "show": true, "position": "top", "distance": 10, fontSize: 26, "color": color } }, { // 分隔 type: "pictorialBar", itemStyle: { color: "#0F375F" }, symbolRepeat: "fixed", symbolMargin: 6, symbol: "rect", symbolClip: true, symbolSize: [20, 2], symbolPosition: "start", symbolOffset: [0, -1], // symbolBoundingData: this.total, data: data.y, width: 25, z: 0, zlevel: 1, }, ] }; this.studentEcharts.setOption(option); tools.loopShowTooltip(this.studentEcharts, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function() { // this.studentEcharts.resize(); // }); }, initEchartStack(el, data) { let that = this; this.mobilizeFL = echarts.init(el); option = { tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: 'axis', textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' } }, grid: { top: "13%", bottom: 50, //也可设置left和right设置距离来控制图表的大小 left: "10%", right: "1%" }, legend: { data: ["入职", "内部调动", "跨二级调出", "跨二级调入", "离职",], align: 'left', itemGap: 50, right: '1%', y: '1%', icon: 'rect', textStyle: { color: "#fff", fontSize: 30 } }, xAxis: { axisTick: { show: false, }, axisLine: { show: false, }, axisLabel: { show: true, interval: 0, fontSize: 30, textStyle: { color: "#fff" //X轴文字颜色 }, // formatter: function (value) { // // 将文字进行换行 // if (value === "人力资源公司") { // value = "人力公司" // } // let list = value.split("") // if (list.length == 5) { // list[3] = "" // return list[0] + list[1] + list[2] // } // if (list.length > 4) { // list[4] = "" // return list[0] + list[1] + list[2] + list[3]; // } // return list[0] + list[1] + list[2] + list[3]; // } }, data: data.x, }, yAxis: { type: "value", gridIndex: 0, // splitNumber: 4, splitLine: { show: false, lineStyle: { color: '#A3C0DF', width: 1 }, }, axisTick: { show: false }, axisLine: { show: false, lineStyle: { color: '#A3C0DF' } }, axisLabel: { show: true, margin: 14, fontSize: 28, textStyle: { color: "#fff" //X轴文字颜色 } }, }, series: [{ type: 'bar', stack: 'total', name: "内部调动", barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#172A45', }, { offset: 1, color: '#FF9915', }, ]), }, data: data.y2, }, { type: 'bar', name: "入职", stack: 'total', barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#91231F', }, { offset: 1, color: '#F98784', }, ]), }, data: data.y1, }, { type: 'bar', name: "离职", stack: 'total', barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#69C0FF', }, { offset: 1, color: '#1a98f8', }, ]), }, data: data.y5, }, { type: 'bar', name: "跨二级调出", stack: 'total', barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#07806E', }, { offset: 1, color: '#79FFEB', }, ]), }, data: data.y3, }, { type: 'bar', stack: 'total', name: "跨二级调入", barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#9e65ea', }, { offset: 1, color: '#514ddd', }, ]), }, data: data.y4, }, ], }; this.mobilizeFL.on('click', function (params) { that.getTurnOverDetail(params.name) // 获取点击事件的参数信息 setTimeout(() => { that.isShowMark = true that.salaryFlag = false that.pdfFlag = false that.mobilizeFlag = true }, 10) // 在这里进行相应的处理逻辑 }); this.mobilizeFL.setOption(option); tools.loopShowTooltip(this.mobilizeFL, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function () { // this.mobilizeFL.resize(); // }); }, initDownholeEcharts(el, data, type) { this.downhole = echarts.init(el); let series = [] let grid = {} if (type == 1) { series.push({ type: 'bar', name: "一级专员", barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#FFFB7D', }, { offset: 1, color: '#85FFBD', }, ]), }, data: data.y[0], }) series.push({ type: 'bar', name: "二级专员", barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#8BC6EC', }, { offset: 1, color: '#9599E2', }, ]), }, data: data.y[1], }) series.push({ type: 'bar', name: "一级技工", barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#80D0C7 ', }, { offset: 1, color: '#0093E9', }, ]), }, data: data.y[2], }) series.push({ type: 'bar', name: "二级技工", barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#52ACFF', }, { offset: 1, color: '#FFE32C', }, ]), }, data: data.y[3], }) // series.push({ // type: 'bar', // name: "区队干", // barWidth: 26, // itemStyle: { // color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ // { // offset: 0, // color: '#69C0FF', // }, // { // offset: 1, // color: '#1a98f8', // }, // ]), // }, // data: data.y[2], // }) grid = { top: "13%", bottom: 50, //也可设置left和right设置距离来控制图表的大小 left: "10%", right: "1%" } } else if (type == 2) { series.push({ type: 'bar', name: "井下一线", barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#07806E', }, { offset: 1, color: '#79FFEB', }, ]), }, data: data.y[0], }) series.push({ type: 'bar', name: "井下辅助", barWidth: 26, itemStyle: { color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [{ offset: 0, color: '#9e65ea', }, { offset: 1, color: '#514ddd', }, ]), }, data: data.y[1], }) grid = { top: "13%", bottom: 50, //也可设置left和right设置距离来控制图表的大小 left: "15%", right: "1%" } } option = { tooltip: { show: true, backgroundColor: 'rgba(0, 0, 0, 0.5)', borderColor: "rgba(0,0,0,0.5)", trigger: 'axis', textStyle: { fontSize: 30, color: '#A3E2F4' }, axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' } }, grid, legend: { data: ["一级专员", "二级专员", "一级技工", "二级技工", "井下一线", "井下辅助",], align: 'left', itemGap: 50, right: '1%', y: '1%', icon: 'rect', textStyle: { color: "#fff", fontSize: 30 } }, xAxis: { axisTick: { show: false, }, axisLine: { show: false, }, axisLabel: { interval: 0, show: true, fontSize: 30, textStyle: { color: "#fff" //X轴文字颜色 }, }, data: data.x, }, yAxis: { type: "value", gridIndex: 0, // splitNumber: 4, splitLine: { show: false, lineStyle: { color: '#A3C0DF', width: 1 }, }, axisTick: { show: false }, axisLine: { show: false, lineStyle: { color: '#A3C0DF' } }, axisLabel: { show: true, margin: 14, fontSize: 28, textStyle: { color: "#fff" //X轴文字颜色 } }, }, series: series }; this.downhole.setOption(option); tools.loopShowTooltip(this.downhole, option, { nterval: 2000, loopSeries: true, }); // window.addEventListener("resize", function() { // this.downhole.resize(); // }); }, handleWarning() { this.isShowMark = false this.isShowMark = true this.salaryFlag = true this.pdfFlag = false this.mobilizeFlag = false this.echartsMark = false }, handleMark() { this.isShowMark = false this.salaryFlag = false this.pdfFlag = false this.selectFlag = false this.warningFlag = false this.mobilizeFlag = false this.echartsMark = false this.studioMark = false this.listFlag = false this.selectYearFlag = false this.listInterval && clearInterval(this.listInterval) this.honorIndex = 0 this.achievementIndex = 0 }, handleStudio(item, index) { // if (index != 0) { // return // } let that = this; setTimeout(() => { that.listFlag = true }, 4500) this.handleMark() this.studioTitle = item.name + "技能大师工作室" this.isShowMark = true this.studioMark = true if (this.isShowRequest) { studioInformation.data = this.newSkillList[index][0] leaderInformation.data = this.newSkillList[index][2] achievementList = this.newSkillList[index][1] honorList = this.newSkillList[index][3] } // if (this.newSkillList[index][0].length < 4) { // } }, handleChange() { this.isShowMark = true this.salaryFlag = false this.pdfFlag = false this.warningFlag = true this.mobilizeFlag = false this.echartsMark = false }, handleORG() { this.isShowMark = true this.salaryFlag = false this.pdfFlag = true this.mobilizeFlag = false this.echartsMark = false }, handleClick(item, index) { let that = this that.efficiency.dispose() this.timeTitle && clearInterval(this.timeTitle); let efficiency = this.$refs.efficiency if (item == "原煤工效") { this.titleIndex = 0 that.initBarChartsElse(efficiency, efficiencyList, "吨/工", { name: "行业线", value: 8.2 }) that.titleList = ["原煤工效", "全员效率"] } else { this.titleIndex = 1 that.initBarChartsElse(efficiency, wholeList, "吨/人", { name: "标杆矿井线", value: 1800 }) that.titleList = ["全员效率", "原煤工效"] } this.timeNt() }, handleTap1(index) { if (this.saIndex == index) { return } this.LineChart.dispose(); this.saTimeIndex = 0 clearInterval(this.SAtime); let serviceAge = this.$refs.serviceAge if (index == 1) { this.initLineEcharts(serviceAge, { x: this.ageListX[this.saTimeIndex], y: this.ageListY[this.saTimeIndex] }) } else if (index == 2) { this.initLineEcharts(serviceAge, { x: this.seniorityListX[this.saTimeIndex], y: this.seniorityListY[this.saTimeIndex] }) } this.saIndex = index this.SAtimeFun() }, handleTap2(index) { let that = this; if (this.twoIndex == index) { return } that.twoBar.dispose(); this.twoTimeIndex = 0 clearInterval(this.twoTime); let echartTwo = that.$refs.echartTwo if (index == 1) { that.initTwoBarEcharts(echartTwo, { x: that.nx1[that.twoTimeIndex], y: that.ny1[that.twoTimeIndex] }) } else if (index == 2) { that.initTwoBarEcharts(echartTwo, { x: that.nx2[that.twoTimeIndex], y: that.ny2[that.twoTimeIndex] }) } this.twoIndex = index this.timeTwo() }, handleChangeTitle(item, index) { let that = this if (item == that.titleList[0]) { return } this.studentEcharts.dispose() let student = this.$refs.student if (item == "高校分布") { that.titleList = ["高校分布", "单位分布"] this.initEchartsBar(student, schoolList, "#07ecd9") } else { that.titleList = ["单位分布", "高校分布"] this.initEchartsBar(student, rightList, "#21D4FD") } }, handleUserChange() { this.getTurnOverDetail() setTimeout(() => { this.isShowMark = true this.salaryFlag = false this.pdfFlag = false this.mobilizeFlag = true this.showChange = true }, 10) }, handleMore() { this.isShowMark = true this.salaryFlag = false this.pdfFlag = false this.mobilizeFlag = false this.echartsMark = true setTimeout(() => { this.getlaborproductivity() this.getMineEfficiency() this.getEmpProductivity() // this.initBarCharts(this.$refs.works, worksList) // this.initBarChartsElse(this.$refs.efficiencyElse, efficiencyList, "吨/工", { name: "行业线", value: 8.2 }) // this.initBarChartsElse(this.$refs.whole, wholeList, "吨/人", { name: "标杆矿井线", value: 1800 }) }) }, getAccumulatedLogin() { let that = this let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/AccumulatedLogin", data).then(res => { if(that.loginInfo.num != res.accumulatedLogin){ that.loginInfo.num = res.accumulatedLogin that.loginInfo.unit = res.unit that.userColor = true setTimeout(()=>{ that.userColor = !that.userColor },2000) } }) }, getMauInfo() { let that = this; let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/MAU", data).then(res => { if (res) { if(that.mauInfo.mau != res.mau){ that.mauInfo.mau = res.mau that.mauInfo.unit = res.unit that.monthColor = true setTimeout(()=>{ that.monthColor = !that.monthColor },2000) } } }) }, scrollChange(index) { let that = this if (that.achievementIndex == achievementList.length - 1) { that.achievementIndex = 0 } else { that.achievementIndex = that.achievementIndex + 1 } if (that.honorIndex == honorList.length - 1) { that.honorIndex = 0 } else { that.honorIndex = that.honorIndex + 1 } }, getDistributionInfo() { let that = this let data = { flag: that.dataFlag } let index = 0 that.setTypeFlag && clearInterval(that.setTypeFlag) this.orgIndex = 0 fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/Distribution", data).then(res => { if (res) { res.data.forEach(item => { item.flag = false item.name = item.key if (item.value == 0) { index = index + 1 } }) if (that.organizationList.length == 3) { that.organizationList.push(...res.data) } if (index < 3) { let arr = this.organizationList.splice(0, this.organizationList.length - 3) this.organizationList = [] this.organizationList.push(...arr, ...res.data) } if (this.organizationList.length != 0) { that.setTypeFlag = setInterval(_ => { if (this.fIndex == this.fList.length - 1) { this.fIndex = 0 } else { this.fIndex = this.fIndex + 1 } this.organizationList.forEach(item => { item.flag = false }) if (this.orgIndex == this.organizationList.length - 1) { this.orgIndex = 0 } else { this.orgIndex = this.orgIndex + 1 } this.organizationList[this.orgIndex].flag = true skillList.forEach(item => { item.flag = false }) if (this.skillIndex == skillList.length - 1) { this.skillIndex = 0 } else { this.skillIndex = this.skillIndex + 1 } skillList[this.skillIndex].flag = true }, 2000) } else { this.organizationList = [{ name: "职能部门", flag: true, value: 18 }, { name: "共享中心", flag: false, value: 12 }, { name: "事业部", flag: false, value: 5 }, { name: "二级单位", flag: false, value: 22 }, { name: "三级单位", flag: false, value: 316 }, { name: "四级单位", flag: false, value: 496 }] that.setTypeFlag = setInterval(_ => { if (this.fIndex == this.fList.length - 1) { this.fIndex = 0 } else { this.fIndex = this.fIndex + 1 } this.organizationList.forEach(item => { item.flag = false }) if (this.orgIndex == this.organizationList.length - 1) { this.orgIndex = 0 } else { this.orgIndex = this.orgIndex + 1 } this.organizationList[this.orgIndex].flag = true skillList.forEach(item => { item.flag = false }) if (this.skillIndex == skillList.length - 1) { this.skillIndex = 0 } else { this.skillIndex = this.skillIndex + 1 } skillList[this.skillIndex].flag = true }, 2000) } } }) }, getOrganizationChange() { let that = this let data = { flag: that.dataFlag } this.orgChange = false fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/OrganizationChange", data).then(res => { if (res) { that.configOrg.data = res.data that.orgChange = true } }) }, getIndustrydistribution(flag) { let that = this let data = { flag: that.dataFlag } if (!flag) { data.flag = false } let industry = that.$refs.industry fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/Industrydistribution", data).then(res => { if (res) { let x = [] let y = [] let index = 0 that.industry = JSON.parse(JSON.stringify({})) res.data.forEach(item => { x.push(item.key) y.push(item.value) }) y.forEach(i => { if (i == 0) { index = index + 1 } }) if (index == x.length) { if (that.IndustrydistributionIndex >= 3) { that.industry = { x: ["矿井", "选煤厂", "火电厂", "清洁电厂", "焦化厂"], y: [151, 50, 6, 32, 4] } that.initOrganizationElse(industry, "", that.industry, "") return } that.getIndustrydistribution(false) that.IndustrydistributionIndex += 1 return } that.industry.x = x that.industry.y = y } that.initOrganizationElse(industry, "", that.industry, "") // }) }, getHumanResources() { let that = this; let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/HumanResources", data).then(res => { if (res) { that.HumanResourcesList.forEach(i => { res.data.forEach(item => { if (i.key == item.key) { i.value = item.value } }) }) } }) }, getlaborproductivity() { let that = this; let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/laborproductivity", data).then(res => { let markLine = [] if (res.data) { res.data.forEach(item => { if (item.key == '组织名称') { worksList.x = item.value } if (item.key == "目标值") { worksList.y2 = item.value } if (item.key == "实际值") { worksList.y1 = item.value } if (item.key == "社会平均") { markLine[0] = item.value } if (item.key == "省企平均") { markLine[1] = item.value } if (item.key == "央企平均") { markLine[2] = item.value } }) that.initBarCharts(that.$refs.works, worksList, markLine) } }).catch(err => { that.initBarCharts(that.$refs.works, worksList) }) }, getMineEfficiency() { let that = this; let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/MineEfficiency", data).then(res => { let obj = {} if (res != null) { res.data.forEach(item => { if (item.key == "行业线") { obj = { name: item.key, value: item.value } } if (item.key == "组织名称") { efficiencyList.x = item.value } if (item.key == "目标值") { efficiencyList.y2 = item.value } if (item.key == "实际值") { efficiencyList.y1 = item.value } }) that.initBarChartsElse(that.$refs.efficiencyElse, efficiencyList, "吨/工", obj) } else { that.initBarChartsElse(that.$refs.efficiencyElse, efficiencyList, "吨/工", { name: "行业线", value: 8.2 }) } }).catch(err => { that.initBarChartsElse(that.$refs.efficiencyElse, efficiencyList, "吨/工", { name: "行业线", value: 8.2 }) }) }, getEmpProductivity() { let that = this; let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/EmpProductivity", data).then(res => { let obj = {} if (res != null) { res.data.forEach(item => { if (item.key == "标杆矿井线") { obj = { name: item.key, value: item.value } } if (item.key == "组织名称") { wholeList.x = item.value } if (item.key == "目标值") { wholeList.y2 = item.value } if (item.key == "实际值") { wholeList.y1 = item.value } }) that.initBarChartsElse(that.$refs.whole, wholeList, "吨/人", obj) } else { that.initBarChartsElse(that.$refs.whole, wholeList, "吨/人", { name: "标杆矿井线", value: 1800 }) } }).catch(err => { that.initBarChartsElse(that.$refs.whole, wholeList, "吨/人", { name: "标杆矿井线", value: 1800 }) }) }, getSalaryCalProg() { let that = this; let data = { flag: that.dataFlag } this.SalaryCalProgDetail = false fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/SalaryCalProg", data).then(res => { if (res) { that.config2.data = res.data } this.SalaryCalProgDetail = true }) }, getSalaryCalProgDetail() { let that = this; let data = { flag: that.dataFlag } // this.isShowMark = false // this.salaryFlag = false fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/SalaryCalProgDetail", data).then(res => { if (res) { that.configWarning.data = res.data } }) // this.isShowMark = true // this.salaryFlag = true // this.pdfFlag = false // this.mobilizeFlag = false // this.echartsMark = false }, getCollegeinternAndEnterpriseship() { let that = this; let data = { flag: that.dataFlag } let student = this.$refs.student fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/CollegeinternAndEnterpriseship", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "高校总数") { that.schoolList1[0].value = item.value } if (item.key == "实训总人数") { that.schoolList1[1].value = item.value } if (item.key == "高校名称") { schoolList.x = item.value } if (item.key == "高校实训人数") { schoolList.y = item.value } if (item.key == "企业名称") { rightList.x = item.value } if (item.key == "企业实训人数") { rightList.y = item.value } }) } this.initEchartsBar(student, schoolList, "#07ecd9") }) }, getCollegestudy() { let that = this; let data = { flag: that.dataFlag } let proList = []; let schList = []; let typeList = []; let userList = []; fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/Collegestudy", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "产学研合作高校数量") { that.schoolList2[0].value = item.value } if (item.key == "产学研成果数量") { that.schoolList2[1].value = item.value } if (item.key == "项目名称") { proList = item.value } if (item.key == "合作高校") { schList = item.value } if (item.key == "合作类型") { typeList = item.value } if (item.key == "主要成效") { userList = item.value } that.fList = [] proList.forEach((i, k) => { let obj = { project: i, school: schList[k], type: typeList[k], merits: userList[k], } that.fList.push(obj) }) }) } }) }, getTurnOver() { let that = this; let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/TurnOver", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "组织名称") { mobilizeList.x = item.value } if (item.key == "内部调动") { mobilizeList.y2 = item.value } if (item.key == "入职") { mobilizeList.y1 = item.value } if (item.key == "离职") { mobilizeList.y5 = item.value } if (item.key == "跨二级调入") { mobilizeList.y4 = item.value } if (item.key == "跨二级调出") { mobilizeList.y3 = item.value } }) } that.fx = spArr(mobilizeList.x, 6) that.fy1 = spArr(mobilizeList.y1, 6) that.fy2 = spArr(mobilizeList.y2, 6) that.fy3 = spArr(mobilizeList.y3, 6) that.fy4 = spArr(mobilizeList.y4, 6) that.fy5 = spArr(mobilizeList.y5, 6) let mobilize = that.$refs.mobilize that.initEchartStack(mobilize, { x: that.fx[0], y1: that.fy1[0], y2: that.fy2[0], y3: that.fy3[0], y4: that.fy4[0], y5: that.fy5[0] }) that.timeSy() }) }, handleChangeImage() { this.imageIndex += 1 }, fullScreen() { let docElm = document.documentElement; if (docElm.requestFullscreen) { docElm.requestFullscreen(); } else if (docElm.msRequestFullscreen) { docElm.msRequestFullscreen(); } else if (docElm.mozRequestFullScreen) { docElm.mozRequestFullScreen(); } else if (docElm.webkitRequestFullScreen) { docElm.webkitRequestFullScreen(); } this.imageFlag = true this.pageFlag = false }, getOptimizeResources() { let that = this; let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/OptimizeResources", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "双选人数") { that.optimize[0].value = item.value } if (item.key == "优化人数") { that.optimize[1].value = item.value } if (item.key == "优化率") { // console.log((item.value * 100)); that.optimizeValue = item.value; } }) } }) }, getHumanOrgAllResources() { let that = this; let data = { flag: that.dataFlag } let buffer = that.$refs.buffer fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/HumanOrgAllResources", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "各二级单位单位名称") { userList.x = item.value } if (item.key == "各二级单位缓冲池人数") { userList.y1 = item.value } if (item.key == "各二级单位待岗池人数") { userList.y2 = item.value } if (item.key == "各二级单位共享池人数") { userList.y3 = item.value } }) if (!userList.x) { return } that.userListX = spArr(userList.x, 9) that.userListy1 = spArr(userList.y1, 9) that.userListy2 = spArr(userList.y2, 9) that.userListy3 = spArr(userList.y3, 9) that.initStereoscopic(buffer, { x: that.userListX[0], y1: that.userListy1[0], y2: that.userListy2[0], y3: that.userListy3[0], }) that.timeuserList() } }) }, getMapData() { let that = this; let data = { flag: that.dataFlag } var geoCoordMap = { 太原市: [112.049248, 38.157014], 大同市: [113.595259, 40.29031], 阳泉市: [113.505474, 37.964652], 长治市: [112.813556, 36.791112], 晋城市: [112.551274, 35.577553], 朔州市: [112.433387, 39.531261], 晋中市: [112.936465, 37.696495], 运城市: [111.003957, 34.99], 忻州市: [112.333538, 38.7769], 临汾市: [111.517973, 36.48415], 吕梁市: [111.134335, 37.524366], } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/MapData", data).then(res => { if (res) { let mapData = [] res.data.forEach(item => { let point = [] for (let k in geoCoordMap) { if (k.indexOf(item.value) != -1) { point = geoCoordMap[k] } } item.data.forEach(i => { let num; let name; i.forEach(j => { if (j.key == "二级单位") { name = j.value } if (j.key == "员工总数") { num = j.value } }) let obj = { itemStyle: { color: "#fff" }, name: item.value, value: [...point, num, name] } mapData.push(obj) }) }) let el = this.$refs.container // this.initProvinceChart(el) this.initMap2(el, mapData) // let map = [] // res.data.forEach(item => { // let obj = {} // item.forEach(i => { // if (i.key == "区域") { // obj.name = i.value // } // if (i.key == "员工总数") { // obj.value = i.value // } // if (i.key == "二级单位") { // obj.level = i.value // } // }) // map.push(obj) // }) // map.forEach(i => { // let obj = { // name: "", // value: [] // } // for (let k in geoCoordMap) { // if (k.indexOf(i.name) != -1) { // obj.name = k // obj.value[0] = geoCoordMap[k][0] // obj.value[1] = geoCoordMap[k][1] // obj.value[2] = i.value // obj.value[3] = i.level // } // } // mapData.push(obj) // }) // let el = this.$refs.container // // this.initProvinceChart(el) // this.initMap2(el, mapData) } }) }, getPersonnelResource() { let that = this; let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/PersonnelResource", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "用工总数") { that.PersonnelResource[0].value = item.value } if (item.key == "男性员工") { that.PersonnelResource[1].value = item.value } if (item.key == "女性员工") { that.PersonnelResource[2].value = item.value } }) } }) }, getEduStructure() { let that = this; let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/EduStructure", data).then(res => { if (res) { let arr = [] res.data.forEach(item => { let obj = { name: item.key, y: item.value, sliced: false, selected: false } arr.push(obj) }) this.initChartsBig(arr) } else { this.initChartsBig() } }) }, getSkillLevel() { let that = this; let data = { flag: that.dataFlag } let level = this.$refs.level fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/SkillLevel", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "技能名称") { levelList.x = item.value } if (item.key == "数量") { levelList.y = item.value } }) let sum = 0 levelList.y.forEach(item => { sum = sum + item }) that.levelListX = spArr(levelList.x, 4) that.levelListY = spArr(levelList.y, 4) if (levelList.x.length > 5) { that.initLineElseEcharts(level, { x: that.levelListX[0], y: that.levelListY[0] }, sum) that.timeLevel() } else { that.initLineElseEcharts(level, { x: that.levelListX[0], y: that.levelListY[0] }, sum) } } else { let sum = 0 levelList.y.forEach(item => { sum = sum + item }) that.levelListX = spArr(levelList.x, 4) that.levelListY = spArr(levelList.y, 4) that.initLineElseEcharts(level, { x: that.levelListX[0], y: that.levelListY[0] }, sum) } }) }, getRankLevel() { let that = this; let data = { flag: that.dataFlag } let initChartR1 = this.$refs.initChartR1 fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/RankLevel", data).then(res => { if (res) { let nameList = [] let valueList = [] let rankLevelList = [] res.data.forEach(item => { if (item.key == "技能名称") { nameList = item.value } if (item.key == "数量") { valueList = item.value } }) nameList.forEach((item, index) => { let obj = { name: item, value: valueList[index] } rankLevelList.push(obj) }) if (this.technical != null) { this.technical.dispose() } this.initChartR1(initChartR1, rankLevelList) } }) }, getFrontLine() { let that = this; let data = { flag: that.dataFlag } let efficiency = this.$refs.efficiency fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/FrontLine", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "组织") { downhole.x = item.value } if (item.key == "井下一线") { downhole.y[4] = item.value } if (item.key == "井下辅助") { downhole.y[5] = item.value } }) // this.initDownholeEcharts(efficiency, { x: downhole.x, y: [downhole.y[4], downhole.y[5]] }, 1) } else { // this.initDownholeEcharts(efficiency, { x: downhole.x, y: [downhole.y[4], downhole.y[5]] }, 1) } }) }, getGrassRoots() { let that = this; let data = { flag: that.dataFlag } let efficiency = this.$refs.efficiency fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/SelectTraining", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "组织名称") { downhole.x = item.value } if (item.key == "一级专员") { downhole.y[0] = item.value } if (item.key == "二级专员") { downhole.y[1] = item.value } if (item.key == "一级技工") { downhole.y[2] = item.value } if (item.key == "二级技工") { downhole.y[3] = item.value } if (item.key == "选拔培训") { that.downholeObj = { key: "选拔培养", value: item.value } that.selectTraining = item.value } }) } this.initDownholeEcharts(efficiency, { x: downhole.x, y: [downhole.y[0], downhole.y[1], downhole.y[2], downhole.y[3]] }, 1) this.getFrontLine() }) this.downholeTimes() }, getEmploysNums() { let that = this; let data = { flag: that.dataFlag }; fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/EmploysNums", data).then(res => { if (res) { that.downholeObj = res that.employsNums = res.value } }) }, getPositionSequence() { let that = this; let data = { flag: that.dataFlag }; let sequence = this.$refs.sequence fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/PositionSequence", data).then(res => { if (res) { let nameList = ["管理序列", "技术序列", "操作序列"]; let valueList = []; let ratioList = []; res.data.forEach(item => { if (item.key == "管理序列人数") { valueList[0] = item.value } if (item.key == "操作序列人数") { valueList[1] = item.value } if (item.key == "技术序列人数") { valueList[2] = item.value } if (item.key == "管理序列比例") { ratioList[0] = item.value } if (item.key == "操作序列比例") { ratioList[1] = item.value } if (item.key == "技术序列比例") { ratioList[2] = item.value } }) let obj = { x: nameList, y1: valueList, y2: ratioList, } this.initBarEcharts(sequence, obj, ["当前数"]) } else { this.initBarEcharts(sequence, { x: ["管理序列", "技术序列", "操作序列"], y1: [34242, 18547, 134012], y2: [28993, 19411, 126807] }, ["当前数"]) } }) }, getDownholeoperationTrue() { let that = this; let data = { flagd: true, flag: that.dataFlag } let echartTwo = this.$refs.echartTwo fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/Downholeoperation", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "原煤人员数量") { that.staffList.coal = item.value } if (item.key == "非原煤人员数量") { that.staffList.noCoal = item.value } if (item.key == "岗位名称") { that.echartTwoList.x = item.value } if (item.key == "人数") { that.echartTwoList.y = item.value } }) that.nx1 = spArr(that.echartTwoList.x, 5) that.ny1 = spArr(that.echartTwoList.y, 5) that.initTwoBarEcharts(echartTwo, { x: that.nx1[0], y: that.ny1[0] }) that.twoTimeIndex = 0 that.timeTwo() } }) }, getDownholeoperationFlase() { let that = this; let data = { flagd: false, flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/Downholeoperation", data).then(res => { if (res) { res.data.forEach(item => { if (item.key == "岗位名称") { that.echartTwoList2.x = item.value } if (item.key == "人数") { that.echartTwoList2.y = item.value } }) } that.nx2 = spArr(that.echartTwoList2.x, 5) that.ny2 = spArr(that.echartTwoList2.y, 5) }) }, getStaffAge() { let that = this; let data = { flag: that.dataFlag }; fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/StaffAge", data).then(res => { if (res) { let dataObj = { x: [], y: [] } res.data.forEach(item => { if(item.key == "平均年龄"){ that.staffAge = item.value } else { dataObj.x.push(item.key) dataObj.y.push(item.value) } }) that.echartsTwoBar1 = JSON.parse(JSON.stringify(dataObj)) } that.ageListX = spArr(that.echartsTwoBar1.x, 4) that.ageListY = spArr(that.echartsTwoBar1.y, 4) let serviceAge = that.$refs.serviceAge that.initLineEcharts(serviceAge, { x: that.ageListX[that.saTimeIndex], y: that.ageListY[that.saTimeIndex] }) that.SAtimeFun() that.getStaffSeniority() }) }, getStaffSeniority() { let that = this; let data = { flag: that.dataFlag }; fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/StaffSeniority", data).then(res => { if (res) { let obj = { x: [], y: [] } res.data.forEach(item => { if(item.key == "平均工龄"){ that.staffSeniority = item.value } else { obj.x.push(item.key) obj.y.push(item.value) } }) that.echartsTwoBar2 = JSON.parse(JSON.stringify(obj)) that.seniorityListX = spArr(that.echartsTwoBar2.x, 4) that.seniorityListY = spArr(that.echartsTwoBar2.y, 4) } }) }, getCalSalary(type=1) { let that = this; let data; if(type == 1){ data = { flag: that.dataFlag, year: 0, month: parseInt(that.selectInfo.average) } } else { data = { flag: that.dataFlag, year: parseInt(that.selectYearInfo.average), month: parseInt(that.selectInfo.average) } } let leftEnd = that.$refs.leftEnd let x = [] let y1 = [] let y2 = [] fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/getCalSalary", data).then(res => { if (res) { // leftEndList = res.data if (res.lastyear.x.length != 0) { x = res.lastyear.x } else { x = res.thisyear.x } y1 = res.thisyear.y y2 = res.lastyear.y leftEndList = { x, y1, y2, } if (!res.mdnb_encryption) { that.initBarEchartsElse(leftEnd, leftEndList, ["累计月平均工资", "同期累计月平均工资"]) } else { that.initBarEchartsElseJM(leftEnd, leftEndList, ["累计月平均工资", "同期累计月平均工资"]) } } }) }, getCalSalary1(type = 1) { let that = this; let data if(type == 1){ data = { flag: that.dataFlag, year: 0, month: parseInt(that.selectInfo.total) } } else { data = { flag: that.dataFlag, year: parseInt(that.selectYearInfo.total), month: parseInt(that.selectInfo.total) } } let echarts90 = that.$refs.echarts90 fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/getCalSalary1", data).then(res => { if (res) { salaryList = res that.gtTotle = res.total if (salaryList.x.length < 6) { that.initLineElseEchartsR(echarts90, { x: salaryList.x, y: salaryList.y }) that.time4 && clearInterval(that.time4); } else { that.sx = spArr(salaryList.x, 6) that.sy = spArr(salaryList.y, 6) that.initLineElseEchartsR(echarts90, { x: that.sx[0], y: that.sy[0] }) that.time4 && clearInterval(that.time4); that.timeSy() } } }) }, getCalSalary2() { let that = this; let data = { flag: that.dataFlag } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/getCalSalary2", data).then(res => { if (res) { that.configMark.data = res } }) }, addArray(arr) { let newArr = [...arr] if (newArr.length <= 5) { newArr.push(...arr) this.addArray(newArr) } else { return newArr } }, addArray(arr, newArr = []) { newArr = newArr.concat(arr); // 将原数组添加到新数组中 if (newArr.length <= 4) { return this.addArray(arr, newArr); // 递归调用方法 } else { return newArr; } }, getCmasterstudio(level) { let that = this; let data = { flag: that.dataFlag, level } fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/Cmasterstudio", data).then(res => { if (res) { let skillObj = [] let list1 = [] let list2 = [] let list3 = [] let list4 = [] res.data.forEach(item => { if (item.key == "工作室总数") { skillList[level - 1].blue = item.value } if (item.key == "工作室成员人数") { skillList[level - 1].green = item.value } if (item.key == "工作室名称") { skillObj[0] = that.addArray(item.value) } if (item.key == "工作室所在单位") { skillObj[1] = that.addArray(item.value) } if (item.key == "颁发单位及时间") { skillObj[2] = that.addArray(item.value) } if (item.key == "成员人数") { skillObj[3] = that.addArray(item.value) } if (item.key == "平均年龄") { skillObj[4] = that.addArray(item.value) } if (item.key == "主要成果") { skillObj[5] = that.addArray(item.value) } if (item.key == "出生年月") { skillObj[6] = that.addArray(item.value) } if (item.key == "从事事业") { skillObj[7] = that.addArray(item.value) } if (item.key == "职业技能等级") { skillObj[8] = that.addArray(item.value) } if (item.key == "担任职务") { skillObj[9] = that.addArray(item.value) } if (item.key == "曾获荣誉") { skillObj[10] = that.addArray(item.value) } }) skillObj.forEach((item, index) => { if (index == 0) { item.forEach((i, z) => { list1.push([i, skillObj[1][z], skillObj[2][z], skillObj[3][z], skillObj[4][z]]) list3.push([skillObj[6][z], skillObj[7][z], skillObj[8][z], skillObj[9][z]]) }) } if (index == 5) { list2 = item } if (index == skillObj.length - 1) { list4 = item } }) that.newSkillList[level - 1] = [list1, list2, list3, list4] } }) }, getTurnOverDetail(orgName = null) { let that = this; let data = { flag: that.dataFlag, orgName, } that.showChange = false fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/TurnOverDetail", data).then(res => { // console.log(res); if (res) { let list = [] let nameList = [] let outList = [] let inList = [] let timeList = [] let flagList = [] // header: ["姓名", "调出单位", "调入单位", "调动时间", '变动状态',], res.data.forEach((item) => { if (item.key == "姓名") { item.value.forEach((i) => { nameList.push(i) }) } if (item.key == "调出单位") { item.value.forEach((i) => { outList.push(i) }) } if (item.key == "调入单位") { item.value.forEach((i) => { inList.push(i) }) } if (item.key == "调动时间") { item.value.forEach((i) => { timeList.push(i) }) } if (item.key == "变动状态") { item.value.forEach((i) => { flagList.push(i) }) } }) nameList.forEach((item, index) => { list.push([item, outList[index], inList[index], timeList[index], flagList[index],]) }) that.configChange.data = list setTimeout(() => { that.showChange = true }, 10) } }) }, getDept(flag) { let that = this; let data = { flag: that.dataFlag } if (!flag) { data.flag = false } let index = 0 that.organizationList = [] fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/Dept", data).then(res => { if (res) { res.data.forEach(item => { item.flag = false item.name = item.key if (item.value == 0) { index = index + 1 } }) if (that.fetchIndex == 3) { this.organizationList = [{ name: "职能部门", flag: true, value: 18 }, { name: "共享中心", flag: false, value: 12 }, { name: "事业部", flag: false, value: 5 }] that.getDistributionInfo() that.fetchIndex = 0 return } if (index == 3) { that.fetchIndex += 1 that.getDept(false) return } res.data[0].flag = true that.organizationList.push(...res.data) that.getDistributionInfo() } }) }, getDistributionAttachment() { let that = this; let data = { flag: that.dataFlag }; fetchPostMethods("/ierp/kapi/v2/mdnb/mdnb_control/DistributionAttachment", data).then(res => { if (res && res.url) { that.imageUrl = res.url } }) }, }, })