2017-06-06 17:19:12 -04:00
|
|
|
import React from "react";
|
2017-01-21 16:31:41 -05:00
|
|
|
|
2017-06-07 21:42:19 -07:00
|
|
|
export class ToolTip extends React.PureComponent {
|
2017-05-17 04:10:25 -04:00
|
|
|
static propTypes = {
|
2017-01-21 16:31:41 -05:00
|
|
|
body: React.PropTypes.string.isRequired,
|
2017-06-06 17:19:12 -04:00
|
|
|
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 (
|
2017-06-06 17:19:12 -04:00
|
|
|
<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>
|
2017-06-06 17:19:12 -04:00
|
|
|
<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
|
|
|
|
2017-06-05 21:21:55 -07:00
|
|
|
export default ToolTip;
|