mirror of
https://github.com/flarum/framework.git
synced 2024-11-24 18:41:10 +08:00
1a2df2d581
* Update FontAwesome to v5.0.6 * Adapt DiscussionListItem-count icon to match FontAwesome 5 syntax * Change icon name to match FontAwesome 5.0.6 fas icon * Add font type prefix parameter to icon helper * Add Enable Icon Prefix to show icon in Extension Page * Fix invalid icon behavior * Change icon name to match FontAwesome 5.0.6 far icon * Use iconPrefix property on component * Use full icon class name * Update icon helper docblock * Full icon class syntax
26 lines
888 B
JavaScript
26 lines
888 B
JavaScript
import Component from 'flarum/Component';
|
|
import icon from 'flarum/helpers/icon';
|
|
|
|
/**
|
|
* The `Select` component displays a <select> input, surrounded with some extra
|
|
* elements for styling. It accepts the following props:
|
|
*
|
|
* - `options` A map of option values to labels.
|
|
* - `onchange` A callback to run when the selected value is changed.
|
|
* - `value` The value of the selected option.
|
|
*/
|
|
export default class Select extends Component {
|
|
view() {
|
|
const {options, onchange, value} = this.props;
|
|
|
|
return (
|
|
<span className="Select">
|
|
<select className="Select-input FormControl" onchange={onchange ? m.withAttr('value', onchange.bind(this)) : undefined} value={value}>
|
|
{Object.keys(options).map(key => <option value={key}>{options[key]}</option>)}
|
|
</select>
|
|
{icon('fa fa-sort', {className: 'Select-caret'})}
|
|
</span>
|
|
);
|
|
}
|
|
}
|