<script setup>

const base64Img="image://"
const state=reactive({
  lineColor:$c.gyl3,
  fontColor:$c.bk,
  chartData:{
    yAxis:['TaskA', 'TaskB', 'TaskC', 'Task Long Name', 'TaskE', 'TaskF', 'TaskG', 'TaskH', 'TaskI'],
    color:[$c.aql4,$c.orl5,$c.rel5],
    data:[69, 96, 35,26, 96, 32 ,52 ,22 ,72]
  },
  chartOption:{}
})

const {lineColor,fontColor}=toRefs(state)

const fillArr=computed(()=>{
  return (new Array(state.chartData.data.length)).fill(100);
})

const getSymbolData=(data)=>{
  let arr = [];
  for (var i = 0; i < data.length; i++) {
    arr.push({
      value: data[i],
      symbolPosition: 'end'
    })
  }
  return arr;
}

const processData=()=>{
  let legend=state.chartData.legend,
      colors=state.chartData.colors,
      yAxis=state.chartData.yAxis,
      data=state.chartData.data,
      processedData=[];
  state.chartOption.yAxis.data=state.chartData.yAxis;
  state.chartOption.series[0].data=state.chartData.data;
  state.chartOption.series[1].data=fillArr;
  state.chartOption.series[2].data=getSymbolData(state.chartData.data);
  dataScroll();
}

const processOption=()=>{
  state.chartOption={
    update:false,
    title: {
      show:false,
      // text: '实时流速图2',
      textStyle:{
        color:$c.cbl5,
        fontSize:16,
        fontWeight:"normal"
      },
    },
    grid: {
      top: '15%',
      left: '18%',
      right: '12%',
      bottom: '5%'
    },
    tooltip: {show: false},
    xAxis: {
      type: 'value',
      min: 0,
      max: 100,
      axisLine: {show: false},
      splitLine: {show: false},
      axisLabel: {show: false},
      axisTick: {show: false}
    },
    dataZoom: {
      yAxisIndex: 0,
      show: false,
      type: "slider",
      startValue: 0,
      endValue: 5,
    },
    yAxis: {
      //show: false,
      type: 'category',
      inverse: true,
      splitLine: {show: false,},
      axisLine: {show: false},
      axisLabel: {
        show: true,
        interval: 0,
        margin: 10,
        color:fontColor,
        fontSize: 12,
        width:50,
        lineHeight:14,
        overflow:"break",
        fontWeight: 'normal',
      },
      axisTick: {show: false},
      data:[]
    },
    series: [
      {
        type: 'bar', 
        barWidth: '40%',
        animationDuration:2000,
        itemStyle: {
          borderWidth:0,
          borderRadius:10,
          color: {
            type: 'linear', x: 0, y: 0, x2: 1, y2: 0,
            colorStops: [{ offset: 0, color: $c.cyl4, }, { offset: 1, color: $c.cyl6, }]
          }
        },
        label: { show: false, },
        data: [],
        z: 0
      },
      {
        type: 'bar', 
        barWidth: '40%',
        barGap: '-100%',
        animation: false,
        itemStyle: {
          borderWidth: 0,
          borderRadius:5,
          color: 'rgba(0,202,255,0.2)'
        },
        label: {
          color:fontColor,
          show: true,
          position: ['101%', '20%'],
          fontSize: 14,
          fontWeight: 'normal',
          formatter: (params)=>{
            return ' ' + (state.chartData.data[params.dataIndex] ) + '%';
          }
        },
        data: [],
        z: 0
      }, 
      {
        type: 'pictorialBar',
        animation: true,
        // animationThreshold: 3000 ,
        animationDuration: 3000 ,
        // animationDurationUpdate:500,
        symbol: base64Img,
        symbolSize: [50, 50],
        symbolOffset: [20, 0],
        z: 12,
        itemStyle: {
          color: '#fff'
        },
        data: []
      },
    ]
  }
  processData();
}
const { proxy } = getCtx();
const dataScroll=()=>{
  proxy.$timer("dataScrollBarHorizD",()=>{
    let {data}=state.chartData
    let {dataZoom}=state.chartOption
    if (dataZoom.endValue == data.length ) {
      dataZoom.endValue = 5;
      dataZoom.startValue = 0;
    }else{
      dataZoom.endValue ++;
      dataZoom.startValue ++;
    }
    state.chartOption.update=true
    dataScroll()
  },5000)
}

onMounted(() => {
  processOption();
})
onBeforeMount(() => {
  proxy.$timer("dataScrollBarHorizD")
})
</script>
<template>
  <echartsInit :chartOption="state.chartOption"></echartsInit>
</template>
<style lang="less">
</style>