apps/v4/content/docs/components/radix/context-menu.mdx
<ComponentPreview styleName="radix-nova" name="context-menu-demo" description="A context menu with sub menu items." />
npx shadcn@latest add context-menu
<Step>Install the following dependencies:</Step>
npm install radix-ui
<Step>Copy and paste the following code into your project.</Step>
<ComponentSource name="context-menu" title="components/ui/context-menu.tsx" styleName="radix-nova" />
<Step>Update the import paths to match your project setup.</Step>
</Steps> </TabsContent> </CodeTabs>import {
ContextMenu,
ContextMenuContent,
ContextMenuItem,
ContextMenuTrigger,
} from "@/components/ui/context-menu"
<ContextMenu>
<ContextMenuTrigger>Right click here</ContextMenuTrigger>
<ContextMenuContent>
<ContextMenuItem>Profile</ContextMenuItem>
<ContextMenuItem>Billing</ContextMenuItem>
<ContextMenuItem>Team</ContextMenuItem>
<ContextMenuItem>Subscription</ContextMenuItem>
</ContextMenuContent>
</ContextMenu>
A simple context menu with a few actions.
<ComponentPreview styleName="radix-nova" name="context-menu-basic" />Use ContextMenuSub to nest secondary actions.
Add ContextMenuShortcut to show keyboard hints.
Group related actions and separate them with dividers.
<ComponentPreview styleName="radix-nova" name="context-menu-groups" />Combine icons with labels for quick scanning.
<ComponentPreview styleName="radix-nova" name="context-menu-icons" />Use ContextMenuCheckboxItem for toggles.
Use ContextMenuRadioItem for exclusive choices.
Use variant="destructive" to style the menu item as destructive.
To enable RTL support in shadcn/ui, see the RTL configuration guide.
<ComponentPreview styleName="radix-nova" name="context-menu-rtl" direction="rtl" />
See the Radix UI documentation for more information.