Overview
A context menu is displayed when the user right-clicks or long-presses on a trigger element, providing contextual actions.Features
- Supports submenus with configurable reading direction
- Supports items, labels, groups of items
- Supports checkable items (single or multiple)
- Customize side, alignment, offsets, collision handling
- Focus is fully managed
- Full keyboard navigation
- Typeahead support
- Optional modal or non-modal mode
Installation
Anatomy
Import all parts and piece them together.API Reference
Root
Contains all the parts of a context menu.Event handler called when the open state of the context menu changes.
The reading direction of submenus when applicable. If omitted, inherits globally from DirectionProvider or assumes LTR (left-to-right) reading mode.
The modality of the context menu. When set to
true, interaction with outside elements will be disabled and only menu content will be visible to screen readers.Trigger
The area that opens the context menu. Wrap it around the target you want the context menu to open from when right-clicking.Change the default rendered element for the one passed as a child, merging their props and behavior.
When
true, the context menu won’t open and will show the browser’s default context menu.Portal
When used, portals the content part into thebody.
Specify a container element to portal the content into.
Used to force mounting when more control is needed. Useful when controlling animation with React animation libraries.
Content
The component that pops out when the context menu is open.Change the default rendered element for the one passed as a child, merging their props and behavior.
When
true, keyboard navigation will loop from last item to first, and vice versa.Event handler called when focus moves back to the trigger after closing. It can be prevented by calling
event.preventDefault.Event handler called when the escape key is down. It can be prevented by calling
event.preventDefault.Event handler called when a pointer event occurs outside the bounds of the component. It can be prevented by calling
event.preventDefault.Event handler called when an interaction happens outside the bounds of the component. It can be prevented by calling
event.preventDefault.Item
The component that contains the context menu items.Change the default rendered element for the one passed as a child, merging their props and behavior.
When
true, prevents the user from interacting with the item.Event handler called when the user selects an item (via mouse or keyboard). Calling
event.preventDefault in this handler will prevent the context menu from closing when selecting that item.Optional text used for typeahead purposes. By default, the typeahead behavior will use the
.textContent of the item. Use this when the content is complex, or you have non-textual content inside.Group
Used to group multiple items. Use in conjunction withContextMenu.Label to ensure good accessibility via automatic labelling.
Change the default rendered element for the one passed as a child, merging their props and behavior.
Label
Used to render a label. It won’t be focusable using arrow keys.Change the default rendered element for the one passed as a child, merging their props and behavior.
CheckboxItem
An item that can be controlled and rendered like a checkbox.Change the default rendered element for the one passed as a child, merging their props and behavior.
The controlled checked state of the item. Must be used in conjunction with
onCheckedChange.Event handler called when the checked state changes.
When
true, prevents the user from interacting with the item.Event handler called when the user selects an item (via mouse or keyboard). Calling
event.preventDefault in this handler will prevent the context menu from closing when selecting that item.Optional text used for typeahead purposes.
RadioGroup
Used to group multipleContextMenu.RadioItems.
Change the default rendered element for the one passed as a child, merging their props and behavior.
The value of the selected item in the group.
Event handler called when the value changes.
RadioItem
An item that can be controlled and rendered like a radio.Change the default rendered element for the one passed as a child, merging their props and behavior.
The unique value of the item.
When
true, prevents the user from interacting with the item.Event handler called when the user selects an item (via mouse or keyboard).
Optional text used for typeahead purposes.
ItemIndicator
Renders when the parentContextMenu.CheckboxItem or ContextMenu.RadioItem is checked. You can style this element directly, or you can use it as a wrapper to put an icon into, or both.
Change the default rendered element for the one passed as a child, merging their props and behavior.
Used to force mounting when more control is needed. Useful when controlling animation with React animation libraries.
Separator
Used to visually separate items in the context menu.Change the default rendered element for the one passed as a child, merging their props and behavior.
Sub
Contains all the parts of a submenu.The controlled open state of the submenu. Must be used in conjunction with
onOpenChange.The open state of the submenu when it is initially rendered. Use when you do not need to control its open state.
Event handler called when the open state of the submenu changes.
SubTrigger
An item that opens a submenu. Must be rendered insideContextMenu.Sub.
Change the default rendered element for the one passed as a child, merging their props and behavior.
When
true, prevents the user from interacting with the item.Optional text used for typeahead purposes.
SubContent
The component that pops out when a submenu is open. Must be rendered insideContextMenu.Sub.
Change the default rendered element for the one passed as a child, merging their props and behavior.
When
true, keyboard navigation will loop from last item to first, and vice versa.Event handler called when the escape key is down.
Event handler called when a pointer event occurs outside the bounds of the component.
Arrow
An optional arrow element to render alongside the context menu.Change the default rendered element for the one passed as a child, merging their props and behavior.
The width of the arrow in pixels.
The height of the arrow in pixels.
Example
Accessibility
Adheres to the Menu WAI-ARIA design pattern and uses roving tabindex to manage focus movement among menu items.Keyboard Interactions
Space- Activates the focused itemEnter- Activates the focused itemArrowDown- Moves focus to the next itemArrowUp- Moves focus to the previous itemArrowRight- Opens a submenu or moves focus to the next item in a submenuArrowLeft- Closes a submenu or moves to the parent menuEsc- Closes the context menu