let barImg =
  ''
let app = new Vue({
  el: '#app',
  data () {
    return {
      imgPop:'',
      // paymentShow:false, // 定薪酬弹窗
      echartC1: {
        national: 100,
        province: 200
      },
      echartC2: {
        national: 100,
        province: 200
      },
      app_token: '',
      twinkle7: [],
      twinkle8: [],
      twinkleR6: [],
      showTip: false,
      showTip2: false,
      showTip3: false,
      showTip4: false,
      titleShow: false,
      tipNum: '',
      tipData: tipData,
      titleData: titleData,
      time: '',
      year: '2022',
      config1: {
        number: [100],
        content: '{nt}个',
      },
      centerData: '',
      storageRecordConfig: {
        header: ['', '公司名称', '工作情况'],
        headerBGC: '#05507b33',
        oddRowBGC: '#69c0ff0f',
        // waitTime: '50000',
        evenRowBGC: '',
        headerHeight: '60',
        columnWidth: [150, 150],
        rowNum: 4,
        align: ['right', 'center', 'center', 'center'],
        data: [],
      },
      storageRecordConfig2: {
        header: ['', '预警内容', '未获取数据天数'],
        headerBGC: '#05507b33',
        oddRowBGC: '#05507b33',
        evenRowBGC: '',
        headerHeight: '60',
        columnWidth: [150, 800, 200],
        rowNum: 4,
        align: ['center', 'center', 'center', 'center', 'center'],
        data: []
      },
      companyList: companyList,
      commonOption: {
        title: {
          text: 'xxx',
          x: 'center',
          y: '3%',
          textStyle: {
            color: '#69C0FF',
            fontSize: 24,
          },
        },
        tooltip: {
          trigger: 'axis',
          textStyle: { fontSize: 18 },
          axisPointer: {
            type: 'cross',
            label: {
              fontSize: 18,
            },
          },
        },
        grid: {
          top: '22%',
          right: '5%',
          left: '8%',
          bottom: '20%',
        },
        legend: {
          data: '',
          top: '12%',
          right: '5%',
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
            fontSize: 16,
          },
        },
        xAxis: {
          data: companyList.map(item => item.name),
          axisLine: {
            show: false, //隐藏X轴轴线
            lineStyle: {
              color: '#005094',
              width: 1,
            },
          },
          axisTick: {
            show: false, //隐藏X轴刻度
          },
          axisLabel: {
            show: true,
            rotate: 50,
            textStyle: {
              color: 'rgba(255,255,255,0.6)', //X轴文字颜色
              fontSize: 16,
            },
          },
        },
        yAxis: [
          {
            type: 'value',
            nameTextStyle: {
              color: '#ebf8ac',
              fontSize: 16,
            },
            splitLine: {
              show: true,
              lineStyle: {
                color: '#68b4dd66',
                type: 'dashed',
              },
            },
            axisLine: {
              show: false,
            },
            axisLabel: {
              show: true,
              textStyle: {
                color: 'rgba(250,250,250,0.6)',
                fontSize: 16,
              },
            },
          },
        ],
      },
    }
  },
  beforeMount () {
  },
  mounted () {
    if (!sessionStorage.getItem('accounts', this.accounts)) {
      window.location.href = './login/login.html'
      return
    }
    this.getAppToken()
    this.time = formatDate()
    this.timer = setInterval(() => {
      this.time = formatDate()
    }, 1000)
    this.centerData = data
    // this.generateEcharts()
  },
  beforeDestroy () {
    if (this.timer) {
      clearInterval(this.timer)
    }
  },
  methods: {
    // 获取token
    getAppToken () {
      let value = {
        // dev环境
        // "appId": "cockpitScreen",
        // "appSecuret": "JSCdpsjgl@123456",
        // "tenantid": "gydev",
        // "accountId": "1614416231203341312",
        // "language": "zh_CN"

        // SIT环境
        // "appId": "CockpitScreen",
        // "appSecuret": "JSCdpsjgl@539126",
        // "tenantid": "test",
        // "accountId": "1484008912330950656",
        // "language": "zh_CN"

        // UAT环境
        // "appId": "CockpitScreen",
        // "appSecuret": "JSCdpsjgl@539126",
        // "tenantid": "uatierp",
        // "accountId": "1490670568960163840",
        // "language": "zh_CN"

        // 生产环境
        "appId": "CockpitScreen",
        "appSecuret": "JSCdpsjgl@539126",
        "tenantid": "ierp",
        "accountId": "1504594026697850880",
        "language": "zh_CN"
      }
      post('/ierp/api/getAppToken.do', value).then(res => {
        this.app_token = res.data.app_token
        this.getAccessToken()
      })
    },
    // 获取AccessToken
    getAccessToken () {
      let value = {
        // dev环境
        // "user": "jiashicangjiekou",
        // "apptoken": this.app_token,
        // "tenantid": "gydev",
        // "accountId": "1614416231203341312",
        // "usertype": "UserName"

        // SIT环境
        // "user": "jiashicangjiekou",
        // "apptoken": this.app_token,
        // "tenantid": "test",
        // "accountId": "1484008912330950656",
        // "usertype": "UserName"

        // UAT环境
        // "user": "jiashicangjiekou",
        // "apptoken": this.app_token,
        // "tenantid": "uatierp",
        // "accountId": "1490670568960163840",
        // "usertype": "UserName"

        // 生产环境
        "user": "jiashicangjiekou",
        "apptoken": this.app_token,
        "tenantid": "ierp",
        "accountId": "1504594026697850880",
        "usertype": "UserName"
      }
      post('/ierp/api/login.do', value).then(res => {
        this.access_token = res.data.access_token
        // Promise.all([this.getData(), this.getInstitutional()])
        //   .then((arr) => {
        //     // 生成图表       
        //     this.generateEcharts()
        //   })
        //   .catch((err) => console.log(err));
        this.getInstitutional()
      })
    },
    // 获取组织机构
    getInstitutional () {
      return new Promise((resolve, err) => {
        let value = {
          access_token: this.access_token,
          "Data": {
            "paramType": "ORG",
            "orgNumber": "100000"
          }
        }
        post('/ierp/kapi/v2/mdnb/mdnb_das/Data/CockpitScreen', value).then(res => {
          this.companyList = res.data.map(item => {
            return { name: item.orgName, id: item.orgNumber, orgLogoNum: item.orgLogoNum }
          })
          this.commonOption.xAxis.data = this.companyList.map(item => item.name)
          this.getData()
          resolve(1);
        })
      });
    },
    generateEcharts () {
      this.initChartL1()
      this.initChartL2()
      this.initChartL3()
      this.initChartL4()
      this.initChartL5()
      this.initChartL6()
      this.initChartL7()
      this.initChartL8()
      // 中间图表
      this.initChartC1()
      this.initChartC2()
      // 右侧图表
      this.initChartR1()
      this.initChartR2()
      this.initChartR3()
      this.initChartR4()
      this.initChartR5()
      this.initChartR6()
      this.initChartR7()
      this.initChartR8()
    },
    getData () {
      return new Promise((resolve, err) => {
        let value = {
          access_token: this.access_token,
          "Data": {
            "paramType": "DATA",
            "orgNumber": "100000"
          }
        }
        post('/ierp/kapi/v2/mdnb/mdnb_das/Data/CockpitScreen', value).then(res => {
          res.orgData = res.data[0]
          // 定机构
          // 弹窗
          // return
          // 左侧图表
          // tipData.focus[0] = res.orgData.area1.keyPoint
          tipData.analysis[0] = res.orgData.area1.intAnalysis.map(item => item.analysis)
          //各省属企业总部机构数
          dataL1[1] = []
          dataL1[0] = []
          dataL1[2] = []
          res.orgData.area1.card1.forEach(item => {
            dataL1[1].push(item['ZBPZ0032'])
            dataL1[0].push(item['ZBPZ0042'])
            dataL1[2].push(item['ZBPZ0043'])
          })
          // 各省属企业共享服务中心/事业部数
          dataL2[0] = []
          dataL2[1] = []
          dataL2[2] = []
          res.orgData.area1.card2.forEach(item => {
            dataL2[1].push(item['ZBPZ0045'])
            dataL2[0].push(item['ZBPZ0024'])
            dataL2[2].push(item['ZBPZ0044'])
          })

          // 定职数
          // 弹窗
          // tipData.focus[1] = res.orgData.area2.keyPoint
          tipData.analysis[1] = res.orgData.area2.intAnalysis.map(item => item.analysis)
          // 各省属企业管理人员数
          dataL3[0] = []
          dataL3[1] = []
          res.orgData.area2.card1.forEach(item => {
            dataL3[0].push(item['ZBPZ0031'])
            dataL3[1].push(item['ZBPZ0049'])
          })
          // 各省属企业总部中层管理人数
          dataL4[1] = []
          dataL4[0] = []
          dataL4[2] = []
          res.orgData.area2.card2.forEach(item => {
            dataL4[1].push(item['ZBPZ0046'])
            dataL4[0].push(item['ZBPZ0047'])
            dataL4[2].push(item['ZBPZ0048'])
          })

          // 定员额
          // 弹窗
          // tipData.focus[2] = res.orgData.area3.keyPoint
          tipData.analysis[2] = res.orgData.area3.intAnalysis.map(item => item.analysis)
          // 各省属企业总人数
          dataL5[0] = []
          dataL5[1] = []
          res.orgData.area3.card1.forEach(item => {
            dataL5[0].push(item['ZBPZ0006'])
            dataL5[1].push(item['ZBPZ0050'])
          })
          // 各省属企业总部员额数
          dataL6[0] = []
          dataL6[1] = []
          dataL6[2] = []
          res.orgData.area3.card2.forEach(item => {
            dataL6[0].push(item['ZBPZ0033'])
            dataL6[1].push(item['ZBPZ0053'])
            dataL6[2].push(item['ZBPZ0052'])
          })
          // 人数变化和全员劳动生产率变化分析
          dataL7[0] = []
          dataL7[1] = []
          res.orgData.area3.card3.forEach(item => {
            dataL7[0].push(item['ZBPZ0050'])
            dataL7[1].push(item['ZBPZ0039'])
          })
          // 人数变化和人工成本利润率变化分析
          dataL8[0] = []
          dataL8[1] = []
          res.orgData.area3.card4.forEach(item => {
            dataL8[0].push(item['ZBPZ0050'])
            dataL8[1].push(item['ZBPZ0041'])
          })

          // 中间
          // 架岗人
          this.centerData.info.value1 = res.orgData.area7.ZBPZ0037
          this.centerData.info.value2 = res.orgData.area7.ZBPZ0038
          this.centerData.info.value3 = res.orgData.area7.ZBPZ0006
          // 六定改革成效
          this.centerData.changeInfo[0].value1 = res.orgData.area8.ZBPZ0067
          this.centerData.changeInfo[0].value2 = res.orgData.area8.ZBPZ0068
          this.centerData.changeInfo[0].value3 = res.orgData.area8.ZBPZ0069
          this.centerData.changeInfo[2].value1 = res.orgData.area8.ZBPZ0074
          this.centerData.changeInfo[2].value2 = res.orgData.area8.ZBPZ0075
          this.centerData.changeInfo[2].value3 = res.orgData.area8.ZBPZ0076
          this.centerData.changeInfo[1].value1 = res.orgData.area8.ZBPZ0071
          this.centerData.changeInfo[1].value2 = res.orgData.area8.ZBPZ0072
          this.centerData.changeInfo[1].value3 = res.orgData.area8.ZBPZ0073

          // 核心指标监测
          // 弹窗
          // tipData.focus[3] = res.orgData.area9.keyPoint
          tipData.analysis[3] = res.orgData.area9.intAnalysis.map(item => item.analysis)
          // 劳动生产各省属企业全员率
          c1[0] = []
          c1[1] = []
          res.orgData.area9.card1.forEach(item => {
            c1[0].push(item['ZBPZ0035'])
            c1[1].push(item['ZBPZ0039'])
          })
          // 各省属企业人工成本利润率
          c2[1] = []
          c2[0] = []
          res.orgData.area9.card2.forEach(item => {
            c2[1].push(item['ZBPZ0040'])
            c2[0].push(item['ZBPZ0041'])
          })
          this.echartC1.national = res.orgData.area9.card1[0].ZBPZ0097
          this.echartC1.province = res.orgData.area9.card1[0].ZBPZ0096
          this.echartC2.national = res.orgData.area9.card2[0].ZBPZ0099
          this.echartC2.province = res.orgData.area9.card2[0].ZBPZ0098
          // 分析预警中心
          // 工作台分析
          this.storageRecordConfig.data = []
          res.orgData.area10.card1.forEach(item => {
            this.storageRecordConfig.data.push(['<span class="lightOut"><span class="light ' + (item.lightsup === '0' ? 'red' : item.lightsup === '1' ? 'yellow' : 'green') + '"></span></span>', item.enterprise, item.work])
          })
          this.storageRecordConfig = { ...this.storageRecordConfig }
          // 数据库预警
          this.storageRecordConfig2.data = []
          res.orgData.area10.card2.forEach(item => {
            this.storageRecordConfig2.data.push(['<span class="lightOut"><span class="light ' + (item.lightsup === '0' ? 'red' : item.lightsup === '1' ? 'yellow' : 'green') + '"></span></span>', item.warning, item.date])
          })
          this.storageRecordConfig2 = { ...this.storageRecordConfig2 }

          // 左边
          // 定机制
          // 弹窗
          // tipData.focus[4] = res.orgData.area4.keyPoint
          tipData.analysis[4] = res.orgData.area4.intAnalysis.map(item => item.analysis)
          // 各省属企业招聘需求公示人次
          dataR1[0] = []
          dataR1[1] = []
          res.orgData.area4.card1.forEach(item => {
            dataR1[0].push(item['ZBPZ0057'])
            dataR1[1].push(item['ZBPZ0058'])
          })
          // 各省属企业录用结果公示人次
          dataR2[0] = []
          dataR2[1] = []
          res.orgData.area4.card2.forEach(item => {
            dataR2[0].push(item['ZBPZ0059'])
            dataR2[1].push(item['ZBPZ0060'])
          })
          // 各省属企业年利润与当年累计招聘人数
          dataR3[0] = []
          dataR3[1] = []
          res.orgData.area4.card3.forEach(item => {
            dataR3[0].push(item['ZBPZ0054'])
            dataR3[1].push(item['ZBPZ0055'])
          })
          // 各省属企业"退二进一"完成情况
          dataR4[0] = []
          dataR4[1] = []
          res.orgData.area4.card4.forEach(item => {
            dataR4[0].push(item['ZBPZ0056'])
            dataR4[1].push(item['ZBPZ0055'])
          })

          // 定薪酬
          // 弹窗
          // tipData.focus[5] = res.orgData.area5.keyPoint
          tipData.analysis[5] = res.orgData.area5.intAnalysis.map(item => item.analysis)
          // 各省属企业在岗职工平均薪酬
          fjxdataL1[0] = []
          fjxdataL1[1] = []
          res.orgData.area5.card1.forEach(item => {
            fjxdataL1[0].push(item['ZBPZ0063'])
            fjxdataL1[1].push(item['ZBPZ0064'])
          })
          // 各省属企业利润与薪酬变动情况
          fjxdataL2[0] = []
          fjxdataL2[1] = []
          res.orgData.area5.card2.forEach(item => {
            fjxdataL2[0].push(item['ZBPZ0061'])
            fjxdataL2[1].push(item['ZBPZ0062'])
          })

          // 定任期
          // 弹窗
          // tipData.focus[5] = res.orgData.area6.keyPoint
          tipData.analysis[5] = res.orgData.area6.intAnalysis.map(item => item.analysis)
          // 各省属企业全员绩效考核
          fjxdataL3[0] = []
          res.orgData.area6.card1.forEach(item => {
            fjxdataL3[0].push(item['ZBPZ0066'])
          })
          // 各省属企业全员绩效考核
          fjxdataL4[0] = []
          res.orgData.area6.card2.forEach(item => {
            fjxdataL4[0].push(item['ZBPZ0065'])
          })
          // 数据整理
          dataL7[0].forEach((item, index) => {
            if (dataL7[1][index] < 0 && dataL7[0][index] > 0) {
              let obj = { value: [this.companyList[index].name, dataL7[0][index]], symbolSize: 15 }
              this.twinkle7.push(obj)
            }
          })
          //  if (dataL8[1][params.dataIndex] < 0 && params.value > 0) {
          dataL8[0].forEach((item, index) => {
            if (dataL8[1][index] < 0 && dataL8[0][index] > 0) {
              let obj = { value: [this.companyList[index].name, dataL8[0][index]], symbolSize: 15 }
              this.twinkle8.push(obj)
            }
          })
          // params.value > 0 && fjxdataL2[0][params.dataIndex] < 0
          fjxdataL2[0].forEach((item, index) => {
            if (fjxdataL2[1][index] > 0 && fjxdataL2[0][index] < 0) {
              let obj = { value: [this.companyList[index].name, fjxdataL2[1][index]], symbolSize: 15 }
              this.twinkleR6.push(obj)
            }
          })
          this.generateEcharts()
          resolve(1)
        })
      });
    },
    handleTitleShow (e) {
      this.imgPop = e
      this.titleShow = true
      this.showTip = false
      this.showTip2 = false
    },
    // handlepaymentShow () {
    //   this.paymentShow = true
    //   this.titleShow = false
    //   this.showTip = false
    //   this.showTip2 = false
    // },
    showTipClose () {
      // this.paymentShow = false
      this.showTip = false
      this.showTip2 = false
      this.titleShow = false
    },
    handleShowTip (index, type) {
      if (type == 'analysis') {
        this.tipData = tipData.analysis
      } else if (type == 'focus') {
        this.tipData = tipData.focus
      } else if (type == 'topThree') {
        this.tipData = tipData.topThree
      } else if (type == 'totlePeople') {
        this.tipData = tipData.totlePeople
      } else if (type == 'beforeReform') {
        this.tipData = tipData.beforeReform
      } else if (type == 'reformRegistered') {
        this.tipData = tipData.reformRegistered
      } else if (type == 'reforAveRemuneration') {
        this.tipData = tipData.reforAveRemuneration
      }
      this.showTip2 = false
      this.showTip = true
      this.titleShow = false
      this.tipNum = index
    },
    handleShowTip2 (index) {
      this.showTip = false
      this.showTip2 = true
      this.titleShow = false
      this.tipNum = index
    },
    handleGoPage (id, name) {
      if (name == '晋能控股') {
        window.location.href = './index2JNKG.html?id=' + id + `&access_token=${this.access_token}` + `&name=${name}`
      } else {
        window.location.href = './index2.html?id=' + id + `&access_token=${this.access_token}` + `&name=${name}`
      }
    },
    numFormat (value) {
      if (!value) return '0'
      // var intPart = Number(value).toFixed(0) // 获取整数部分
      var intPart = parseInt(value)// 获取整数部分
      var intPartFormat = intPart.toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,') // 将整数部分逢三一断

      var floatPart = '.00' // 预定义小数部分
      var value2Array = value.toString().split('.')
      // =2表示数据有小数位
      if (value2Array.length === 2) {
        floatPart = value2Array[1].toString() // 拿到小数部分
        if (floatPart.length === 1) {
          // 补0
          return intPartFormat + '.' + floatPart + '0'
        } else {
          return intPartFormat + '.' + floatPart
        }
      } else {
        return intPartFormat
      }
    },
    initChartL1 () {
      let myChart = echarts.init(this.$refs['echartL1'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#5e7ae9',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '总部机构数核定上限',
            type: 'line',
            // yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 8, //标记的大小
            smooth: false,
            itemStyle: {
              //折线拐点标志的样式
              color: '#fbe138',
              borderColor: '#fbe138',
              width: 2,
              shadowColor: '#fbe138',
              shadowBlur: 4,
            },
            lineStyle: {
              color: '#fbe138',
              width: 2,
            },
            data: dataL1[2],
          },
          {
            name: '六定改革前总部机构数',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#43ede3',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataL1[0],
          },
          {
            name: '当前各省属企业总部机构数',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: params => {
                  if (params.value > dataL1[2][params.dataIndex]) {
                    return 'red'
                  } else {
                    return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                      {
                        offset: 0,
                        color: '#5e7ae9',
                      },
                      {
                        offset: 1,
                        color: '#082550',
                      },
                    ])
                  }
                },
              },
            },
            data: dataL1[1],
          },
        ],
        // tooltip: {
        //   trigger: 'item',
        //   position: 'top'
        // },
      }

      option.title.text = '各省属企业总部机构数'
      option.legend.data = ['六定改革前总部机构数', '当前各省属企业总部机构数', '总部机构数核定上限']
      option.yAxis.push({
        splitLine: {
          show: false,
        },
        axisLine: {
          show: false,
        },
      })
      myChart.setOption(option)
    },
    initChartL2 () {
      let myChart = echarts.init(this.$refs['echartL2'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#69c0ff',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '当前总部共享服务中心/事业部数',
            type: 'bar',
            barWidth: 15,
            label: {
              normal: {
                show: true,
                position: 'top',
                textStyle: {
                  color: '#69c0ff',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '华阳新材') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              color: params => {
                if (params.value > dataL2[1][params.dataIndex]) {
                  return 'red'
                } else {
                  return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                    {
                      offset: 0,
                      color: '#69c0ff',
                    },
                    {
                      offset: 1,
                      color: '#082550',
                    },
                  ])
                }
              },
            },
            data: dataL2[0],
          },
          {
            name: '六定改革前总部共享服务中心/事业部核定上限',
            type: 'bar',
            barWidth: 15,
            label: {
              normal: {
                show: true,
                position: 'top',
                textStyle: {
                  color: '#69c0ff',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '华阳新材') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#5e7ae9',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataL2[2],
          },
          {
            name: '总部共享服务中心/事业部核定上限',
            type: 'line',
            // yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 8, //标记的大小
            smooth: false,
            label: {
              normal: {
                show: true,
                position: 'top',
                textStyle: {
                  color: '#fbe138',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '华阳新材') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              //折线拐点标志的样式
              color: '#fbe138',
              borderColor: '#fbe138',
              width: 2,
              shadowColor: '#fbe138',
              shadowBlur: 4,
            },
            lineStyle: {
              color: '#fbe138',
              width: 2,
            },
            data: dataL2[1],
          },
        ],
      }
      option.title.text = '各省属企业总部共享服务中心/事业部数'
      option.legend.data = ['当前总部共享服务中心/事业部数', '总部共享服务中心/事业部核定上限', '六定改革前总部共享服务中心/事业部核定上限']
      option.yAxis.push({
        splitLine: {
          show: false,
        },
        axisLine: {
          show: false,
        },
      })
      myChart.setOption(option)
    },
    initChartL3 () {
      let myChart = echarts.init(this.$refs['echartL3'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        series: [
          {
            name: '当前管理人员数',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#5e7ae9',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataL3[0],
          },
          {
            name: '管理人员数占总人数比值',
            type: 'line',
            yAxisIndex: 1,
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 8, //标记的大小
            smooth: false,
            itemStyle: {
              //折线拐点标志的样式
              color: '#fbe138',
              borderColor: '#fbe138',
              width: 2,
              shadowColor: '#fbe138',
              shadowBlur: 4,
            },
            lineStyle: {
              color: '#fbe138',
              width: 2,
            },
            markLine: {
              data: [
                {
                  name: '管理人员数占总人数的合理比值线',
                  yAxis: 15,
                  lineStyle: {
                    color: '#fff',
                  },
                  label: {
                    formatter: '{b}',
                    position: 'middle',
                    color: '#fff',
                    fontSize: 16,
                  },
                },
              ],
              label: {
                distance: [20, 8],
              },
            },
            data: dataL3[1],
          },
        ],
      }
      option.title.text = '各省属企业管理人员数'
      option.legend.data = ['当前管理人员数', '管理人员数占总人数比值']
      option.yAxis[0] = {
        type: 'log',
        min: 1,
        logBase: 10,
        axisLine: {
          show: false,
        },
        splitLine: {
          show: true,
          lineStyle: {
            color: '#68b4dd66',
            type: 'dashed',
          },
        },
        axisLabel: {
          show: true,
          formatter: function (value) {
            return value === 1 ? 0 : value
          },
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
      }
      option.yAxis.push({
        type: 'value',
        axisLine: {
          show: false,
        },
        splitLine: {
          show: false,
        },
        axisLabel: {
          show: true,
          formatter: '{value} %',
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
      })
      option.tooltip.formatter = '{a0}:{c0}' + '<br/>' + '{a1}:{c1}' + '%'
      myChart.setOption(option)
    },
    initChartL4 () {
      let myChart = echarts.init(this.$refs['echartL4'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#6480f3',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '六定改革前总部中层管理人数',
            type: 'bar',
            barWidth: 15,
            label: {
              normal: {
                show: true,
                position: 'top',
                textStyle: {
                  color: '#69c0ff',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '云时代') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#69c0ff',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataL4[0],
          },
          {
            name: '当前总部中层管理人数',
            type: 'bar',
            barWidth: 15,
            label: {
              normal: {
                show: true,
                position: 'top',
                textStyle: {
                  color: '#6480f3',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '云时代') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              normal: {
                color: params => {
                  if (params.value > dataL4[2][params.dataIndex] || params.value > dataL4[0][params.dataIndex]) {
                    return 'red'
                  } else {
                    return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                      {
                        offset: 0,
                        color: '#6480f3',
                      },
                      {
                        offset: 1,
                        color: '#082550',
                      },
                    ])
                  }
                },
              },
            },
            data: dataL4[1],
          },
          {
            name: '总部中层管理人数核定上限',
            type: 'line',
            // yAxisIndex: 1,
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 8, //标记的大小
            smooth: false,
            label: {
              normal: {
                show: true,
                position: 'top',
                textStyle: {
                  color: '#fbe138',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '云时代') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              //折线拐点标志的样式
              color: '#fbe138',
              borderColor: '#fbe138',
              width: 2,
              shadowColor: '#fbe138',
              shadowBlur: 4,
            },
            lineStyle: {
              color: '#fbe138',
              width: 2,
            },
            data: dataL4[2],
          },
        ],
      }
      option.title.text = '各省属企业总部中层管理人数'
      option.legend.data = ['六定改革前总部中层管理人数', '当前总部中层管理人数', '总部中层管理人数核定上限']
      option.legend.show = true
      // option.yAxis.push({
      //   splitLine: {
      //     show: false,
      //   },
      //   axisLine: {
      //     show: false,
      //   },
      // })
      myChart.setOption(option)
    },
    initChartL5 () {
      let myChart = echarts.init(this.$refs['echartL5'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#69c0ff',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '各省属企业总人数',
            type: 'bar',
            barWidth: 15,
            label: {
              normal: {
                show: true,
                position: 'top',
                lineHeight: '25',
                textStyle: {
                  color: '#69c0ff',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '华阳新材' || data.name == '华舰体育') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              normal: {
                color: params => {
                  if (params.dataIndex > 0 && Math.abs(params.value - dataL5[0][params.dataIndex - 1]) > params.value * 0.1) {
                    return 'yellow'
                  } else {
                    return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                      {
                        offset: 0,
                        color: '#69c0ff',
                      },
                      {
                        offset: 1,
                        color: '#082550',
                      },
                    ])
                  }
                }
              },
            },
            data: dataL5[0],
          },
          {
            name: '总人数同比变化',
            type: 'line',
            yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 8, //标记的大小
            smooth: false,
            label: {
              normal: {
                show: true,
                position: 'bottom',
                lineHeight: '25',
                textStyle: {
                  color: '#b889ea',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '华阳新材' || data.name == '华舰体育') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              //折线拐点标志的样式
              color: '#b889ea',
              borderColor: '#b889ea',
              width: 2,
              shadowColor: '#b889ea',
              shadowBlur: 4,
            },
            lineStyle: {
              color: '#b889ea',
              width: 2,
            },
            data: dataL5[1],
          },
        ],
      }
      option.title.text = '各省属企业总人数'
      option.legend.data = ['各省属企业总人数', '总人数同比变化']
      option.legend.show = true
      option.yAxis[0] = {
        type: 'value',
        // type: 'log',
        min: 1,
        // logBase: 10,
        axisLine: {
          show: false,
        },
        splitLine: {
          show: true,
          lineStyle: {
            color: '#68b4dd66',
            type: 'dashed',
          },
        },
        axisLabel: {
          show: true,
          formatter: function (value) {
            return value === 1 ? 0 : value
          },
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
      }
      option.yAxis.push({
        type: 'value',
        axisLine: {
          show: false,
        },
        splitLine: {
          show: false,
        },
        axisLabel: {
          show: true,
          formatter: '{value} %',
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
      })
      option.tooltip.formatter = '{a0}:{c0}' + '<br/>' + '{a1}:{c1}' + '%'
      myChart.setOption(option)
    },
    initChartL6 () {
      let myChart = echarts.init(this.$refs['echartL6'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#43ede3',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '总部员额数',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              color: params => {
                if (params.value > dataL6[1][params.dataIndex]) {
                  return 'red'
                } else {
                  return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                    {
                      offset: 0,
                      color: '#43ede3',
                    },
                    {
                      offset: 1,
                      color: '#082550',
                    },
                  ])
                }
              },
            },
            data: dataL6[0],
          },
          {
            name: '六定改革前总部员额数',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#5e7ae9',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataL6[2],
          },
          {
            name: '总部员额数核定上限',
            type: 'line',
            yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 8, //标记的大小
            smooth: false,
            itemStyle: {
              //折线拐点标志的样式
              color: '#fbe138',
              borderColor: '#fbe138',
              width: 2,
              shadowColor: '#fbe138',
              shadowBlur: 4,
            },
            lineStyle: {
              color: '#fbe138',
              width: 2,
            },
            data: dataL6[1],
          },
        ],
      }
      option.title.text = '各省属企业总部员额数'
      option.legend.data = ['六定改革前总部员额数', '总部员额数', '总部员额数核定上限']
      option.legend.show = true
      option.yAxis.push({
        splitLine: {
          show: false,
        },
        axisLine: {
          show: false,
        },
      })
      myChart.setOption(option)
    },
    initChartL7 () {
      let myChart = echarts.init(this.$refs['echartL7'])
      let that = this
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: ['#43ede3'],
        series: [
          {
            name: '人数变化',
            type: 'line',
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 15, //标记的大小
            smooth: false,
            label: {
              normal: {
                show: true,
                position: 'bottom',
                lineHeight: '35',
                textStyle: {
                  color: '#43ede3',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '文旅集团' || data.name == "大地控股" || data.name == '华舰体育') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              color: params => {
                if (dataL7[1][params.dataIndex] < 0 && params.value > 0) {
                  return 'red'
                } else if (params.value < 0 && dataL7[1][params.dataIndex] > 0) {
                  return 'green'
                }
                else {
                  return '#43ede3'
                }
              },
            },
            lineStyle: {
              color: '#43ede3',
              width: 2,
            },
            data: dataL7[0],
          },
          {
            name: '劳动生产率同比变化',
            type: 'line',
            yAxisIndex: 1,
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 8, //标记的大小
            smooth: false,
            label: {
              normal: {
                show: true,
                position: 'top',
                lineHeight: '25',
                textStyle: {
                  color: '#b889ea',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '文旅集团' || data.name == "大地控股" || data.name == '华舰体育') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              //折线拐点标志的样式
              color: '#b889ea',
              borderColor: '#b889ea',
              width: 2,
              shadowColor: '#b889ea',
              shadowBlur: 4,
            },
            data: dataL7[1],
          },
          {
            type: 'effectScatter',
            coordinateSystem: 'cartesian2d',
            showEffectOn: 'render',
            rippleEffect: {
              period: 10,
              scale: 4,
              brushType: 'stroke'
            },
            hoverAnimation: true,
            itemStyle: {
              color: 'red'
            },
            lineStyle: {
              color: '#43ede3',
              width: 2,
            },

            data: that.twinkle7,
          },
        ],
      }
      option.title.text = '人数变化和全员劳动生产率变化分析'
      option.legend.data = ['人数变化', '劳动生产率同比变化']
      option.legend.show = true
      option.yAxis[0].axisLabel.formatter = '{value} %'
      option.tooltip.formatter = '{a0}:{c0}' + '%' + '<br/>' + '{a1}:{c1}' + '%'
      option.yAxis.push({
        type: 'value',
        axisLine: {
          show: false,
        },
        splitLine: {
          show: false,
        },
        axisLabel: {
          show: true,
          formatter: '{value} %',
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
          splitLine: {
            show: false,
          },
          axisLabel: {
            show: true,
            formatter: '{value} %',
            textStyle: {
              color: 'rgba(250,250,250,0.6)',
            },
          },
        },
      })

      myChart.setOption(option)
    },
    initChartL8 () {
      let myChart = echarts.init(this.$refs['echartL8'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: ['#43ede3'],
        series: [
          {
            name: '人数变化',
            type: 'line',
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 15, //标记的大小
            smooth: false,
            label: {
              normal: {
                show: true,
                position: 'bottom',
                lineHeight: '20',
                textStyle: {
                  color: '#43ede3',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '文旅集团' || data.name == '大地控股') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              color: params => {
                if (dataL8[1][params.dataIndex] < 0 && params.value > 0) {
                  return 'red'
                } else if (params.value < 0 && dataL8[1][params.dataIndex] > 0) {
                  return 'green'
                }
                else {
                  return '#43ede3'
                }
              },
            },
            lineStyle: {
              color: '#43ede3',
              width: 2,
            },
            data: dataL8[0],
          },
          {
            name: '人工成本利润率同比变化',
            type: 'line',
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 15, //标记的大小
            smooth: false,
            label: {
              normal: {
                show: true,
                position: 'top',
                lineHeight: '30',
                textStyle: {
                  color: '#b889ea',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '文旅集团' || data.name == '大地控股') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              //折线拐点标志的样式
              color: '#b889ea',
              borderColor: '#b889ea',
              width: 2,
              shadowColor: '#b889ea',
              shadowBlur: 4,
            },

            lineStyle: {
              color: '#b889ea',
              width: 2,
            },
            data: dataL8[1],
          },
          {
            type: 'effectScatter',
            coordinateSystem: 'cartesian2d',
            showEffectOn: 'render',
            rippleEffect: {
              period: 10,
              scale: 4,
              brushType: 'stroke'
            },
            hoverAnimation: true,
            itemStyle: {
              color: 'red'
            },
            lineStyle: {
              color: '#43ede3',
              width: 2,
            },

            data: this.twinkle8,
          },
          // {
          //   type: 'effectScatter',
          //   coordinateSystem: 'cartesian2d',
          //   showEffectOn: 'render',
          //   rippleEffect: {
          //     period: 10,
          //     scale: 4,
          //     brushType: 'stroke'
          //   },
          //   hoverAnimation: true,
          //   itemStyle: {
          //     color: 'red'
          //   },
          //   lineStyle: {
          //     color: '#43ede3',
          //     width: 2,
          //   },

          //   data: that.twinkle,
          // },
        ],
        // tooltip: {
        //   trigger: 'axis',
        //   formatter(params){
        //     console.log(params)
        //     return params[0]
        //   }
        // }
      }
      option.title.text = '人数变化和人工成本利润率变化分析'
      option.legend.data = ['人数变化', '人工成本利润率同比变化']
      option.legend.show = true
      option.yAxis[0].axisLabel.formatter = '{value} %'
      option.tooltip.formatter = '{a0}:{c0}' + '%' + '<br/>' + '{a1}:{c1}' + '%'
      myChart.setOption(option)
    },
    // 中间图表---------------------------------------------开始
    initChartC1 () {
      let myChart = echarts.init(this.$refs['echartC1'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#69c0ff',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '全员劳动生产率(万/人)',
            type: 'bar',
            barWidth: 15,
            label: {
              normal: {
                show: true,
                position: 'top',
                textStyle: {
                  color: '#69c0ff',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '国际能源' || data.name == '汾酒集团') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              color: params => {
                if (params.value < 0 && c1[1][params.dataIndex] < 0) {
                  return 'red'
                } else if (params.value > this.echartC1.province) {
                  return 'green'
                } else {
                  return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                    {
                      offset: 0,
                      color: '#69c0ff',
                    },
                    {
                      offset: 1,
                      color: '#082550',
                    },
                  ])
                }
              },
            },
            markLine: {
              data: [
                {
                  name: '省属企业平均水平',
                  yAxis: this.echartC1.national,
                  lineStyle: {
                    color: '#fff',
                  },
                  label: {
                    formatter: '{b}',
                    position: 'middle',
                    padding: [20, 100, 10, 10],
                    fontSize: 16,
                    color: '#fff',

                  },
                },
                {
                  name: '央企平均水平',
                  yAxis: this.echartC1.province,
                  lineStyle: {
                    color: '#fff',
                  },
                  label: {
                    formatter: '{b}',
                    position: 'end',
                    padding: [-4, 150, 10, 10],
                    color: '#fff',
                    fontSize: 16,
                  },
                },
              ],
              label: {
                distance: [50, 0],
              },
            },
            data: c1[0],
          },
          {
            name: '全员劳动生产率同比',
            type: 'line',
            yAxisIndex: 1,
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 8, //标记的大小
            smooth: false,
            itemStyle: {
              //折线拐点标志的样式
              color: '#B889EA',
              borderColor: '#B889EA',
              width: 2,
              shadowColor: '#B889EA',
              shadowBlur: 4,
            },
            lineStyle: {
              color: '#B889EA',
              width: 2,
            },
            label: {
              normal: {
                show: true,
                position: 'top',
                textStyle: {
                  color: '#B889EA',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '国际能源' || data.name == '汾酒集团') {
                    return data.value + '%'
                  } else {
                    return ''
                  }
                }
              }
            },

            data: c1[1],
          },
        ],
      }
      option.title.text = '各省属企业全员劳动生产率'
      option.legend.show = true
      option.grid.right = '15%'
      option.tooltip.formatter = '{a0}:{c0}' + '<br/>' + '{a1}:{c1}' + '%'
      option.yAxis.push({
        type: 'value',
        axisLine: {
          show: false,
        },
        splitLine: {
          show: false,
        },
        axisLabel: {
          show: true,
          formatter: '{value} %',
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
      })
      myChart.setOption(option)
      // tools.loopShowTooltip(myChart, option, {
      //   nterval: 2000,
      //   loopSeries: true,
      // })
    },
    initChartC2 () {
      let myChart = echarts.init(this.$refs['echartC2'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#69c0ff',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '人工成本利润率',
            type: 'bar',
            barWidth: 15,
            label: {
              normal: {
                show: true,
                position: 'top',
                textStyle: {
                  color: '#fff',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '国际能源' || data.name == '文旅集团' || data.name == '航产集团' || data.name == '华舰体育') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            markLine: {
              data: [
                {
                  name: '省属企业平均水平',
                  yAxis: this.echartC2.province,
                  lineStyle: {
                    color: '#fff',
                  },
                  label: {
                    formatter: '{b}',
                    position: 'end',
                    padding: [24, 100, 10, 10],
                    fontSize: 16,
                    color: '#fff',
                  },
                },
                {
                  name: '央企平均水平',
                  yAxis: this.echartC2.national,
                  lineStyle: {
                    color: '#fff',
                  },
                  label: {
                    formatter: '{b}',
                    position: 'middle',
                    padding: [-24, 200, 10, 10],
                    color: '#fff',
                    fontSize: 16,
                  },
                },
              ],
              label: {
                distance: [50, 0],
              },
            },
            itemStyle: {
              color: params => {
                if (params.value < 0 && c2[0][params.dataIndex] < 0) {
                  return 'red'
                } else if (params.value > this.echartC2.province) {
                  return 'green'
                } else {
                  return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                    {
                      offset: 0,
                      color: '#69c0ff',
                    },
                    {
                      offset: 1,
                      color: '#082550',
                    },
                  ])
                }
              },
            },
            data: c2[1],
          },
          {
            name: '人工成本利润率同比',
            type: 'line',
            yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 8, //标记的大小
            smooth: false,
            label: {
              normal: {
                show: true,
                position: 'top',
                lineHeight: '30',
                textStyle: {
                  color: '#b889ea',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '国际能源' || data.name == '文旅集团' || data.name == '航产集团' || data.name == '华舰体育') {
                    return data.value + '%'
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              //折线拐点标志的样式
              color: '#B889EA',
              borderColor: '#B889EA',
              width: 2,
              shadowColor: '#B889EA',
              shadowBlur: 4,
            },
            lineStyle: {
              color: '#B889EA',
              width: 2,
            },
            data: c2[0],
          },
        ],
      }
      option.title.text = '各省属企业人工成本利润率'
      option.legend.show = true
      option.grid.right = '15%'
      option.yAxis[0].axisLabel.formatter = '{value} %'
      option.tooltip.formatter = '{a0}:{c0}' + '%' + '<br/>' + '{a1}:{c1}' + '%'
      option.yAxis.push({
        type: 'value',
        axisLine: {
          show: false,
        },
        splitLine: {
          show: false,
        },
        axisLabel: {
          show: true,
          formatter: '{value} %',
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
      })
      myChart.setOption(option)
      // tools.loopShowTooltip(myChart, option, {
      //   nterval: 2000,
      //   loopSeries: true,
      // })
    },
    // 右侧图表---------------------------------------------开始
    initChartR1 () {
      let myChart = echarts.init(this.$refs['echartR1'])
      let commonOptions = this.commonOption
      commonOptions.yAxis[0].splitNumber = 2
      let dataTemp = []
      let dataTemp2 = []
      dataR1[0].forEach(item => {
        dataTemp.push(item)
      })
      dataR1[1].forEach(item => {
        dataTemp2.push(item)
      })

      let option = {
        ..._.cloneDeep(commonOptions),
        series: [
          {
            name: '招聘需求公告次数',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#69c0ff',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataTemp,
          },
          {
            name: '招聘需求公告累计公开招聘人数',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#43ede3',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataTemp2,
          },
        ],
      }
      option.title.text = '各省属企业招聘需求公示人次'
      option.legend.data = ['招聘需求公告次数', '招聘需求公告累计公开招聘人数']
      option.legend.show = true
      // option.tooltip.formatter = function (value) {
      //   return value[0].axisValue + ':' + (value[0].value - 1) + '<br>' + value[1].axisValue + ':' + (value[1].value - 1)
      // }
      option.yAxis[0] = {
        type: 'log',
        min: 1,
        logBase: 10,
        axisLine: {
          show: false,
        },
        splitLine: {
          show: true,
          lineStyle: {
            color: '#68b4dd66',
            type: 'dashed',
          },
        },
        axisLabel: {
          show: true,
          formatter: function (value) {
            return value === 1 ? 0 : value
          },
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
      }
      myChart.setOption(option)
    },
    initChartR2 () {
      let myChart = echarts.init(this.$refs['echartR2'])
      let commonOptions = this.commonOption
      commonOptions.yAxis[0].splitNumber = 2
      let dataTemp = []
      let dataTemp2 = []
      dataR2[0].forEach(item => {
        dataTemp.push(item)
      })
      dataR2[1].forEach(item => {
        dataTemp2.push(item)
      })
      let option = {
        ..._.cloneDeep(commonOptions),
        series: [
          {
            name: '录用结果公示次数',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#69c0ff',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataTemp,
          },
          {
            name: '录用结果公示累计公示人数',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#45DAD1',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataTemp2,
          },
        ],
      }
      option.title.text = '各省属企业录用结果公示人次'
      option.legend.data = ['录用结果公示次数', '录用结果公示累计公示人数']
      option.legend.show = true
      // option.tooltip.formatter = function (value) {
      //   return value[0].axisValue + ':' + (value[0].value - 1) + '<br>' + value[1].axisValue + ':' + (value[1].value - 1)
      // }
      option.yAxis[0] = {
        type: 'log',
        min: 1,
        logBase: 10,
        axisLine: {
          show: false,
        },
        splitLine: {
          show: true,
          lineStyle: {
            color: '#68b4dd66',
            type: 'dashed',
          },
        },
        axisLabel: {
          show: true,
          formatter: function (value) {
            return value === 1 ? 0 : value
          },
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
      }
      myChart.setOption(option)
    },
    initChartR3 () {
      let myChart = echarts.init(this.$refs['echartR3'])
      let commonOptions = this.commonOption
      commonOptions.yAxis[0].splitNumber = 2
      let option = {
        ..._.cloneDeep(commonOptions),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#45DAD1',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '年利润(万)',
            type: 'bar',
            barWidth: 15,
            label: {
              normal: {
                show: true,
                position: 'bottom',
                textStyle: {
                  color: '#69c0ff',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 14,
                },
                formatter: function (data) {
                  if (data.name == "国际能源" || data.name == '文旅集团' || data.name == '航产集团' || data.name == '华舰体育') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#69c0ff',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataR3[0],
          },
          {
            name: '2022年招聘人数和2023年当前累计招聘人数之和',
            type: 'bar',
            barWidth: 15,
            yAxisIndex: 1,
            label: {
              normal: {
                show: true,
                position: 'top',
                textStyle: {
                  color: '#45DAD1',
                  fontStyle: 'normal',
                  textAlign: 'right',
                  fontSize: 14,
                },
                formatter: function (data) {
                  if (data.name == "国际能源" || data.name == '文旅集团' || data.name == '航产集团' || data.name == '华舰体育') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              color: params => {
                if (params.value > 0 && dataR3[0][params.dataIndex] < 0) {
                  return 'red'
                } else {
                  return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                    {
                      offset: 0,
                      color: '#45DAD1',
                    },
                    {
                      offset: 1,
                      color: '#082550',
                    },
                  ])
                }
              },
            },
            // itemStyle: {
            //   normal: {
            //     color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
            //       {
            //         offset: 0,
            //         color: '#45DAD1',
            //       },
            //       {
            //         offset: 1,
            //         color: '#082550',
            //       },
            //     ]),
            //   },
            // },
            data: dataR3[1],
          },
        ],
      }
      option.title.text = '各省属企业年利润与当年累计招聘人数'
      option.legend.data = ['年利润(万)', '2022年招聘人数和2023年当前累计招聘人数之和']
      option.legend.show = true
      option.yAxis[0] = {
        max: function (value) {
          if (Math.abs(value.max) > Math.abs(value.min)) {
            return (Math.abs(value.max) * 1.2).toFixed(2)
          } else {
            return (Math.abs(value.min) * 1.2).toFixed(2)
          }
        },
        min: function (value) {
          if (Math.abs(value.max) > Math.abs(value.min)) {
            return (-Math.abs(value.max) * 1.2).toFixed(2)
          } else {
            return (-Math.abs(value.min) * 1.2).toFixed(2)
          }
        },
        type: 'value',
        axisLine: {
          show: false,
        },
        splitLine: {
          show: true,
          lineStyle: {
            color: '#68b4dd66',
            type: 'dashed',
          },
        },
        axisLabel: {
          show: true,
          formatter: function (value) {
            return value === 1 ? 0 : value
          },
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
      }
      option.yAxis.push({
        splitLine: {
          show: false,
        },
        axisLine: {
          show: false,
        },
        axisLabel: {
          show: true,
          formatter: '{value}',
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
        max: function (value) {
          if (Math.abs(value.max) > Math.abs(value.min)) {
            return (Math.abs(value.max) * 1.2).toFixed(2)
          } else {
            return (Math.abs(value.min) * 1.2).toFixed(2)
          }
        },
        min: function (value) {
          if (Math.abs(value.max) > Math.abs(value.min)) {
            return (-Math.abs(value.max) * 1.2).toFixed(2)
          } else {
            return (-Math.abs(value.min) * 1.2).toFixed(2)
          }
        },
      })
      myChart.setOption(option)
    },
    initChartR4 () {
      let myChart = echarts.init(this.$refs['echartR4'])
      let commonOptions = this.commonOption
      commonOptions.yAxis[0].splitNumber = 2
      let option = {
        ..._.cloneDeep(commonOptions),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#6480f3',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '2022年退出人数和2023年当前累计退出人数之和',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#69c0ff',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: dataR4[0],
          },
          {
            name: '2022年招聘人数和2023年当前累计招聘人数之和',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: params => {
                  // if (params.value / dataR4[0][params.dataIndex] > 3) {
                  //   return 'green'
                  // } else if (params.value / 2 < dataR4[0][params.dataIndex]) {
                  //   return 'yellow'
                  // }
                  if (dataR4[0][params.dataIndex] / 2 < params.value) {
                    return 'red'
                  }
                  else {
                    return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                      {
                        offset: 0,
                        color: '#6480f3',
                      },
                      {
                        offset: 1,
                        color: '#082550',
                      },
                    ])
                  }
                },
              },
            },
            data: dataR4[1],
          },
        ],
      }
      option.title.text = '各省属企业"退二进一"完成情况'
      option.legend.data = ['2022年退出人数和2023年当前累计退出人数之和', '2022年招聘人数和2023年当前累计招聘人数之和']
      option.legend.show = true
      option.yAxis[0] = {
        //type: 'log',
        //min: 1,
        //logBase: 3,
        axisLine: {
          show: false,
        },
        splitLine: {
          show: true,
          lineStyle: {
            color: '#68b4dd66',
            type: 'dashed',
          },
        },
        axisLabel: {
          show: true,
          formatter: function (value) {
            return value === 1 ? 0 : value
          },
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        },
      }
      myChart.setOption(option)
    },
    initChartR5 () {
      let myChart = echarts.init(this.$refs['echartR5'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        series: [
          {
            name: '去年同期在岗职工平均薪酬',
            type: 'bar',
            barWidth: 15,
            markLine: {
              data: [
                {
                  name: '省属企业平均水平',
                  yAxis: 9333.33,
                  lineStyle: {
                    color: '#fff',
                  },
                  label: {
                    formatter: '{b}',
                    position: 'middle',
                    fontSize: 16,
                    color: '#fff',
                  },
                }
              ],
              label: {
                distance: [50, 0],
              },
            },
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#6682F5',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: fjxdataL1[1],
          },
          {
            name: '在岗职工平均薪酬',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                  {
                    offset: 0,
                    color: '#69c0ff',
                  },
                  {
                    offset: 1,
                    color: '#082550',
                  },
                ]),
              },
            },
            data: fjxdataL1[0],
          },
        ],
      }
      option.title.text = '各省属企业在岗职工平均薪酬'
      option.legend.data = ['去年同期在岗职工平均薪酬', '在岗职工平均薪酬']
      option.legend.show = true
      option.yAxis.push({
        splitLine: {
          show: false,
        },
        axisLine: {
          show: false,
        },
      })
      myChart.setOption(option)
    },
    initChartR6 () {
      let myChart = echarts.init(this.$refs['echartR6'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: ['#69c0ff'],
        series: [
          {
            name: '月利润总额同期变化率',
            type: 'line',
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 8, //标记的大小
            smooth: false,
            label: {
              normal: {
                show: true,
                lineHeight: '20',
                position: 'top',
                textStyle: {
                  color: '#B889EA',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '文旅集团') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              //折线拐点标志的样式
              color: '#B889EA',
              borderColor: '#B889EA',
              width: 2,
              shadowColor: '#B889EA',
              shadowBlur: 4,
            },
            lineStyle: {
              color: '#B889EA',
              width: 2,
            },
            data: fjxdataL2[0],
          },

          {
            name: '月薪酬总额同期变化率',
            type: 'line',
            smooth: true, //平滑曲线显示
            showAllSymbol: true, //显示所有图形。
            symbol: 'circle', //标记的图形为实心圆
            symbolSize: 12, //标记的大小
            smooth: false,
            label: {
              normal: {
                show: true,
                position: 'top',
                lineHeight: '35',
                textStyle: {
                  color: '#69c0ff',
                  fontStyle: 'normal',
                  textAlign: 'left',
                  fontSize: 16,
                },
                formatter: function (data) {
                  if (data.name == '文旅集团') {
                    return data.value
                  } else {
                    return ''
                  }
                }
              }
            },
            itemStyle: {
              color: params => {
                if (params.value > 0 && fjxdataL2[0][params.dataIndex] < 0) {
                  return 'yellow'
                } else if (params.value < 0 && fjxdataL2[0][params.dataIndex] > 0) {
                  return 'green'
                }
                else {
                  return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                    {
                      offset: 0,
                      color: '#69c0ff',
                    },
                    {
                      offset: 1,
                      color: '#082550',
                    },
                  ])
                }
              },
            },
            lineStyle: {
              color: '#69C0FF',
              width: 2,
            },
            data: fjxdataL2[1],
          },
          {
            type: 'effectScatter',
            coordinateSystem: 'cartesian2d',
            showEffectOn: 'render',
            rippleEffect: {
              period: 10,
              scale: 4,
              brushType: 'stroke'
            },
            hoverAnimation: true,
            itemStyle: {
              color: 'yellow'
            },
            lineStyle: {
              color: '#43ede3',
              width: 2,
            },

            data: this.twinkleR6,
          },
        ],
      }
      option.title.text = '各省属企业利润与薪酬变动情况'
      option.legend.data = ['月利润总额同期变化率', '月薪酬总额同期变化率']
      option.tooltip.formatter = '{a0}:{c0}' + '%' + '<br/>' + '{a1}:{c1}' + '%'
      option.yAxis[0].axisLabel.formatter = '{value} %'
      myChart.setOption(option)
    },
    initChartR7 () {
      let myChart = echarts.init(this.$refs['echartR7'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#B889EA',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '全员绩效考核完成率',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: params => {
                  if (params.value < 50) {
                    return 'yellow'
                  }
                  else {
                    return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                      {
                        offset: 0,
                        color: '#B889EA',
                      },
                      {
                        offset: 1,
                        color: '#082550',
                      },
                    ])
                  }
                },
              },
            },
            data: fjxdataL3[0],
          },
        ],
      }
      option.title.text = '各省属企业全员绩效考核'
      option.legend.show = true
      option.tooltip = {
        trigger: 'axis',
        formatter: '{a0}:{c0}' + '%'
      },
        option.yAxis[0].axisLabel = {
          show: true,
          formatter: '{value} %',
          textStyle: {
            color: 'rgba(250,250,250,0.6)',
          },
        }
      myChart.setOption(option)
    },
    initChartR8 () {
      let myChart = echarts.init(this.$refs['echartR8'])
      let option = {
        ..._.cloneDeep(this.commonOption),
        color: [
          {
            x: 0,
            y: 0,
            x2: 0,
            y2: 1,
            colorStops: [{
              offset: 0,
              color: '#43ede3',
            },
            {
              offset: 1,
              color: '#082550',
            },],
          }
        ],
        series: [
          {
            name: '任期制契约化考核完成率',
            type: 'bar',
            barWidth: 15,
            itemStyle: {
              normal: {
                color: params => {
                  if (params.value < 50) {
                    return 'yellow'
                  }
                  else {
                    return new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                      {
                        offset: 0,
                        color: '#43ede3',
                      },
                      {
                        offset: 1,
                        color: '#082550',
                      },
                    ])
                  }
                },
              },
            },
            data: fjxdataL4[0],
          },
        ],
      }
      option.title.text = '各省属企业任期制契约化管理'
      option.legend.show = true
      option.tooltip.formatter = '{a0}:{c0}' + '%'
      option.yAxis[0].axisLabel.formatter = '{value} %'
      myChart.setOption(option)
    },
  },
})