<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});
}
}
This Pen doesn't use any external CSS resources.