react-toolbox/components/dropdown/readme.md

74 lines
3.3 KiB
Markdown
Raw Normal View History

# Dropdown
The Dropdown selects an option between multiple selections. The element displays the current state and a down arrow. When it is clicked, it displays the list of available options.
<!-- example -->
```jsx
import Dropdown from 'react-toolbox/lib/dropdown';
const countries = [
{ value: 'EN-gb', label: 'England' },
{ value: 'ES-es', label: 'Spain'},
{ value: 'TH-th', label: 'Thailand' },
{ value: 'EN-en', label: 'USA'}
];
class DropdownTest extends React.Component {
2016-05-22 22:28:48 +03:00
state = { value: 'ES-es' };
handleChange = (value) => {
this.setState({value: value});
};
render () {
return (
<Dropdown
auto
onChange={this.handleChange}
source={countries}
value={this.state.value}
/>
);
}
}
```
2016-05-29 20:37:40 +03:00
If you want to provide a theme via context, the component key is `RTDropdown`.
## Properties
2016-05-29 20:37:40 +03:00
| Name | Type | Default | Description |
|:-------------|:-----------|:--------|:------------|
2016-11-21 02:21:28 +03:00
| `allowBlank` | `Boolean` | `true` | If false the dropdown will preselect the first item if the supplied value matches none of the options' values.|
2016-05-29 20:37:40 +03:00
| `auto` | `Boolean` | `true` | If true, the dropdown will open up or down depending on the position in the screen.|
| `className` | `String` | `''` | Set the class to give custom styles to the dropdown.|
| `disabled` | `Boolean` | `false` | Set the component as disabled.|
| `error` | `String` | | Give an error string to display under the field.|
| `label` | `String` | | The text string to use for the floating label element.|
| `onBlur` | `Function` | | Callback function that is fired when the component is blurred.|
| `onChange` | `Function` | | Callback function that is fired when the component's value changes.|
| `onFocus` | `Function` | | Callback function that is fired when the component is focused.|
| `source` | `Array` | | Array of data objects with the data to represent in the dropdown.|
| `template` | `Function` | | Callback function that returns a JSX template to represent the element.|
| `value` | `String` | | Default value using JSON data.|
2016-10-11 23:12:12 +03:00
| `required` | `Boolean` | `false` | If true, the dropdown has a required attribute.|
2016-05-22 22:28:48 +03:00
## Theming
This component uses an `Input` under the covers. The theme object is passed down namespaced under `input` keyword. This means you can use the same theme classNames from `Input` component but namespaced with `input`. For example, to style the label you have to use `inputLabel` className.
2016-05-29 20:37:40 +03:00
| Name | Description|
|:----------------|:-----------|
| `active` | Added to the root element when the dropdown is active.|
| `disabled` | Added to the root element when it's disabled.|
| `dropdown` | Root element class.|
| `error` | Used for the error element.|
| `errored` | Added to the inner wrapper if it's errored.|
| `field` | Used for the inner wrapper of the component.|
| `label` | Used for the the label element.|
| `selected` | Used to highlight the selected value.|
| `templateValue` | Used as a wrapper for the given template value.|
| `up` | Added to the root element when it's opening up.|
| `value` | Used for each value in the dropdown component.|
| `values` | Used for the list of values.|