Skip to main contentCarbon Design System

Get started

Carbon charts help you tell accurate and convincing stories around data with beautiful and accessible visualizations.

Resources

Carbon Charts Vanilla library

The library provides a collection of reusable charting components to build websites and user interfaces. Adopting the library enables developers to use consistent markup, styles, and behavior in prototype and production work.

Install

If using yarn:
$ yarn add @carbon/charts d3
If you prefer npm:
$ npm install --save @carbon/charts d3

Getting started

If consuming through a bundler (e.g. webpack):
index.html
...
<div id="my-bar-chart"></div>
...
index.js
import '@carbon/charts/styles.css';
import { StackedBarChart } from '@carbon/charts';
// grab chart holder DOM element
const chartHolder = document.getElementById('my-bar-chart');
// initialize the chart
new StackedBarChart(chartHolder, {
data: stackedBarData,
options: stackedBarOptions,
});
If consuming in a browser environment (e.g. through CDNs):
index.html
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://unpkg.com/@carbon/charts/styles.css" />
</head>
<body>
<div id="my-bar-chart"></div>
<script src="https://unpkg.com/@carbon/charts/bundle.js"></script>
<script>
// grab chart holder DOM element
const chartHolder = document.getElementById('my-bar-chart');
const stackedBarData = {
// ...see next section
};
const stackedBarOptions = {
// ...see next section
};
// initialize the chart
new Charts.StackedBarChart(chartHolder, {
data: stackedBarData,
options: stackedBarOptions,
});
</script>
</body>
</html>

Data and options

Data and options follow the same model in all charts, with minor exceptions and differences in specific components.

For instance, in the case of pie and donut charts, you would only provide one data set. In the case of donut charts, you can pass in an additional field called center in your options configuring the donut center.

There are also additional options available depending on the chart type being used, for more examples please see here.

Below are sample data and options that can be used in a stacked bar chart:

const stackedBarData = {
labels: ['Quantity', 'Leads', 'Sold', 'Restocking', 'Misc'],
datasets: [
{
label: 'Dataset 1',
data: [65000, 29123, 35213, 51213, 16932],
},
{
label: 'Dataset 2',
data: [32432, 21312, 56456, 21312, 34234],
},
{
label: 'Dataset 3',
data: [12312, 23232, 34232, 12312, 34234],
},
],
};
const stackedBarOptions = {
title: 'Stacked bar (discrete)',
axes: {
left: {
primary: true,
stacked: true,
},
bottom: {
scaleType: 'labels',
secondary: true,
},
},
height: '400px',
};

Demos and Examples

Development

Please refer to the Contribution Guidelines before starting any work.

Using the server

We recommend the use of Webpack Dev Server for developing components.

Start the server
cd packages/core
yarn run demo:server

Open browser to http://localhost:9001/.

List of available components

View available components here.

Troubleshooting

If you experience any issues while getting set up with Carbon Charts, please head over to the GitHub repo for more guidelines and support. Please create an issue if your issue does not already exist.