64 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import PropTypes from 'prop-types';
 | |
| import { PureComponent } from 'react';
 | |
| 
 | |
| import classNames from 'classnames';
 | |
| 
 | |
| import CheckIcon from 'mastodon/../material-icons/400-24px/done.svg?react';
 | |
| import { Icon }  from 'mastodon/components/icon';
 | |
| 
 | |
| export default class Option extends PureComponent {
 | |
| 
 | |
|   static propTypes = {
 | |
|     name: PropTypes.string.isRequired,
 | |
|     value: PropTypes.string.isRequired,
 | |
|     checked: PropTypes.bool,
 | |
|     label: PropTypes.node,
 | |
|     description: PropTypes.node,
 | |
|     onToggle: PropTypes.func,
 | |
|     multiple: PropTypes.bool,
 | |
|     labelComponent: PropTypes.node,
 | |
|   };
 | |
| 
 | |
|   handleKeyPress = e => {
 | |
|     const { value, checked, onToggle } = this.props;
 | |
| 
 | |
|     if (e.key === 'Enter' || e.key === ' ') {
 | |
|       e.stopPropagation();
 | |
|       e.preventDefault();
 | |
|       onToggle(value, !checked);
 | |
|     }
 | |
|   };
 | |
| 
 | |
|   handleChange = e => {
 | |
|     const { value, onToggle } = this.props;
 | |
|     onToggle(value, e.target.checked);
 | |
|   };
 | |
| 
 | |
|   render () {
 | |
|     const { name, value, checked, label, labelComponent, description, multiple } = this.props;
 | |
| 
 | |
|     return (
 | |
|       <label className='dialog-option poll__option selectable'>
 | |
|         <input type={multiple ? 'checkbox' : 'radio'} name={name} value={value} checked={checked} onChange={this.handleChange} />
 | |
| 
 | |
|         <span
 | |
|           className={classNames('poll__input', { active: checked, checkbox: multiple })}
 | |
|           tabIndex={0}
 | |
|           role='radio'
 | |
|           onKeyPress={this.handleKeyPress}
 | |
|           aria-checked={checked}
 | |
|           aria-label={label}
 | |
|         >{checked && <Icon icon={CheckIcon} />}</span>
 | |
| 
 | |
|         {labelComponent ? labelComponent : (
 | |
|           <span className='poll__option__text'>
 | |
|             <strong>{label}</strong>
 | |
|             {description}
 | |
|           </span>
 | |
|         )}
 | |
|       </label>
 | |
|     );
 | |
|   }
 | |
| 
 | |
| }
 |