Chart.js/samples/charts/multi-series-pie.html

98 lines
2.6 KiB
HTML
Raw Normal View History

2020-01-06 21:04:41 +01:00
<!doctype html>
<html>
<head>
<title>Multi Series Pie Chart</title>
<script src="../../dist/chart.js"></script>
2020-01-06 21:04:41 +01:00
<script src="../utils.js"></script>
</head>
<body>
<div id="canvas-holder" style="width:40%">
<canvas id="chart-area"></canvas>
</div>
<script>
var ctx = document.getElementById('chart-area');
new Chart(ctx, {
type: 'pie',
data: {
labels: [
'Overall Yay',
'Overall Nay',
'Group A Yay',
'Group A Nay',
'Group B Yay',
'Group B Nay',
'Group C Yay',
'Group C Nay'
],
datasets: [
{backgroundColor: ['#AAA', '#777'], data: [21, 79]},
{
backgroundColor: ['hsl(0, 100%, 60%)', 'hsl(0, 100%, 35%)'],
data: [33, 67]
},
{
backgroundColor: ['hsl(100, 100%, 60%)', 'hsl(100, 100%, 35%)'],
data: [20, 80]
},
{
backgroundColor: ['hsl(180, 100%, 60%)', 'hsl(180, 100%, 35%)'],
data: [10, 90]
}
]
},
options: {
plugins: {
legend: {
labels: {
generateLabels: function(chart) {
// Get the default label list
var original = Chart.overrides.pie.plugins.legend.labels.generateLabels;
var labels = original.call(this, chart);
2020-01-06 21:04:41 +01:00
// Build an array of colors used in the datasets of the chart
var datasetColors = chart.data.datasets.map(function(e) {
return e.backgroundColor;
});
datasetColors = datasetColors.flat();
2020-01-06 21:04:41 +01:00
// Modify the color and hide state of each label
labels.forEach(label => {
// There are twice as many labels as there are datasets. This converts the label index into the corresponding dataset index
label.datasetIndex = (label.index - label.index % 2) / 2;
2020-01-06 21:04:41 +01:00
// The hidden state must match the dataset's hidden state
label.hidden = !chart.isDatasetVisible(label.datasetIndex);
2020-01-06 21:04:41 +01:00
// Change the color to match the dataset
label.fillStyle = datasetColors[label.index];
});
2020-01-06 21:04:41 +01:00
return labels;
}
},
onClick: function(mouseEvent, legendItem, legend) {
// toggle the visibility of the dataset from what it currently is
legend.chart.getDatasetMeta(
legendItem.datasetIndex
).hidden = legend.chart.isDatasetVisible(legendItem.datasetIndex);
legend.chart.update();
2020-01-06 21:04:41 +01:00
}
},
tooltip: {
callbacks: {
label: function(context) {
var labelIndex = (context.datasetIndex * 2) + context.dataIndex;
return context.chart.data.labels[labelIndex] + ': ' + context.formattedValue;
}
2020-01-06 21:04:41 +01:00
}
}
}
}
});
</script>
</body>
</html>