Dropdown

Open in Storybook

A menu of actions or options revealed from a toggle.

OverviewUsageCompositionExamplesAccessibilityAPI referencePartsDependenciesDesign guidelines
Loading...

Usage

Dropdown shows a menu of actions or options, revealed from a toggle. Put the trigger in the toggle slot and the menu contents — Dropdown Item elements, optionally organised with a Dropdown Group or nested in a Dropdown Submenu — in the default slot.

Import the parts you need — each import registers its custom element:

Copy code
import "@nordhealth/components/lib/Dropdown"
import "@nordhealth/components/lib/DropdownItem"
import "@nordhealth/components/lib/DropdownGroup"
import "@nordhealth/components/lib/DropdownSubmenu"

Then compose a toggle with its menu:

Composition

A dropdown pairs a toggle with a menu of items, which can be grouped or nested.

Copy code
Dropdown
├── Button            (slot="toggle")
├── DropdownItem
├── DropdownGroup
│   └── DropdownItem
└── DropdownSubmenu
    ├── DropdownItem  (slot="trigger")
    └── DropdownItem
Copy code
<nord-dropdown>
  <nord-button slot="toggle">Menu</nord-button>
  <nord-dropdown-item>Option</nord-dropdown-item>
</nord-dropdown>

Dropdown is the container. The element in the toggle slot opens and closes the menu; size, align, position and always-floating control how the menu is presented.

Dropdown Item is a single action or option. Give it an href to render as a link, or add slot="start" / slot="end" content for icons and adornments.

Dropdown Group clusters related items under an optional heading.

Dropdown Submenu nests a secondary menu. Put the item that opens it in the trigger slot, and the nested items in the default slot.

Examples

Basic

A simple menu of actions.

Grouped items

Use a Dropdown Group with a heading to label a section of the menu.

Nest a secondary menu with a Dropdown Submenu.

With a header

Place fixed content above the scrollable items using the header slot — useful for showing the current account or context the menu acts on.

With messages

Combine dropdown items with Banner messages to surface status or contextual information inside the menu.

Badge as toggle

Any element can act as the trigger via the toggle slot. Here a Badge opens the menu.

Clinic switcher

A real-world pattern: an expanding dropdown in the navigation header that lets the user switch between clinics.

Complex menu

A richer menu combining groups, icons, descriptions and a submenu.

Always floating

By default the dropdown becomes a full-width sheet on small viewports. Add always-floating to keep it as a floating overlay at every viewport size.

Position and alignment

The position attribute places the menu relative to its trigger (block-end, block-start, inline-start, inline-end, or auto), and align (start or end) shifts it along that edge.

Inline size

Constrain the width of the menu with the size and inline-size styling so long items wrap or truncate predictably.

Maximum block size

Cap the height of the menu so long lists scroll inside the dropdown instead of overflowing the viewport.

RTL

Dropdown follows the document or container direction. Toggle the direction to see the layout mirror.

Accessibility

  • The toggle and menu implement the menu-button keyboard pattern: open with Enter / Space, move between items with the arrow keys, and close with Esc.
  • Keep Dropdown Item labels short and action-oriented. Don't place unrelated interactive controls inside the menu.
  • Use a Dropdown for menus and commands — for selecting a form value, use Select or Combobox instead.

API reference

Dropdown

Dropdown menu displays a list of actions or selectable options for a user. Dropdown uses popout component internally to create the overlay functionality.

<nord-dropdown></nord-dropdown>

Props

PropertyAttribute Description TypeDefault
expandexpandControls whether the toggle slot expands to fill the width of its container.booleanfalse
sizesizeThe size of the dropdown. This affects the minimum and maximum inline-size of the dropdown.'s' | 'm' | 'l''m'
alwaysFloatingalways-floatingSet to true to always display the dropdown as a floating overlay, even on smaller viewports.booleanfalse
openopenControls whether the component is open or not.booleanfalse
alignalignSet the alignment in relation to the toggle (or anchor) depending on the position. start will align it to the left of the toggle (or anchor). end will align it to the right of the toggle (or anchor). Setting the position to inline-start or inline-end will switch start and end to the top and bottom respectively.'start' | 'end''start'
positionpositionSet the position in relation to the toggle (or anchor). Options follow logical properties. block-start and block-end referring to top and bottom respectively, inline-start and inline-end referring to left and right respectively. You can also set it to auto for automatic positioning depending on which side has the most space available.'block-end' | 'block-start' | 'inline-start' | 'inline-end' | 'auto''block-end'
sideOffsetside-offsetDistance in pixels from the toggle (or anchor) along the main axis — the gap between the floating element and the side it opens against. Fed into Floating UI's offset middleware as mainAxis. Defaults to 8.number8
alignOffsetalign-offsetOffset in pixels along the alignment axis — slides the floating element toward the start or end of the toggle (or anchor). Fed into Floating UI's offset middleware as alignmentAxis. Defaults to 0.number0

Slots

Slot name Description
Default slotThe dropdown content.
toggleUsed to place the toggle for dropdown.
headerOptional slot that holds a header for the dropdown.
header-endOptional slot that positions content at the end of the header. Useful for actions or additional info.

Methods

Method nameParameters Description
hide(moveFocusToButton?: boolean) => Promise<TransitionEvent | void>moveFocusToButton: A boolean option to move the focus to the original button that opens the dropdown.Hide the dropdown programmatically. This method delegates to the Dropdown's internal Popout component. See Popout's hide() method for more details.
show() => Promise<TransitionEvent | void>N/AShow the dropdown programmatically. This method delegates to the Dropdown's internal Popout component. See Popout's show() method for more details.
EventDetail TypeDescription
openNordEventDispatched when the popout is opened.
closeNordEventDispatched when the popout is closed.

CSS Properties

CSS Custom Properties provide more fine grain control over component presentation. We advise utilizing existing properties on the component before using these.

PropertyDescriptionDefault
--n-dropdown-sizeControls the inline size, or width, of the dropdown. Will resize up to 1.5 times to account for larger content.250px
--n-dropdown-max-block-sizeControls the maximum block size, or height, of the dropdown. Larger content will get a scrollbar.460px

Parts

This component is made up of the following parts.

Design guidelinesFor designers

Usage

This section includes guidelines for designers and developers about the usage of this component in different contexts.

Do

  • Dropdown menus are typically used when you have 5-15 items to choose from. They’re used for navigation or commands, where an action is initiated based on the selection.
  • When organizing dropdown menu items, sort the list in a logical order by putting the most selected option at the top.
  • Use for a “more” menu, where the control contains an icon.
  • Use for user profiles, where the control is an avatar.
  • Use in conjunction with the dropdown item and dropdown group components.

Don’t

  • Don't use for form inputs or selects, use the select component or input component instead.
  • Don't use for hiding primary actions since they should be visible by default.
  • Don't nest elements or components other than the dropdown item and dropdown group components. Consider using the popout component when creating custom UI.
  • Don't use always-floating property for long lists or complex content that benefits from full-screen focus.

Content guidelines

Dropdown items should be always written in sentence case, not title case. The first word should be capitalized and the rest lowercase (unless a proper noun):

Create user
Create User

Dropdown items should always lead with a strong verb that encourages action. Use the {verb}+{noun} format except in the case of common actions like Save, Close or Cancel:

Edit row
Editing options

Avoid unnecessary words and articles in dropdown items, such as “the”, “an” or “a”:

Change theme
Change the theme

Avoid ending dropdown items in punctuation:

Switch user
Switch user.

Avoid all caps for dropdown items:

Rename
RENAME

Keep dropdown items to a single line of text:

Change theme
Change the theme
of the veterinary application.

Additional considerations

  • Consider using the alwaysFloating property for compact dropdown menus that work well in a small floating container.

Was this page helpful?

Yes No

We use this feedback to improve our documentation.