Charts - Sankey 🧪
Sankey charts are great for visualizing flows between different elements.
Basics
The Sankey chart requires a specific data structure with two main parts: nodes and links.
- The nodesarray is optional but allows the customization of individual nodes.
- The linksarray defines the connections between nodes and must specifysource,target, andvalue.
Automatic nodes
If a node is referenced in links but not defined in the nodes array, it is automatically created with the ID as the label.
Explicit nodes
When an explicit node definition is provided, it allows customizing labels and colors for each node.
import { Unstable_SankeyChart as SankeyChart } from '@mui/x-charts-pro/SankeyChart';
<SankeyChart
  height={300}
  series={{
    data: {
      // ... your data
    },
    nodeOptions: {
      color: '#1976d2',
      width: 15,
      padding: 10,
      showLabels: true,
    },
  }}
/>Playground
Default link styles
Default styles can be applied to all links using the linkOptions prop:
import { Unstable_SankeyChart as SankeyChart } from '@mui/x-charts-pro/SankeyChart';
<SankeyChart
  height={300}
  series={{
    data: {
      // ... your data
    },
    linkOptions: {
      color: '#90a4ae',
      opacity: 0.8,
      showValues: true,
    },
  }}
/>Playground
Link color keywords
Link colors can use special keyword values to automatically inherit colors from their connected nodes:
- 'source'- The link inherits the color of its source node
- 'target'- The link inherits the color of its target node
This feature works for both individual link colors and the default link color in linkOptions:
import { Unstable_SankeyChart as SankeyChart } from '@mui/x-charts-pro/SankeyChart';
<SankeyChart
  height={300}
  series={{
    data,
    linkOptions: {
      color: 'source',
      opacity: 0.6,
    },
  }}
/>Playground
Node alignment
The node alignment determines how nodes are positioned within the Sankey chart. The layout follows these principles:
- Nodes are grouped into columns based on the graph structure
- Source nodes always appear to the left of their target nodes
- Some nodes have fixed positions (determined by the graph topology), while others can be positioned more flexibly (affected by alignment)
For example, in the demonstration below:
- Nodes A, B, D, G, I, and K have fixed positions because moving them would require creating a new column
- Node E can be placed in either the first or second column
- Node F is flexible and can be positioned in columns 4, 5, or 6
Left
Right
Justify
Center
Curve correction
The curveCorrection prop adjusts the look of the links between nodes by modifying the x-coordinate of the control points in the curve function.
In some instances, this creates better-looking connections but is dependent on the graph layout, and is especially impacted by the chart height.
Higher values create plumper links, while lower values create thinner connections. The default value is 10.
Curve Correction: 10
Value formatting
You can customize how values are displayed in tooltips and labels using the valueFormatter prop.
This function receives the numeric value and a context object that provides information about what type of element is being formatted.
The context object contains:
- location: either- 'tooltip'or- 'label'to indicate where the formatted value is used
- type: either- 'node'or- 'link'to indicate what is being formatted
- nodeId: for nodes, the ID of the node being formatted
- sourceIdand- targetId: for links, the IDs of the source and target nodes
In the following demo, the value formatter adds relevant units to the values. And when pointer is on top of a node, it display "total" to the tooltip.
Sorting
Nodes are displayed in the same order as they are defined in the nodes array.
If a nodes array isn't provided, nodes are rendered according to the order in which they are referenced in the links array.
To dynamically customize the order, use the sorting functions for the element that needs sorting.
Node sorting
The nodeOptions.sort function allows control of the vertical order of nodes within each column.
It receives two SankeyLayoutNode objects and should return a number (similar to Array.sort()).
Default Node Order
Nodes Sorted Alphabetically
Link sorting
The linkOptions.sort function allows control of the order of links emanating from each node.
It receives two SankeyLayoutLink objects and should return a number.
Default Link Order
Links Sorted by Value
Layout iterations
The iterations prop controls how many times the layout algorithm runs to optimize node positioning. More iterations generally result in better layouts but take longer to compute.
import { Unstable_SankeyChart as SankeyChart } from '@mui/x-charts-pro/SankeyChart';
<SankeyChart
  height={400}
  series={{
    data: {
      // ... your data
    },
    iterations: 32,
  }}
/>Playground
Interaction
Click event
You can use the onNodeClick and onLinkClick props to handle click events on both nodes and links in the Sankey chart. The callback receives the mouse event and a SankeyNodeIdentifierWithData or SankeyLinkIdentifierWithData respectively, both of which contain information about the clicked item.
The SankeyItemIdentifierWithData type is a union of SankeyNodeIdentifierWithData and SankeyLinkIdentifierWithData, allowing you to handle both types of items in a single callback if needed.
Click on the chart
// Data from item click
// The data will appear hereTooltip
The Sankey chart has an item tooltip that can be customized as described in the Tooltip documentation page.
The only difference of the Sankey Tooltip is its default content. You can import the default tooltip, or only its content as follows:
import { SankeyTooltip, SankeyTooltipContent } from '@mui/x-charts/SankeyChart',
API
See the documentation below for a complete reference to all of the props and classes available to the components mentioned here.