lbry-desktop/ui/js/component/tooltip.js

44 lines
931 B
JavaScript
Raw Normal View History

2017-01-21 16:31:41 -05:00
import React from 'react';
2017-05-17 04:10:25 -04:00
export class ToolTip extends React.Component {
static propTypes = {
2017-01-21 16:31:41 -05:00
body: React.PropTypes.string.isRequired,
label: React.PropTypes.string.isRequired
2017-05-17 04:10:25 -04:00
}
constructor(props) {
super(props);
this.state = {
2017-01-21 16:31:41 -05:00
showTooltip: false,
};
2017-05-17 04:10:25 -04:00
}
handleClick() {
2017-01-21 16:31:41 -05:00
this.setState({
showTooltip: !this.state.showTooltip,
});
2017-05-17 04:10:25 -04:00
}
handleTooltipMouseOut() {
2017-01-21 16:31:41 -05:00
this.setState({
showTooltip: false,
});
2017-05-17 04:10:25 -04:00
}
render() {
2017-01-21 16:31:41 -05:00
return (
<span className={'tooltip ' + (this.props.className || '')}>
<a className="tooltip__link" onClick={() => { this.handleClick() }}>
2017-01-21 16:31:41 -05:00
{this.props.label}
</a>
<div className={'tooltip__body ' + (this.state.showTooltip ? '' : ' hidden')}
onMouseOut={() => { this.handleTooltipMouseOut() }}>
2017-01-21 16:31:41 -05:00
{this.props.body}
</div>
</span>
);
}
2017-05-17 04:10:25 -04:00
}
2017-05-08 18:22:27 -04:00
export default ToolTip