Skip to main content
🏠ComponentsDropdownVersion: 2.0.0-beta.8

Dropdown

The dropdown component is a container for a dropdown-trigger and a dropdown-overlay.

  • dropdown-trigger is the container for a button.
  • dropdown-overlay the togglable container for a menu, hidden by default, with a white background and a shadow.
Dropdown buttonMenu ItemMenu ItemMenu Item
<QtmDropdown>
<QtmDropdownTrigger>
<QtmButton>Dropdown button</QtmButton>
</QtmDropdownTrigger>
<QtmDropdownOverlay>
<QtmMenuItemList>
<QtmMenuItem>
<QtmMenuItemLabel>Menu Item</QtmMenuItemLabel>
</QtmMenuItem>
<QtmMenuItem>
<QtmMenuItemLabel>Menu Item</QtmMenuItemLabel>
</QtmMenuItem>
<QtmMenuItem>
<QtmMenuItemLabel>Menu Item</QtmMenuItemLabel>
</QtmMenuItem>
</QtmMenuItemList>
</QtmDropdownOverlay>
</QtmDropdown>

You are able to implement inside a QtmDropdownOverlay a menu item list, a paragraph or whatever.

Dropdown button

You can insert any type of content within the dropdown overlay.

<QtmDropdown visible>
<QtmDropdownTrigger>
<QtmButton>Dropdown button</QtmButton>
</QtmDropdownTrigger>
<QtmDropdownOverlay>
<QtmTypography component="body-2" classes="p-m"
>You can insert any type of content within the dropdown
overlay.</QtmTypography
>
</QtmDropdownOverlay>
</QtmDropdown>

Visible

You can use visible attribute to display dropdown-overlay.

Dropdown buttonMenu Item
<QtmDropdown visible> ... </QtmDropdown>

Placement

You can set top-center, top-right, top-left, bottom-center, bottom-right and bottom-left to placement property to place the dropdown overlay. By default the placement is bottom-left.

Left aligned

The dropdown is bottom left aligned.

<QtmDropdown visible placement="bottom-left"> ... </QtmDropdown>
Center aligned

The dropdown is center left aligned.

<QtmDropdown visible placement="bottom-center"> ... </QtmDropdown>
Right aligned

The dropdown is bottom right aligned.

<QtmDropdown visible placement="bottom-right"> ... </QtmDropdown>
Top left aligned

The dropdown is top left aligned.

<QtmDropdown visible placement="top-left"> ... </QtmDropdown>
Top center aligned

The dropdown is top center aligned.

<QtmDropdown visible placement="top-center"> ... </QtmDropdown>
Top right aligned

The dropdown is top right aligned.

<QtmDropdown visible placement="top-right"> ... </QtmDropdown>

Customize style

Add your own classes in the classes attribute. This way you will be able to override or extend the styles applied to the component (you can use available utility classes by importing @qtm/css/dist/utilities.css).

API

QtmDropdown

PropertyTypeDefaultDescription
classesstringlist of classes to override or extend the styles applied to the component. You can use available utility classes by importing
disabledbooleanfalseIf true, the component is disabled.
placement"bottom-center" | "bottom-left" | "bottom-right" | "top-center" | "top-left" | "top-right"Placement of dropdown overlay
visiblebooleanfalseIf true, the dropdown overlay is opened
EventTypeDescription
onClickOutsideCustomEvent<void>Callback fired when the dropdown overlay is closed.
onVisibleChangeCustomEvent<DropdownVisibleData>Callback fired when the dropdown trigger is clicked. function(event: object) => void

QtmDropdownTrigger

PropertyTypeDefaultDescription
classesstringlist of classes to override or extend the styles applied to the component. You can use available utility classes by importing
disabledbooleanfalseIf true, the dropdown trigger is disabled does not emit a trigger event.
EventTypeDescription
onTriggerEventCustomEvent<void>Callback fired when the dropdown trigger is clicked.

QtmDropdownOverlay

PropertyTypeDefaultDescription
classesstringlist of classes to override or extend the styles applied to the component. You can use available utility classes by importing