Rich Tree View - Selection
Handle how users can select items.
Single selection
By default, the Tree View allows selecting a single item.
- Data Grid
- Date and Time Pickers
- Charts
- Tree View
Multi selection
Use the multiSelect prop to enable multi-selection.
- Data Grid
- Date and Time Pickers
- Charts
- Tree View
Disable selection
Use the disableSelection prop if you don't want your items to be selectable:
- Data Grid
- Date and Time Pickers
- Charts
- Tree View
Checkbox selection
To activate checkbox selection set checkboxSelection={true}:
- Data Grid
- Date and Time Pickers
- Charts
- Tree View
This is also compatible with multi selection:
- Data Grid
- Date and Time Pickers
- Charts
- Tree View
Controlled selection
Use the selectedItems prop to control the selected items.
You can use the onSelectedItemsChange prop to listen to changes in the selected items and update the prop accordingly.
- Data Grid
- Date and Time Pickers
- Charts
- Tree View
Track item selection change
Use the onItemSelectionToggle prop if you want to react to an item selection change:
No item selection recorded
- Data Grid
- Date and Time Pickers
- Charts
- Tree View
Automatic parents and children selection
By default, selecting a parent item does not select its children. You can override this behavior using the selectionPropagation prop.
Here's how it's structured:
type TreeViewSelectionPropagation = {
  descendants?: boolean; // default: false
  parents?: boolean; // default: false
};
When selectionPropagation.descendants is set to true:
- Selecting a parent selects all its descendants automatically.
- Deselecting a parent deselects all its descendants automatically.
When selectionPropagation.parents is set to true:
- Selecting all the descendants of a parent selects the parent automatically.
- Deselecting a descendant of a selected parent deselects the parent automatically.
The example below demonstrates the usage of the selectionPropagation prop.
- Sarah
- Thomas
- Jennifer
- Michael
- Elizabeth
- William
 
 
Apply propagation on mount
You can use the useApplyPropagationToSelectedItemsOnMount() to apply the selection propagation to your defaultSelectedItems or selectedItems prop.
// Uncontrolled example
const defaultSelectedItems = useApplyPropagationToSelectedItemsOnMount({
  items: props.items,
  selectionPropagation: props.selectedPropagation,
  selectedItems: ['10', '11', '13', '14'],
});
return (
  <RichTreeView
    items={props.items}
    selectionPropagation={props.selectionPropagation}
    defaultSelectedItems={defaultSelectedItems}
  />
);
// Controlled example
const initialSelectedItems = useApplyPropagationToSelectedItemsOnMount({
  items: props.items,
  selectionPropagation: props.selectedPropagation,
  selectedItems: ['10', '11', '13', '14'],
});
const [selectedItems, setSelectedItems] = React.useState(initialSelectedItems);
return (
  <RichTreeView
    items={props.items}
    selectionPropagation={props.selectionPropagation}
    selectedItems={selectedItems}
    onSelectedItemsChange={setSelectedItems}
  />
);
In the example below, only Anna, Michael, Elizabeth, and William are selected in the raw data, their ancestors are added to the defaultSelectedItems prop by the hook:
- Sarah
- Robert
- Karen
- Nancy
- Daniel
- Christopher
- Donald
 
- Anna
 
- Michael
- Elizabeth
- William
 
 
Imperative API
Select or deselect an item
Use the setItemSelection() API method to select or deselect an item:
apiRef.current.setItemSelection({
  // The DOM event that triggered the change
  event,
  // The id of the item to select or deselect
  itemId,
  // If `true`, the other already selected items will remain selected
  // Otherwise, they will be deselected
  // This parameter is only relevant when `multiSelect` is `true`
  keepExistingSelection,
  // If `true` the item will be selected
  // If `false` the item will be deselected
  // If not defined, the item's selection status will be toggled
  shouldBeSelected,
});
- @mui/x-data-grid
- @mui/x-data-grid-pro
 
- Date and Time Pickers
- Charts
- Tree View
You can use the keepExistingSelection property to avoid losing the already selected items when using multiSelect:
- @mui/x-data-grid
- @mui/x-data-grid-pro
 
- Date and Time Pickers
- Charts
- Tree View
API
See the documentation below for a complete reference to all of the props and classes available to the components mentioned here.