RichTreeView API
API reference docs for the React RichTreeView component. Learn about the props, CSS, and other APIs of this exported module.
Demos
Import
import { RichTreeView } from '@mui/x-tree-view/RichTreeView';
// or
import { RichTreeView } from '@mui/x-tree-view';Learn about the difference by reading this guide on minimizing bundle size.
Props of the native component are also available.
| Name | Type | Default | Description | 
|---|---|---|---|
| apiRef | { current?: { focusItem?: func, getItem?: func, getItemDOMElement?: func, getItemOrderedChildrenIds?: func, getItemTree?: func, getParentId?: func, isItemExpanded?: func, setEditedItem?: func, setIsItemDisabled?: func, setItemExpansion?: func, setItemSelection?: func, updateItemLabel?: func } } | - | The ref object that allows Tree View manipulation. Can be instantiated with  | 
| checkboxSelection | bool | false | If  | 
| classes | object | - | Override or extend the styles applied to the component. See CSS classes API below for more details. | 
| defaultExpandedItems | Array<string> | [] | Expanded item ids. Used when the item's expansion is not controlled. | 
| defaultSelectedItems | any | [] | Selected item ids. (Uncontrolled) When  | 
| disabledItemsFocusable | bool | false | If  | 
| disableSelection | bool | false | If  | 
| expandedItems | Array<string> | - | Expanded item ids. Used when the item's expansion is controlled. | 
| expansionTrigger | 'content' | 'iconContainer' | 'content' | The slot that triggers the item's expansion when clicked. | 
| getItemChildren | func | (item) => item.children | Used to determine the children of a given item. Signature: function(item: R) => Array
 | 
| getItemId | func | (item) => item.id | Used to determine the id of a given item. Signature: function(item: R) => string
 | 
| getItemLabel | func | (item) => item.label | Used to determine the string label for a given item. Signature: function(item: R) => string
 | 
| id | string | - | This prop is used to help implement the accessibility logic. If you don't provide this prop. It falls back to a randomly generated id. | 
| isItemDisabled | func | - | Used to determine if a given item should be disabled. Signature: function(item: R) => boolean
 | 
| isItemEditable | func | bool | () => false | Determine if a given item can be edited. | 
| itemChildrenIndentation | number | string | 12px | Horizontal indentation between an item and its children. Examples: 24, "24px", "2rem", "2em". | 
| multiSelect | bool | false | If  | 
| onExpandedItemsChange | func | - | Callback fired when Tree Items are expanded/collapsed. Signature: function(event: React.SyntheticEvent, itemIds: array) => void
 | 
| onItemClick | func | - | Callback fired when the  Signature: function(event: React.MouseEvent, itemId: string) => void
 | 
| onItemExpansionToggle | func | - | Callback fired when a Tree Item is expanded or collapsed. Signature: function(event: React.SyntheticEvent | null, itemId: array, isExpanded: array) => void
 | 
| onItemFocus | func | - | Callback fired when a given Tree Item is focused. Signature: function(event: React.SyntheticEvent | null, itemId: string) => void
 | 
| onItemLabelChange | func | - | Callback fired when the label of an item changes. Signature: function(itemId: TreeViewItemId, newLabel: string) => void
 | 
| onItemSelectionToggle | func | - | Callback fired when a Tree Item is selected or deselected. Signature: function(event: React.SyntheticEvent, itemId: array, isSelected: array) => void
 | 
| onSelectedItemsChange | func | - | Callback fired when Tree Items are selected/deselected. Signature: function(event: React.SyntheticEvent, itemIds: Array
 | 
| selectedItems | any | - | Selected item ids. (Controlled) When  | 
| selectionPropagation | { descendants?: bool, parents?: bool } | { parents: false, descendants: false } | When  | 
| slotProps | object | {} | The props used for each component slot. | 
| slots | object | {} | Overridable component slots. See Slots API below for more details. | 
| sx | Array<func | object | bool> | func | object | - | The system prop that allows defining system overrides as well as additional CSS styles. See the `sx` page for more details. | 
ref is forwarded to the root element.Theme default props
You can use MuiRichTreeView to change the default props of this component with the theme.
| Slot name | Class name | Default component | Description | 
|---|---|---|---|
| root | .MuiRichTreeView-root | RichTreeViewRoot | Element rendered at the root. | 
| collapseIcon | The default icon used to collapse the item. | ||
| expandIcon | The default icon used to expand the item. | ||
| endIcon | The default icon displayed next to an end item. This is applied to all Tree Items and can be overridden by the TreeItem iconslot prop. | ||
| item | .MuiRichTreeView-item | TreeItem. | Custom component to render a Tree Item. | 
These class names are useful for styling with CSS. They are applied to the component's slots when specific states are triggered.
| Class name | Rule name | Description | 
|---|---|---|
| .MuiRichTreeView-itemCheckbox | itemCheckbox | Styles applied to the item's checkbox element. | 
| .MuiRichTreeView-itemContent | itemContent | Styles applied to the item's content element. | 
| .MuiRichTreeView-itemGroupTransition | itemGroupTransition | Styles applied to the item's transition element. | 
| .MuiRichTreeView-itemIconContainer | itemIconContainer | Styles applied to the item's icon container element icon. | 
| .MuiRichTreeView-itemLabel | itemLabel | Styles applied to the item's label element. | 
| .MuiRichTreeView-itemLabelInput | itemLabelInput | Styles applied to the item's label input element (visible only when editing is enabled). | 
You can override the style of the component using one of these customization options:
- With a global class name.
- With a rule name as part of the component's styleOverridesproperty in a custom theme.
Source code
If you did not find the information in this page, consider having a look at the implementation of the component for more detail.