An ActionList
is a list of items which can be activated or selected. ActionList
is the base component for many of our menu-type components, including DropdownMenu
and ActionMenu
.
Use new version of ActionList with composable API, design updates and accessibility fixes.
Before
<ActionListrole="listbox"items={[{text: 'New file', role: 'option'},{text: 'Copy link', role: 'option'},{text: 'Edit file', role: 'option'},ActionList.Divider,{text: 'Delete file', variant: 'danger', role: 'option'}]}/>
After
<ActionList role="listbox"><ActionList.Item role="option">New file</ActionList.Item><ActionList.Item role="option">Copy link</ActionList.Item><ActionList.Item role="option">Edit file</ActionList.Item><ActionList.Divider /><ActionList.Item variant="danger" role="option">Delete file</ActionList.Item></ActionList>
Or continue using deprecated API:
import {ActionList} from '@primer/react/deprecated'
<ActionListrole="listbox"items={[{text: 'New file', role: 'option'},ActionList.Divider,{text: 'Copy link', role: 'option'},{text: 'Edit file', role: 'option'},{text: 'Delete file', variant: 'danger', role: 'option'}]}/>
<ActionListrole="listbox"groupMetadata={[{groupId: '0'},{groupId: '1', header: {title: 'Live query', variant: 'subtle'}},{groupId: '2', header: {title: 'Layout', variant: 'subtle'}},{groupId: '3'},{groupId: '4'}]}items={[{key: '1', leadingVisual: TypographyIcon, text: 'Rename', groupId: '0', trailingVisual: '⌘R', role: 'option'},{key: '2', leadingVisual: VersionsIcon, text: 'Duplicate', groupId: '0', role: 'option'},{key: '3', leadingVisual: SearchIcon, text: 'repo:github/github', groupId: '1', role: 'option'},{key: '4',leadingVisual: NoteIcon,text: 'Table',description: 'Information-dense table optimized for operations across teams',descriptionVariant: 'block',groupId: '2',role: 'option'},{key: '5',leadingVisual: ProjectIcon,text: 'Board',description: 'Kanban-style board focused on visual states',descriptionVariant: 'block',groupId: '2',role: 'option'},{key: '6',leadingVisual: FilterIcon,text: 'Save sort and filters to current view',disabled: true,groupId: '3',role: 'option'},{key: '7', leadingVisual: FilterIcon, text: 'Save sort and filters to new view', groupId: '3', role: 'option'},{key: '8', leadingVisual: GearIcon, text: 'View settings', groupId: '4', trailingVisual: ArrowRightIcon, role: 'option'}]}/>
<ActionListrole="listbox"items={[{text: 'Vanilla link',role: 'option',renderItem: props => <ActionList.Item as="a" href="/about" {...props} />},{text: 'React Router link',role: 'option',renderItem: props => <ActionList.Item as={ReactRouterLikeLink} to="/about" {...props} />},{text: 'NextJS style',role: 'option',renderItem: props => (<NextJSLikeLink href="/about"><ActionList.Item as="a" {...props} /></NextJSLikeLink>)}]}/>
Name | Type | Default | Description |
---|---|---|---|
items | (ItemProps & Omit<React.ComponentPropsWithoutRef<'div'>, keyof ItemProps>) \| ((Partial<ItemProps> & {renderItem: RenderItemFn}) & {key?: Key}) | undefined | Required. A list of item objects conforming to the ActionList.Item props interface. |
renderItem | (props: ItemProps) => JSX.Element | ActionList.Item | Optional. If defined, each item in items will be passed to this function, allowing for ActionList -wide custom item rendering. |
groupMetadata | GroupProps[] | undefined | Optional. If defined, ActionList will group items into ActionList.Group s separated by ActionList.Divider according to their groupId property. |
showItemDividers | boolean | false | Optional. If true dividers will be displayed above each ActionList.Item which does not follow an ActionList.Header or ActionList.Divider |