mirror of
				https://github.com/flarum/core.git
				synced 2025-10-26 21:21:28 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			26 lines
		
	
	
		
			882 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			26 lines
		
	
	
		
			882 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('sort', {className: 'Select-caret'})}
 | |
|       </span>
 | |
|     );
 | |
|   }
 | |
| }
 |