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
.
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
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
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)
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.