mirror of
https://github.com/flarum/framework.git
synced 2024-11-25 17:57:04 +08:00
a9ded36b57
- Get rid of Bootstrap (except we still rely on some JS) - Use BEM class names - Rework variables/theme config - Fix various bugs, including some on mobile The CSS is still not ideal – it needs to be cleaned up some more. But that can be a focus for after beta.
70 lines
1.8 KiB
JavaScript
70 lines
1.8 KiB
JavaScript
import Component from 'flarum/Component';
|
|
import LoadingIndicator from 'flarum/components/LoadingIndicator';
|
|
import icon from 'flarum/helpers/icon';
|
|
|
|
/**
|
|
* The `Checkbox` component defines a checkbox input.
|
|
*
|
|
* ### Props
|
|
*
|
|
* - `state` Whether or not the checkbox is checked.
|
|
* - `className` The class name for the root element.
|
|
* - `disabled` Whether or not the checkbox is disabled.
|
|
* - `onchange` A callback to run when the checkbox is checked/unchecked.
|
|
* - `children` A text label to display next to the checkbox.
|
|
*/
|
|
export default class Checkbox extends Component {
|
|
constructor(...args) {
|
|
super(...args);
|
|
|
|
/**
|
|
* Whether or not the checkbox's value is in the process of being saved.
|
|
*
|
|
* @type {Boolean}
|
|
* @public
|
|
*/
|
|
this.loading = false;
|
|
}
|
|
|
|
view() {
|
|
let className = 'Checkbox ' + (this.props.state ? 'on' : 'off') + ' ' + (this.props.className || '');
|
|
if (this.loading) className += ' loading';
|
|
if (this.props.disabled) className += ' disabled';
|
|
|
|
return (
|
|
<label className={className}>
|
|
<input type="checkbox"
|
|
checked={this.props.state}
|
|
disabled={this.props.disabled}
|
|
onchange={m.withAttr('checked', this.onchange.bind(this))}/>
|
|
<div className="Checkbox-display">
|
|
{this.getDisplay()}
|
|
</div>
|
|
{this.props.children}
|
|
</label>
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get the template for the checkbox's display (tick/cross icon).
|
|
*
|
|
* @return {*}
|
|
* @protected
|
|
*/
|
|
getDisplay() {
|
|
return this.loading
|
|
? LoadingIndicator.component({size: 'tiny'})
|
|
: icon(this.props.state ? 'check' : 'times');
|
|
}
|
|
|
|
/**
|
|
* Run a callback when the state of the checkbox is changed.
|
|
*
|
|
* @param {Boolean} checked
|
|
* @protected
|
|
*/
|
|
onchange(checked) {
|
|
if (this.props.onchange) this.props.onchange(checked, this);
|
|
}
|
|
}
|