Pickers

Select

A customizable dropdown menu that lets users choose a single option from a predefined list, optimized for accessibility and seamless user interaction.

Loading...

Installation

Install the component via the CLI in one command.

npx shadcn@latest add @intentui/select

Composed components

When you install this component via the CLI, it automatically loads all composed components, so you don’t need to add them individually.

Manual installation

Use this approach if you prefer to install and wire up the component yourself instead of using the CLI.

npm install react-aria-components @heroicons/react tailwind-merge

Anatomy

import {
  Select,
  SelectContent,
  SelectItem,
  SelectTrigger,
} from "@/components/ui/select"
const software = [
  { id: 1, name: "Adobe Photoshop" },
  { id: 2, name: "Sketch" },
  { id: 3, name: "Figma" },
  { id: 4, name: "Adobe XD" },
  { id: 5, name: "InVision" },
]

<Select aria-label="Design software" placeholder="Select a software">
  <SelectTrigger />
  <SelectContent items={software}>
    {(item) => (
      <SelectItem id={item.id} textValue={item.name}>
        {item.name}
      </SelectItem>
    )}
  </SelectContent>
</Select>

Examples

Section

A select component can display items grouped together in sections.

Loading...

Searchable select

Sometimes, you may need to search for an item in a select component. Here's how you can do it.

Loading...

With icon

Loading...

With avatar

Loading...

Multiple select

Enable selecting more than one option by setting selectionMode to multiple.

Loading...

Validation

If a user submits the form without selecting an item, an error message will appear.

Loading...

Label

When the children option is a string, Select.Label will automatically wrap it. However, if the option includes an icon or avatar, you'll need to manually define the wrapper like this:

<SelectItem id="discord" textValue="Discord">
  <BrandDiscordIcon />
  <SelectLabel>Discord</SelectLabel>
</SelectItem>

Details description

If you need to provide more information about an option, use the Description component to display additional details.

Loading...

Controlled

You can control the select component by passing the selectedKey prop.

Loading...

Uncontrolled

You can uncontrolled the select component by passing the defaultSelectedKey prop.

Loading...

Disabled

When the select component is disabled, it cannot be interacted with.

Loading...

Component API

Select

The Select component lets users choose from a list of options.

PropTypeDefault
classNamestring-
itemsIterable<T, M>-

SelectContent

The SelectContent component renders select options inside a popover.

PropTypeDefault
classNamestring-
itemsIterable<T>-
popoverOmit<PopoverProps, "children">-

SelectItem

The SelectItem component represents one select option.

PropTypeDefault
classNamestring-
intent"danger" | "warning"-

SelectLabel

The SelectLabel component renders the primary text for a select option.

PropTypeDefault
classNamestring-

SelectDescription

The SelectDescription component renders supporting text for a select option.

PropTypeDefault
classNamestring-

SelectSection

The SelectSection component groups related select options.

PropTypeDefault
classNamestring-
titlestring-

SelectSeparator

The SelectSeparator component separates select option groups.

PropTypeDefault
classNamestring-

SelectTrigger

The SelectTrigger component opens the select popover and displays the selected value.

PropTypeDefault
classNamestring-
prefixReactNode-

See the React Aria for the full API reference.

Unlock the full power of
Intent UI Design

Build modern web apps faster with 1000+ resources across components, blocks, patterns, templates, and starter kits.

Learn more