Package Exports
- react-bootstrap-typeahead
- react-bootstrap-typeahead/css/Token.css
- react-bootstrap-typeahead/css/Typeahead.css
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (react-bootstrap-typeahead) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
React Bootstrap Typeahead
React-based typeahead component that uses standard the Bootstrap theme for as a base and supports both single- and multi-selection. Try a live example.
Installation
Use NPM to install the module in your project and build using a tool like webpack or browserify.
npm install react-bootstrap-typeahead
To generate UMD modules, both minified and unminified, download the project and run npm run build
.
Usage
react-bootstrap-typeahead
works very much like any standard input
element. It requires an array of options to display, similar to a select
.
var Typeahead = require('react-bootstrap-typeahead');
<Typeahead
onChange={this._handleChange}
options={myData}
/>
Single & Multi-Selection
react-bootstrap-typeahead
allows single-selection by default, but also supports multi-selection. Simply set the multiple
prop and the component turns into a tokenizer:
<Typeahead
multiple
onChange={this._handleChange}
options={myData}
/>
Controlled vs. Uncontrolled
Like an input
, the component can be controlled or uncontrolled. Use the selected
prop to control it via the parent, or defaultSelected
to optionally set defaults and then allow the component to control itself.
<Typeahead
onChange={this._handleChange}
options={myData}
selected={selected}
/>
Data
react-bootstrap-typeahead
has some expectations about the shape of your data. It expects an array of objects, each of which should have a string property to be used as the label for display. By default, the key is named label
, but you can specify a different key via the labelKey
prop.
var myData = [
{id: 1, name: 'John'},
{id: 2, name: 'Miles'},
{id: 3, name: 'Charles'},
{id: 4, name: 'Herbie'},
];
<Typeahead
labelKey="name"
onChange={this._handleChange}
options={myData}
/>
As far as the source of the data, the component simply handles rendering and selection. It is agnostic about the data source (eg: an async endpoint), which should be handled separately.
Example
An example file is included with the project. Simply open index.html
in a browser. You can also try the live example.
Documentation
Props
Name | Type | Default | Description |
---|---|---|---|
allowNew | boolean | false | Allows the creation of new selections on the fly. Note that any new items will be added to the list of selections, but not the list of original options unless handled as such by Typeahead 's parent. |
defaultSelected | array | [] |
Specify any pre-selected options. Use only if you want the component to be uncontrolled. |
disabled | boolean | Whether to disable the input. Will also disable selections when multiple={true} . |
|
emptyLabel | string | 'No matches found.' | Message to display in the menu if there are no valid results. |
labelKey | string | 'label' | Specify which option key to use for display. By default, the selector will use the label key. |
maxHeight | number | 300 |
Maximum height of the dropdown menu, in px. |
multiple | boolean | false |
Whether or not multiple selections are allowed. |
newSelectionPrefix | string | 'New selection:' | Provides the ability to specify a prefix before the user-entered text to indicate that the selection will be new. No-op unless allowNew={true} . |
options required |
array | Full set of options, including any pre-selected options. | |
placeholder | string | Placeholder text for the input. | |
selected | array | [] |
The selected option(s) displayed in the input. Use this prop if you want to control the component via its parent. |
Future Enhancements
- Custom
Token
andMenuItem
rendering - Create a new data item on the fly
- Test coverage