ant-design/components/transfer/operation.jsx

55 lines
1.2 KiB
React
Raw Normal View History

2015-11-26 16:07:11 +08:00
import React, { Component, PropTypes } from 'react';
import Button from '../button';
2015-12-21 15:29:02 +08:00
import Icon from '../icon';
2015-11-26 16:07:11 +08:00
function noop() {
}
class TransferOperation extends Component {
render() {
2015-12-24 15:23:26 +08:00
const {
moveToLeft,
moveToRight,
leftArrowText,
rightArrowText,
leftActive,
rightActive,
2015-12-24 15:31:03 +08:00
className,
2015-12-24 15:23:26 +08:00
} = this.props;
2015-11-26 16:07:11 +08:00
2015-12-24 15:23:26 +08:00
const moveToLeftButton = (
2015-12-24 15:52:49 +08:00
<Button type="primary" size="small" disabled={!leftActive} onClick={moveToLeft}>
{<span><Icon type="left" />{leftArrowText}</span>}
2015-12-24 15:23:26 +08:00
</Button>
);
const moveToRightButton = (
2015-12-24 15:52:49 +08:00
<Button type="primary" size="small" disabled={!rightActive} onClick={moveToRight}>
{<span>{rightArrowText}<Icon type="right" /></span>}
2015-12-24 15:23:26 +08:00
</Button>
);
return (
<div className={className}>
{moveToLeftButton}
{moveToRightButton}
</div>
);
2015-11-26 16:07:11 +08:00
}
}
TransferOperation.defaultProps = {
leftArrowText: '',
rightArrowText: '',
moveToLeft: noop,
moveToRight: noop,
};
TransferOperation.propTypes = {
2015-12-24 15:31:03 +08:00
className: PropTypes.string,
2015-11-26 16:07:11 +08:00
leftArrowText: PropTypes.string,
rightArrowText: PropTypes.string,
moveToLeft: PropTypes.func,
moveToRight: PropTypes.func,
};
export default TransferOperation;