Dropdown Menu
Anatomy
Usage
To display a dropdown menu, compose <DropdownMenu>
, <DropdownMenuTrigger>
, <DropdownMenuContent>
, and one or more of <DropdownMenuItem>
.
Checkboxes
To display a multiselect dropdown with checkboxes, use <DropdownMenuCheckboxItem>
instead of <DropdownMenuItem>
.
Radio group
To display a radio button group, use <DropdownMenuRadioItem>
and wrap the items in <DropdownMenuRadioGroup>
.
Submenus
To display a nested menu, compose <DropdownMenuSub>
, <DropdownMenuSubTrigger>
, <DropdownMenuSubContent>
, and one or more of <DropdownMenuItem>
within <DropdownMenuContent>
.
API Reference
Basics
DropdownMenu
Contains all the parts of the menu.
Prop | Type | Default |
---|---|---|
children | ReactNode | |
defaultOpen | boolean | |
dir | "ltr" "rtl" | |
modal | boolean | true |
onOpenChange | (open: boolean) => void | |
open | boolean |
DropdownMenuTrigger
The button that, when clicked, toggles the menu.
Inherits properties from HTMLButtonElement
.
Prop | Type | Default |
---|---|---|
asChild | boolean | false |
children | ReactNode |
DropdownMenuContent
The element that pops out when the menu is open.
Prop | Type | Default |
---|---|---|
align | "start" "center" "end" | "center" |
alignOffset | number | 0 |
arrowPadding | number | 0 |
asChild | boolean | false |
avoidCollisions | boolean | false |
children | ReactNode | |
className | string | |
collisionBoundary | Boundary | [] |
collisionPadding | number | Padding | 0 |
container | HTMLElement | document.body |
forceMount | boolean | |
hideWhenDetached | boolean | false |
isLoading | boolean | |
loop | boolean | false |
onCloseAutoFocus | (event: Event) => void | |
onEscapeKeyDown | (event: KeyboardEvent) => void | |
onFocusOutside | (event: FocusOutsideEvent) => void | |
onInteractOutside | (event: PointerDownOutsideEvent | FocusOutsideEvent) => void | |
onPointerDownOutside | (event: PointerDownOutsideEvent) => void | |
side | "top" "right" "bottom" "left" | "bottom" |
sideOffset | number | 0 |
sticky | "partial" "always" | "center" |
theme | "light" "dark" | "dark" |
DropdownMenuLabel
A non-interactive label to provide a heading for a section of the DropdownMenu.
Prop | Type | Default |
---|---|---|
className | string | |
theme | "light" "dark" | "dark" |
variant | "title" "label" | "label" |
DropdownMenuSeparator
A horizontal line to separate sections within the DropdownMenu.
Prop | Type | Default |
---|---|---|
theme | "light" "dark" |
Items
DropdownMenuGroup
Used to group multiple DropdownMenuItem
s
Prop | Type | Default |
---|---|---|
asChild | boolean | false |
children | ReactNode | |
theme | "light" "dark" |
DropdownMenuItem
A single item within the dropdown menu.
Prop | Type | Default |
---|---|---|
asChild | boolean | false |
avatarProps | React.ComponentProps<typeof Avatar> | |
children | React.ReactNode | |
childrenClassName | string | |
className | string | |
disabled | boolean | |
icon | IconDefinition | |
onSelect | (event: Event) => void | |
shortcutText | string | |
showAvatar | boolean | |
showShortcut | boolean | |
showTag | boolean | |
subtext | string | |
textValue | string | |
theme | "light" "dark" |
Checkboxes
DropdownMenuCheckboxItem
A single checkbox item within the dropdown menu.
Prop | Type | Default |
---|---|---|
asChild | boolean | false |
avatarProps | React.ComponentProps<typeof Avatar> | |
checked | boolean | |
children | React.ReactNode | |
childrenClassName | string | |
className | string | |
disabled | boolean | |
icon | IconDefinition | |
onCheckedChange | (checked: boolean) => void | |
onSelect | (event: Event) => void | |
showAvatar | boolean | |
showTag | boolean | |
subtext | string | |
tagComponent | ReactNode | |
textValue | string | |
theme | "light" "dark" |
Radios
DropdownMenuRadioGroup
Used to group multiple DropdownMenuRadioItem
s
Prop | Type | Default |
---|---|---|
asChild | boolean | false |
children | ReactNode | |
className | string | |
onValueChange | (value: string) => void | |
theme | "light" "dark" | |
value | string |
DropdownMenuRadioItem
A single radio item within the dropdown menu.
Prop | Type | Default |
---|---|---|
asChild | boolean | false |
avatarProps | React.ComponentProps<typeof Avatar> | |
children | React.ReactNode | |
childrenClassName | string | |
className | string | |
disabled | boolean | |
icon | IconDefinition | |
onSelect | (event: Event) => void | |
showAvatar | boolean | |
subtext | string | |
textValue | string | |
theme | "light" "dark" | |
value | string |
Submenus
DropdownMenuSub
Contains all the parts of a sub menu.
Prop | Type | Default |
---|---|---|
children | ReactNode | |
defaultOpen | boolean | |
onOpenChange | (open: boolean) => void | |
open | boolean | |
theme | "light" "dark" |
DropdownMenuSubTrigger
The button that, when clicked, toggles the dropdown sub menu.
Inherits properties from HTMLDivElement
.
Prop | Type | Default |
---|---|---|
asChild | boolean | false |
disabled | boolean | |
icon | IconDefinition | |
textValue | string | |
theme | "light" "dark" |
DropdownMenuSubContent
The element that pops out when sub menu is open.
Prop | Type | Default |
---|---|---|
alignOffset | number | 0 |
arrowPadding | number | 0 |
asChild | boolean | false |
avoidCollisions | boolean | false |
children | ReactNode | |
className | string | |
collisionBoundary | Boundary | [] |
collisionPadding | number | Padding | 0 |
forceMount | boolean | |
hideWhenDetached | boolean | false |
loop | boolean | false |
onEscapeKeyDown | (event: KeyboardEvent) => void | |
onFocusOutside | (event: FocusOutsideEvent) => void | |
onInteractOutside | (event: PointerDownOutsideEvent | FocusOutsideEvent) => void | |
onPointerDownOutside | (event: PointerDownOutsideEvent) => void | |
sideOffset | number | 0 |
sticky | "partial" "always" | "center" |
theme | "light" "dark" | "dark" |
Other
DropdownMenuPortal
When used, portals the content part into the body
.
Prop | Type | Default |
---|---|---|
children | ReactNode | |
container | HTMLElement | document.body |
forceMount | boolean | |
theme | "light" "dark" | "dark" |