Autocomplete
Autocomplete user input with any list of options
Source
Docs
Package
Made with Combobox
Autocomplete is an opinionated component built on top of Combobox component. It has a limited set of features to cover only the basic use cases. If you need more advanced features, you can build your own component with Combobox. You can find examples of custom autocomplete components on the examples page.
Not a searchable select
Autocomplete is not a searchable select, it is a text input with suggestions.
Values are not enforced to be one of the suggestions, user can type anything.
If you need a searchable select, use Select component instead.
To learn more about the differences between Autocomplete and Select, check
help center article.
Usage
Autocomplete provides user a list of suggestions based on the input,
however user is not limited to suggestions and can type anything.
Controlled
Autocomplete value must be a string, other types are not supported.
onChange function is called with a string value as a single argument.
Select first option on change
Set the selectFirstOptionOnChange prop to automatically select the first option in the dropdown when the input value changes.
This feature allows users to type a value and immediately press Enter to select the first matching option,
without needing to press the arrow down key first.
autoSelectOnBlur
Set autoSelectOnBlur prop to automatically select the highlighted option when the input loses focus.
To see this feature in action: select an option with up/down arrows, then click outside the input:
Data formats
Autocomplete data prop accepts data in one of the following formats:
Array of strings:
Array of groups with string options:
Options filtering
By default,Autocomplete filters options by checking if the option label contains input value. You can change this behavior with filter prop.filter function receives an object with the following properties as a single argument:options– array of options or options groups, all options are in{ value: string; label: string; disabled?: boolean }formatsearch– current search querylimit– value oflimitprop passed toAutocomplete
Example of a custom filter function that matches options by words instead of letters sequence:
Sort options
By default, options are sorted by their position in the data array. You can change this behavior
with filter function:
Large data sets
The best strategy for large data sets is to limit the number of options that are rendered at the same time. You can do it with limit prop. Note that if you use a custom filter function, you need to implement your own logic to limit the number of options in filter
Example of Autocomplete with 100 000 options, 5 options are rendered at the same time:
renderOption
renderOption callback allows you to customize option rendering. It is called with option object.
The function must return a React node.
Nothing found message
Autocomplete component does not support nothing found message. It is designed to
accept any string as a value, so it does not make sense to show nothing found message.
If you want to limit user input to suggestions, you can use searchable Select
component instead. To learn more about the differences between Autocomplete and Select, check
help center article.
Scrollable dropdown
By default, the options list is wrapped with ScrollArea.Autosize.
You can control dropdown max-height with maxDropdownHeight prop if you do not change the default settings.
If you want to use native scrollbars, set withScrollArea={false}. Note that in this case,
you will need to change dropdown styles with Styles API.
Group options
Disabled options
When option is disabled, it cannot be selected and is ignored in keyboard navigation.
Combobox props
You can override Combobox props with comboboxProps. It is useful when you need to change some of the props that are not exposed by Autocomplete, for example withinPortal:
Change dropdown z-index
Inside Popover
To use Autocomplete inside popover, you need to set withinPortal: false:
Clearable
Set clearable prop to display the clear button in the right section. The button is not displayed
when:
- The component does not have a value
- The component is disabled
- The component is read only
Control dropdown opened state
You can control dropdown opened state with dropdownOpened prop. Additionally,
you can use onDropdownClose and onDropdownOpen to listen to dropdown opened state changes.
Dropdown position
By default, the dropdown is displayed below the input if there is enough space; otherwise it is displayed above the input.
You can change this behavior by setting position and middlewares props, which are passed down to the
underlying Popover component.
Example of dropdown that is always displayed above the input:
Dropdown animation
By default, dropdown animations are disabled. To enable them, you can set transitionProps,
which will be passed down to the underlying Transition component.
Dropdown padding
Dropdown shadow
Left and right sections
Autocomplete supports leftSection and rightSection props. These sections are rendered with absolute position inside the input wrapper. You can use them to display icons, input controls or any other elements.
You can use the following props to control sections styles and content:
rightSection/leftSection– React node to render on the corresponding side of inputrightSectionWidth/leftSectionWidth– controls width of the right section and padding on the corresponding side of the input. By default, it is controlled by componentsizeprop.rightSectionPointerEvents/leftSectionPointerEvents– controlspointer-eventsproperty of the section. If you want to render a non-interactive element, set it tononeto pass clicks through to the input.
Input props
Autocomplete component supports Input and Input.Wrapper components features and all input element props. Autocomplete documentation does not include all features supported by the component – see Input documentation to learn about all available features.
Input description
Read only
Set readOnly to make the input read only. When readOnly is set,
Autocomplete will not show suggestions and will not call onChange function.
Disabled
Set disabled to disable the input. When disabled is set,
user cannot interact with the input and Autocomplete will not show suggestions.
Error state
Invalid name
Styles API
Autocomplete supports Styles API, you can add styles to any inner element of the component withclassNames prop. Follow Styles API documentation to learn more.
Description
Component Styles API
Hover over selectors to highlight corresponding elements
Get element ref
Accessibility
If Autocomplete is used without label prop, it will not be announced properly by screen reader:
Set aria-label to make the input accessible. In this case label will not be visible, but screen reader will announce it:
If label prop is set, input will be accessible it is not required to set aria-label: