React ChartsCreate a Basic Chart

Learn the key concepts of AG Charts by building a basic combination chart and applying styling & formatting

Get Started thumbnail

Overview

In this tutorial you will:

  1. Create a Simple Bar chart
  2. Add an additional Line Series to the Bar Series
  3. Style the chart with Themes, titles, Legend, and formatted data
  4. Format the axes

By the end of this tutorial, you will have a Line and Bar combination chart, with a Legend, title and formatted values. Try it out for yourself by hovering elements to display tooltips, or toggling series visibility by clicking the Legend elements in the example below.

Chart Basics

Complete our Quick Start (or open the example below in Plunker) to start with a basic chart, comprised of:

  • Chart Options: Object which contains the chart configuration options, including data, and series properties:
    • Data: The data to display within a chart (typically an array of data-points).
    • Series: The type of chart to display, and the data to use. For cartesian charts, a minimum of three properties are required:
      • Type: Defines the type of chart to display (e.g. Line, Bar, etc...).
      • xKey: The data to use for the X axis.
      • yKey: The data to use for the Y axis.

Putting these things together creates a basic chart.

Combination Charts

A chart can have more than one series, which can be useful when comparing datasets. To add another series to the chart, simply add another object to the series array, referencing the data to use.

const [chartOptions, setChartOptions] = useState({
    series: [
        { type: 'bar', xKey: 'month', yKey: 'iceCreamSales' }, // Existing 'Bar' Series, using 'iceCreamSales' data-points
        { type: 'line', xKey: 'month', yKey: 'avgTemp' }, // Additional 'Line' Series, using 'avgTemp' data-points
    ],
    // ...
});

Running the chart at this point will show the two series in the same chart.

Configuring Secondary Axes

The chart above shows both series in a single chart, but given that the data-sets are quite different, it would make more sense to have a secondary axis for the second series. To do this, we need to configure three Axes: bottom, left and right.

const [chartOptions, setChartOptions] = useState({
    axes: [
        { type: 'category', position: 'bottom' },
        { type: 'number', position: 'left', keys: ['iceCreamSales'] },
        { type: 'number', position: 'right', keys: ['avgTemp'] },
    ],
    // ...
});

Let's breakdown what's happening here:

  • Type: The type of axis to use - one of Category, Number, Time or Log.
  • Position: The position on the chart where the axis should be rendered, e.g. 'top', 'bottom', 'right' or 'left'.
  • Keys: Associates the axis with a given series, with the keys axis property linking the appropriate series to the axis.

Now when we run our chart, we should see both series and three axes.

Styling

Now we have a chart complete with multiple series and axes, the last thing to do is style the chart.

Titles

Titles and subtitles can also be added to the chart via the title and subtitle properties.

const [chartOptions, setChartOptions] = useState({
    title: { text: 'Ice Cream Sales' },
    subtitle: { text: 'Data from 2022' },
    // ...
});

Note: Refer to the title and subtitle API docs for a full list of properties that can be configured

Legend

You may have noticed that the chart added a Legend when we added a second series to our chart. We can configure the Legend using the legend property, including adjusting its size and position.

const [chartOptions, setChartOptions] = useState({
    legend: {
        position: 'right',
    },
    // ...
});

We should now see the Legend displayed on the right hand side of the chart, rather than underneath it.

Note: Refer to the Legend docs for more info

Renaming Series

As you can see, our Legend and Tooltips use the property name from the data directly. We can show something more human readable by adding the yName property to our series.

const [chartOptions, setChartOptions] = useState({
    series: [
        { type: 'bar', xKey: 'month', yKey: 'iceCreamSales', yName: 'Ice Cream Sales' },
        // ...
    ],
    // ...
});

Now we should see our Legend and Tooltips using the yName value as opposed to the yKey.

Formatting Axes

The last thing to do is format our axes labels to make the chart more readable. We can do this by using a formatter on the label property of the axis.

The formatter should be a function that receives the axis label data and returns a String to display. For example, we can format our right axes to include ' °C' with the following function:

const [chartOptions, setChartOptions] = useState({
    axes: [
        // ...
        {
            type: 'number',
            position: 'right',
            keys: ['avgTemp'],
            label: {
                // Label value as a formatter function
                formatter: (params) => {
                    return params.value + ' °C';
                },
            },
        },
    ],
    // ...
});

Now our chart should display formatted temperature values on the right axis.

Note: Refer to the axes API docs for a full list of properties that can be configured

Test your Knowledge

  1. Format the left axis using toLocaleString()

    Hint: Add a formatter to the axes.label property

  2. Change the 'avgTemp' legend item label to 'Average Temperature (°C)'.

    Hint: use the yName property on the 'avgTemp' series

If you're stuck, check the source code of the example.

Summary

Congratulations, you've completed our introductory tutorial! By now, you should be familiar with a few key concepts of AG Charts:

  • Chart Options: Object which contains all of the configuration options for the chart.
  • Data: The data to be displayed within the chart.
  • Series: Controls the chart type (series) and links it to the data. Multiple series can be used to create combination charts.
  • Axes: Controls the Axes and links it to the data.
  • Styling & Formatting: Controls the look and feel of the chart through formatters and series properties, etc...