2017-04-14 16:20:09 +08:00
|
|
|
import React, { PropTypes } from 'react';
|
|
|
|
import classNames from 'classnames';
|
2017-03-13 10:20:25 +08:00
|
|
|
import RcCheckbox from 'rc-checkbox';
|
2017-04-14 16:20:09 +08:00
|
|
|
import shallowEqual from 'shallowequal';
|
2017-03-13 10:20:25 +08:00
|
|
|
import CheckboxGroup from './Group';
|
|
|
|
|
2017-04-14 16:20:09 +08:00
|
|
|
export interface AbstractCheckboxProps {
|
2017-03-13 10:20:25 +08:00
|
|
|
prefixCls?: string;
|
2017-04-14 16:20:09 +08:00
|
|
|
className?: string;
|
2017-03-13 10:20:25 +08:00
|
|
|
defaultChecked?: boolean;
|
2017-04-14 16:20:09 +08:00
|
|
|
checked?: boolean;
|
|
|
|
style?: React.CSSProperties;
|
|
|
|
disabled?: boolean;
|
2017-03-13 10:20:25 +08:00
|
|
|
onChange?: React.FormEventHandler<any>;
|
|
|
|
onMouseEnter?: React.MouseEventHandler<any>;
|
|
|
|
onMouseLeave?: React.MouseEventHandler<any>;
|
2017-04-14 16:20:09 +08:00
|
|
|
value?: any;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface CheckboxProps extends AbstractCheckboxProps {
|
|
|
|
indeterminate?: boolean;
|
2017-03-13 10:20:25 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
export default class Checkbox extends React.Component<CheckboxProps, any> {
|
|
|
|
static Group: typeof CheckboxGroup;
|
|
|
|
static defaultProps = {
|
|
|
|
prefixCls: 'ant-checkbox',
|
|
|
|
indeterminate: false,
|
|
|
|
};
|
2017-04-14 16:20:09 +08:00
|
|
|
|
|
|
|
static contextTypes = {
|
|
|
|
checkboxGroup: PropTypes.any,
|
|
|
|
};
|
|
|
|
|
|
|
|
shouldComponentUpdate(nextProps, nextState, nextContext) {
|
|
|
|
return !shallowEqual(this.props, nextProps) ||
|
|
|
|
!shallowEqual(this.state, nextState) ||
|
|
|
|
!shallowEqual(this.context.checkboxGroup, nextContext.checkboxGroup);
|
2017-03-13 10:20:25 +08:00
|
|
|
}
|
2017-04-14 16:20:09 +08:00
|
|
|
|
2017-03-13 10:20:25 +08:00
|
|
|
render() {
|
2017-04-14 16:20:09 +08:00
|
|
|
const { props, context } = this;
|
2017-03-13 10:20:25 +08:00
|
|
|
const {
|
2017-04-14 16:20:09 +08:00
|
|
|
prefixCls,
|
|
|
|
className,
|
|
|
|
children,
|
|
|
|
indeterminate,
|
|
|
|
style,
|
|
|
|
onMouseEnter,
|
|
|
|
onMouseLeave,
|
|
|
|
...restProps,
|
|
|
|
} = props;
|
|
|
|
const { checkboxGroup } = context;
|
|
|
|
let checkboxProps: CheckboxProps = { ...restProps };
|
|
|
|
if (checkboxGroup) {
|
|
|
|
checkboxProps.onChange = () => checkboxGroup.toggleOption({ label: children, value: props.value });
|
|
|
|
checkboxProps.checked = checkboxGroup.value.indexOf(props.value) !== -1;
|
|
|
|
checkboxProps.disabled = 'disabled' in props ? props.disabled : checkboxGroup.disabled;
|
|
|
|
}
|
2017-03-13 10:20:25 +08:00
|
|
|
const classString = classNames(className, {
|
|
|
|
[`${prefixCls}-wrapper`]: true,
|
|
|
|
});
|
|
|
|
const checkboxClass = classNames({
|
|
|
|
[`${prefixCls}-indeterminate`]: indeterminate,
|
|
|
|
});
|
|
|
|
return (
|
|
|
|
<label
|
|
|
|
className={classString}
|
|
|
|
style={style}
|
|
|
|
onMouseEnter={onMouseEnter}
|
|
|
|
onMouseLeave={onMouseLeave}
|
|
|
|
>
|
|
|
|
<RcCheckbox
|
2017-04-14 16:20:09 +08:00
|
|
|
{...checkboxProps}
|
2017-03-13 10:20:25 +08:00
|
|
|
prefixCls={prefixCls}
|
|
|
|
className={checkboxClass}
|
|
|
|
/>
|
|
|
|
{children !== undefined ? <span>{children}</span> : null}
|
|
|
|
</label>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|