Skip to content

Instantly share code, notes, and snippets.

@kacpak
Last active February 25, 2017 20:04
Show Gist options
  • Save kacpak/2e39a69bcb2d4d3c2612d8831d75f6e7 to your computer and use it in GitHub Desktop.
Save kacpak/2e39a69bcb2d4d3c2612d8831d75f6e7 to your computer and use it in GitHub Desktop.
Custom Chart.js demo chart
const originalData = [
{ name: 'Bank 1', balance: -50, currency: 'EUR', date: '2012-12-01', image: '' },
{ name: 'Bank 2', balance: 150, currency: 'EUR', date: '2012-12-13', image: 'data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==' },
{ name: 'Bank 3', balance: 25, currency: 'EUR', date: '2013-02-01', image: '' }
]
const data = {
labels: originalData.map(acc => acc.name),
datasets: [
{
data: originalData.map(acc => acc.balance),
backgroundColor: originalData.map(acc => acc.balance < 0 ? 'red' : 'blue'),
images: originalData.map(acc => acc.image),
dates: originalData.map(acc => acc.date)
}
]
}
const images = originalData.map(acc => {
const img = new Image();
img.src = acc.image;
return img;
});
const logoWidth = 50, logoHeight = 50;
const options = {
maintainAspectRatio: false,
legend: { display: false },
layout: {
padding: { top: logoHeight }
},
onResize: function(chartInstance) {
console.log(chartInstance)
},
scales: {
xAxes: [{ display: false }],
yAxes: [{
paddingTop: 50,
gridLines: {
color: 'transparent',
zeroLineColor: '#ccc'
},
ticks: { display: false }
}]
},
hover: { animationDuration: 0 },
animation: {
duration: 0,
onComplete: drawLabels
},
tooltips: {
displayColors: false,
backgroundColor: '#eee',
titleFontColor: 'black',
titleFontStyle: 'normal',
bodyFontColor: 'black',
bodyFontStyle: 'bold',
footerFontColor: 'black',
footerFontStyle: 'normal',
callbacks: {
title: function(tooltipItem, data) {
const item = tooltipItem[0];
const dataset = data.datasets[item.datasetIndex]
const index = item.index;
const date = dataset.dates[index];
return `${item.xLabel} - ${date}`;
},
label: function(tooltipItem, data) {
return 'customLabel';
},
footer: function(tooltipItem, data) {
return 'and Footer';
}
}
}
}
function drawLabels(chartInstance, animationObject) {
const ctx = this.chart.ctx;
this.data.datasets.forEach(dataset => {
for (let i = 0; i < dataset.data.length; i++) {
const model = dataset._meta[Object.keys(dataset._meta)[0]].data[i]._model;
const img = new Image();
const y = (model.base < model.y ? model.base : model.y) - logoHeight - 10;
img.src = dataset.images[i];
img.onload = () => ctx.drawImage(img, model.x - logoWidth / 2, y, logoWidth, logoHeight);
}
});
}
const myChart = new Chart('chart', {
type: 'bar',
data: data,
options: options
});
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>Chart.js v2 demon</title>
<link rel="stylesheet" href="chartjs03.css">
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.5.0/Chart.bundle.min.js"></script>
<script src="chartjs01.js"></script>
</head>
<body>
<div class="wrapper">
<canvas id="chart"></canvas>
</div>
</body>
</html>
.wrapper {
width: 400px;
height: 400px;
margin: 0 auto;
border: 1px solid black;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment