Skip to content
+

Charts - Tooltip

Tooltip provides extra data on charts item.

In all charts components, the tooltip is accessible via the slot tooltip. If you are using composition, you can use the <ChartsTooltip /> component.

Tooltip trigger

The Tooltip can be triggered by two kinds of events:

  • 'item'—when the user's mouse hovers over an item on the chart, the tooltip displays data about this specific item.
  • 'axis'—the user's mouse position is associated with a value of the x-axis. The tooltip displays data about all series at this specific x value.
  • 'none'—disable the tooltip.

To pass this trigger attribute to the tooltip use slotProps.tooltip.trigger.

Press Enter to start editing

Customization

Formatting

The format of data rendered in the tooltip can be modified thanks to the series valueFormatter property. The same can be applied to x values when a tooltip is triggered by the 'axis'.

Here is a demo with:

  • The time axis is formatted to only show the year
  • The number values are formatted in U.S. Dollars.
  • French GDP per capita
  • German GDP per capita
  • UK GDP per capita
19901992199419961998200020022004200620082010201220142016201825,00030,00035,00040,00045,00050,000
Press Enter to start editing

Advanced formatting

The series valueFormatter provides a context as its second argument containing a dataIndex property which you can use to calculate other data-related values.

In the demo below you can notice we use dataIndex to add each team's rank in the tooltip.

  • Amber Ants
  • Eagle Warriors
  • Elephant Trunk
  • Jaguars
  • Smooth Pandas
Press Enter to start editing

Axis formatter

To modify how data is displayed in the axis use the valueFormatter property.

Its second argument is a context that provides a location property with either 'tick' or 'tooltip'.

In this demo, you can see:

  • The country axis displays only the country code
  • The label displays annotated data Country: name (code)
ATBEBGHRCZDKFIFRDEGRHUIEITNLPLPTROSKESSE01,0002,0003,0004,0005,000GDP (million $USD)
Press Enter to start editing

Label formatting

The label text inside the tooltip can also be formatted conditionally by providing a function to the series label property.

<LineChart
  // ...
  series={[
    {
      data: [ ... ],
      label: (location) => location === 'tooltip' ? 'BR' : 'Brazil'
    }
  ]}
/>

Hiding values

You can hide the axis value with hideTooltip in the xAxis props. It removes the header showing the x-axis value from the tooltip.

<LineChart
  // ...
  xAxis={[{ data: [ ... ], hideTooltip: true }]}
/>

Overriding content

To override tooltip content, provide a custom component to slots.tooltip. Some helper are provided, such as:

  • <ChartsTooltipContainer /> which provide a tooltip with built-in open and position management.
  • useItemTooltip() which provides all basic information associated to the current item.
  • useAxisTooltip() which provides all basic information associated to the current axis.

Here is the basic scheme to follow. Examples about helpers are provided in the composition section.

import { ChartsTooltipContainer } from '@mui/x-charts/ChartsTooltip';

function CustomItemTooltipContent() {
  const tooltipData = useItemTooltip();

  if (!tooltipData) { // No data to display
    return null;
  }

  return <div>{/** Your custom content **/}</div>;
}

<LineChart
  slots={{ tooltip: CustomItemTooltip }}
/>

// With composition
<ChartContainer>
  // ...
  <ChartsTooltipContainer trigger="item">
    <CustomItemTooltipContent />
  </ChartsTooltipContainer>
</ChartContainer>

Overriding placement

To override tooltip placement, override to the tooltip with slots.tooltip. If you want to keep the default content, you can place the ChartsItemTooltipContent or ChartsAxisTooltipContent in your custom tooltip.

Composition

If you're using composition, by default, the axis listens for mouse events to get its current x/y values. If you don't need it, you can disable those listeners with the disableAxisListener prop.

You need those listeners if you are using axes highlight or you have a tooltip triggered by axis.

<ChartContainer {...} disableAxisListener>
  {/* ... */}
</ChartContainer>

Overriding content

Item Tooltip

You can create your own tooltip by using useItemTooltip(). This hook returns the information about the current item user is interacting with. It contains:

  • identifier: An object that identify the item. Which often contains its series type, series id, and data index.
  • color: The color used to display the item. This includes the impact of color map.
  • label, value, formattedValue: Values computed to simplify the tooltip creation.

To follow the mouse position, you can track pointer events on the SVG thanks to useSvgRef.

Axis Tooltip

Like in previous section, you can create your own tooltip by using useAxisTooltip(). This hook returns the information about the current axis user is interacting with and the relevant series. It contains:

  • identifier: An object that identify the axis. Which often contains its series type, series id, and data index.
  • color: The color used to display the item. This includes the impact of color map.
  • label, value, formattedValue: Values computed to simplify the tooltip creation.

To follow the mouse position, you can track pointer events on the SVG thanks to useSvgRef.

Tooltip position

This demo show example about how to use additional hooks such as useXAxis() or useDrawingArea() to customize the tooltip position.

API

See the documentation below for a complete reference to all of the props and classes available to the components mentioned here.