<div class="main__wrapper" style="width:100%; height:600px;">
  <div id="main" style="width:100%; height:100%;">
    <!-- Chart will be here-->
  </div>
</div>
.main__wrapper{
  margin: 0 auto;
}

.tooltip{
  width: 220px;
  display: flex;
  flex-wrap:wrap;
  justify-content: center;
  align-items: center;
  padding:6px;
  border-radius: 4px;
  
  .tooltip__item{
    width:100%;
    font-size: 14px;
    margin: 5px 0px;
    white-space: normal;
    word-wrap: break-word;
    word-break: break-all;
  }
  
  .tooltip__itemParagraph{
    margin:5px 0px;
  }
  
  .historyData{
    &:before{
      content: '';
      display: inline-block;
      width: 10px;
      height: 7.5px;
      margin-right: 5px;
      background-color: #4bc0c0;
      vertical-align: middle;
    } 
  }
  
  .forecastData{
    &:before{
      content: '';
      display: inline-block;
      width: 10px;
      height: 7.5px;
      margin-right: 5px;
      background-color: white;
      border: 2px solid #4bc0c0;
      vertical-align: middle;
    } 
  }
  
  .Confidence80{
    &:before{
      content: '';
      display: inline-block;
      width: 10px;
      height: 7.5px;
      margin-right: 5px;
      background-color: black;
      vertical-align: middle;
    } 
  }
  
  .Confidence95{
    &:before{
      content: '';
      display: inline-block;
      width: 10px;
      height: 7.5px;
      margin-right: 5px;
      background-color: red;
      vertical-align: middle;
    } 
  }
}
View Compiled
let chartDom = document.getElementById('main');
let myChart = echarts.init(chartDom);

const option = {
  "tooltip": {
    "trigger": "axis",
    "axisPointer": {
      "type": "line"
    },
    formatter : function (params) {
      let template = `<div class="tooltip">`
      params.forEach(d=>{
        if(d.seriesName.includes('Confidence')){
          let uniqueClassName = d.seriesName.split("% ").reverse().join("")
          template += `<div class="tooltip__item">
            <p class="${uniqueClassName} tooltip__itemParagraph">${d.seriesName}</p> 
            <p class="tooltip__itemParagraph"">${d.data[1]} ~ ${d.data[2]}</p>
          </div>`
        }else{
          if(d.color==="#4bc0c0"){
            template += `<div class="historyData tooltip__item">${d.seriesName} : ${d.value}</div>` 
          }else{
            template += `<div class="forecastData tooltip__item">${d.seriesName} : ${d.value}</div>`
          }
        }
      })
      template += `</div>`
      return template
    },     
    "backgroundColor": "#fff",
    "textStyle": {
      "color": "black"
    },
    extraCssText: 'box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);'
  },
  "title": {
    "text": "Costs ($)"
  },
  "legend": {
    "x": "center",
    "y": "bottom",
    "selectedMode": false,
    "data": [
      {
        "name": "Costs",
        "icon": "bar"
      },
      {
        "name": "Forecast",
        "icon": `image://`
      }
    ],
    "textStyle": {
      fontSize: 16,
      color: 'blue',
    }
  },
  "xAxis": {
    "data": [
      "2020-12-01",
      "2021-01-01",
      "2021-02-01",
      "2021-03-01",
      "2021-04-01",
    ]
  },
  "series": [
    {
      "type": "bar",
      "name": "Costs",
      "itemStyle": {
        "normal": {
          "color": "#4bc0c0"
        }
      },
      "data": [
        25658.27,
        25797.17,
        24905.34,
        {
          "value": 22896.3,
          "itemStyle": {
            "normal": {
              "color": "#fff",
              "borderColor": "#4bc0c0"
            }
          }
        },
        {
          "value": 23968.49,
          "itemStyle": {
            "normal": {
              "color": "#fff",
              "borderColor": "#4bc0c0"
            }
          }
        }
      ]
    },
    {
      "type": "line",
      "name": "Forecast"
    }
  ],
  "yAxis": {}
}

option && myChart.setOption(option);

window.onresize = () => {
  const that = this
  if(document.body.clientWidth > 320){
    myChart.resize({width:document.body.clientWidth});
  }
}
Run Pen

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

  1. https://cdnjs.cloudflare.com/ajax/libs/echarts/4.1.0/echarts.min.js