Command Menu
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
import { matchSorter } from "match-sorter";import { useMemo, useState } from "react";import {CommandMenu,CommandMenuGroup,CommandMenuInput,CommandMenuItem,CommandMenuList,} from "./command-menu.tsx";import { allItems, applications, commands, suggestions } from "./commands.tsx";import "./style.css";function search(value: string): Record<string, Command[]> {if (!value) {return {Suggestions: suggestions,Commands: commands.filter((item) => !suggestions.includes(item)),Apps: applications.filter((item) => !suggestions.includes(item)),};}const keys = ["name", "title"];const results = matchSorter(allItems, value, { keys });if (!results.length) return {};return { Results: results };}export default function Example() {const [open, setOpen] = useState(false);const [searchValue, setSearchValue] = useState("");const matches = useMemo(() => search(searchValue), [searchValue]);const matchEntries = Object.entries(matches);return (<>Open Command Menu<CommandMenuaria-label="Command Menu"open={open}onOpenChange={setOpen}onSearch={setSearchValue}><CommandMenuInput placeholder="Search for apps and commands..." /><CommandMenuList>{!matchEntries.length && (<div className="no-results">No results found</div>)}{matchEntries.map(([group, items]) => (<CommandMenuGroup key={group} label={group}>{items.map((item) => (<CommandMenuItem key={item.name} id={item.name}>{item.icon && (<span className="item-icon" aria-hidden>{item.icon}</span>)}{item.title}{item.extension?.title && (<span className="item-group" aria-hidden>{item.extension?.title}</span>)}<span className="item-type" aria-hidden>{item.extension ? "Command" : "Application"}</span></CommandMenuItem>))}</CommandMenuGroup>))}</CommandMenuList></CommandMenu></>);}import { matchSorter } from "match-sorter";import { useMemo, useState } from "react";import {CommandMenu,CommandMenuGroup,CommandMenuInput,CommandMenuItem,CommandMenuList,} from "./command-menu.tsx";import { allItems, applications, commands, suggestions } from "./commands.tsx";import "./style.css";function search(value: string): Record<string, Command[]> {if (!value) {return {Suggestions: suggestions,Commands: commands.filter((item) => !suggestions.includes(item)),Apps: applications.filter((item) => !suggestions.includes(item)),};}const keys = ["name", "title"];const results = matchSorter(allItems, value, { keys });if (!results.length) return {};return { Results: results };}export default function Example() {const [open, setOpen] = useState(false);const [searchValue, setSearchValue] = useState("");const matches = useMemo(() => search(searchValue), [searchValue]);const matchEntries = Object.entries(matches);return (<>Open Command Menu<CommandMenuaria-label="Command Menu"open={open}onOpenChange={setOpen}onSearch={setSearchValue}><CommandMenuInput placeholder="Search for apps and commands..." /><CommandMenuList>{!matchEntries.length && (<div className="no-results">No results found</div>)}{matchEntries.map(([group, items]) => (<CommandMenuGroup key={group} label={group}>{items.map((item) => (<CommandMenuItem key={item.name} id={item.name}>{item.icon && (<span className="item-icon" aria-hidden>{item.icon}</span>)}{item.title}{item.extension?.title && (<span className="item-group" aria-hidden>{item.extension?.title}</span>)}<span className="item-type" aria-hidden>{item.extension ? "Command" : "Application"}</span></CommandMenuItem>))}</CommandMenuGroup>))}</CommandMenuList></CommandMenu></>);}
Related examples
data:image/s3,"s3://crabby-images/05d15/05d1508a9882aa6428561b450051ff355b2f55d5" alt=""
data:image/s3,"s3://crabby-images/b477b/b477bc8b414c62b0ca0a0dbb9b51d99718c596ac" alt=""
Command Menu with TabsCombining Dialog, Tab, and Combobox from Ariakit React to build a command palette component.
data:image/s3,"s3://crabby-images/1dd70/1dd7014c5581cadf225fc40f7f2631fe265a5c1b" alt=""
data:image/s3,"s3://crabby-images/3aef7/3aef7f7abf8b5cf595b69f9152a4b74fdcc2169d" alt=""
Combobox with linksUsing a Combobox with items rendered as links that can be clicked with keyboard and mouse. This is useful for creating an accessible page search input in React.
data:image/s3,"s3://crabby-images/57fe8/57fe89aeaf3677003ed8b03b47e8b608b64d24fe" alt=""
data:image/s3,"s3://crabby-images/f9d1e/f9d1e6cb1c1b81aeb75171d14e226b4006d0ad63" alt=""
Combobox filteringListing suggestions in a Combobox component based on the input value using React.startTransition to ensure the UI remains responsive during typing.
data:image/s3,"s3://crabby-images/e1854/e1854b7f044cd165b4d51101016e3865d4bad070" alt=""
data:image/s3,"s3://crabby-images/3b8fc/3b8fcd3f5f9d00cbd7756d8cfb748e1c5b46a533" alt=""
Combobox with TabsOrganizing Combobox with Tab components that support mouse, keyboard, and screen reader interactions. The UI remains responsive by using React.startTransition.
data:image/s3,"s3://crabby-images/26546/26546092f2517026ec69c4c85867d6289aa085b6" alt=""
data:image/s3,"s3://crabby-images/1ad7d/1ad7d9fb9294772f9f9a36e75751bbaec6ece96f" alt=""
Dialog with MenuShowing a nested dropdown Menu component inside a modal Dialog using React.
data:image/s3,"s3://crabby-images/b5f2a/b5f2ab1185d08f79ffe4ee5c0b832f71959207cf" alt=""
data:image/s3,"s3://crabby-images/2f5c5/2f5c57c7d7f586e2aeef915a28e48044bea289b2" alt=""
Nested DialogRendering a modal Dialog to confirm an action inside another modal dialog using React.
Menu with ComboboxCombining Menu and Combobox to create a dropdown menu with a search field that can be used to filter menu items.
Select with ComboboxCombining Select and Combobox to create a dropdown with a search field that can be used to filter items.