Usage
Combobox is an autocomplete input that allows users to filter and select one or more values from a list of options.
Best practices
data:image/s3,"s3://crabby-images/cb1a0/cb1a0fd5d8b5e4da2174d737a48c280c8c6be8e2" alt=""
Use labels to describe what the data in the combobox is all about.
data:image/s3,"s3://crabby-images/f5abe/f5abe22dea5c5858111d998bda625fd83a3246b6" alt=""
Do not omit the label, or use a placeholder as a label. The label should be always visible to the user.
data:image/s3,"s3://crabby-images/78d71/78d717470e35575ca4738bcf8350bc1dbb3b2eb6" alt=""
Use combobox for single selection in forms where the list of options is long and filtering options benefits the user.
data:image/s3,"s3://crabby-images/79a58/79a588a731dc9c809b83432dcba3c1716539aed4" alt=""
Avoid using it for short and simple lists of options that do not require filtering. Use the Select instead.
data:image/s3,"s3://crabby-images/8298a/8298a96da9e9fb6d1fda05a1ad00560dcb35dbed" alt=""
Use combobox for multi-selection in forms.
data:image/s3,"s3://crabby-images/1ce39/1ce3971a1fb881ce8e0988977fd6f1b355222c5f" alt=""
Don’t use combobox for actions and filtering purposes e.g. table filters. Use the Popover instead.
Anatomy
Single-select
Leading and trailing icons are placed at the start or end of the dropdown item and, as the icons that are placed in buttons, they should be used consciously.
data:image/s3,"s3://crabby-images/fe850/fe850c59f56f278fbedbcbfcd4e057d94f948162" alt=""
Trigger
Text input that opens the combobox popout when clicked, displaying the available options.
Popout
Container that holds available options.
Option
Item that can be selected by the user. Selection is indicated by check icon placed on the left. Option can be extended with complementary content.
Multi-select
Leading and trailing icons are placed at the start or end of the dropdown item and, as the icons that are placed in buttons, they should be used consciously.
data:image/s3,"s3://crabby-images/68cf4/68cf49ab869eef0841e8a2e86ff1d7baf0867bcb" alt=""
Trigger
Text input that opens the combobox popout when clicked, displaying the available options. The trigger includes a badge that shows the total number of selected options.
Popout
Container that holds available options.
Option
Item that can be selected by the user. Unlike a single-selection combobox, options in this case include a checkbox instead of an icon. This helps users clearly understand that they can select multiple items.
Grouping
Combobox support section dividers and headers for grouping options and adding clarity.
data:image/s3,"s3://crabby-images/67362/6736224cd014c469ed5b229278c5f6f7e712b6ff" alt=""
Combobox Options
Options can include a prefix icon and description, in addition to the label. These provide users with extra information to help them choose the right option.
data:image/s3,"s3://crabby-images/131a1/131a1a2d4003bbfd309e990fdddc1b11b9778d71" alt=""
Use supplementary content if it helps users make a decision.
data:image/s3,"s3://crabby-images/9cb44/9cb44a644eafdeabc93c53074653655ea2fae813" alt=""
Do not use supplementary content for decorative purposes.
data:image/s3,"s3://crabby-images/609ae/609ae8b5e2d5e23e096fc1e75434805509301aed" alt=""
Use icons consistently for all options to ensure proper layout and easy scanning.
Examples
Live Preview
Props
Name | Description | Type | Default | Values |
---|---|---|---|---|
trigger-type | Determines whether the combobox is triggering on click or input typing. | string | click | click, input |
multiselect | Determines whether the combobox is multiselect or not. | boolean | false, true | |
loading | Determines whether the combobox is loading or not. | Boolean | false, true | |
error | Optional error message to be shown under the combobox field. | string,boolean | ||
hint | Optional text about the expected combobox. | string | ||
label | The label for the combobox field. | string | ||
placeholder | Placeholder text to display within the combobox field. | string | ||
required | Determines whether the combobox is required or not. | boolean | false, true | |
target | Type string or an actual DOM node where you want render component | string|object | body | |
use-teleport | When it is set to true, combobox menu will teleport the content part into the target. | boolean | false | false, true |
open | Controls whether the dropdown is open or not. | boolean | false | false, true |
position | Controls the position of the dropdown menu in relation to the trigger. `bottom-left` will align it to the bottom left of the trigger. `bottom-right` will align it to the bottom right of the trigger. `top-left`and 'top-right' will align it to the top left and right respectively. | string | bottom-left | bottom-left, bottom-right, top-left, top-right |
items | Controls the number of dropdown items and dropdown groups to display. | array | [{ heading: string, items: array [ { title: string, trailingIcon: string, leadingIcon: string, href: string, to: string, value } ], hideDivider: boolean }] | |
v-model model-value | Selection of the combobox. Accepts an array of item objects. For single selection, pass in an array of one object. | array | [{ title: string, value: string }] | |
translations | Object with all necessary translations. | object | { triggerIconSearch: 'Search', triggerRemoveSelectedItems: 'Remove selected items', triggerIconToggle: 'Toggle', itemIconCheck: 'Item selected', messageResultsNotFound: 'No results found' } | { triggerIconSearch: string, triggerRemoveSelectedItems: string, triggerIconToggle: string, itemIconCheck: string, messageResultsNotFound: string} |
readonly | Determines whether the combobox is readonly or not. | boolean | false, true |
Events
Name | Description | Type |
---|---|---|
input | { "names": [ "undefined" ] } | |
item-click | This event is emitted when the combobox item is clicked. | { "names": [ "Event, Object<string, string>" ] } |
v-model update:modelValue | This event is emitted when the combobox selection is changed. | { "names": [ "Array" ] } |
Slots
Name | Description |
---|---|
hint | Use it to provide rich content for input hint. Takes precedence over hint property. |