88 lines
2.3 KiB
JavaScript
88 lines
2.3 KiB
JavaScript
|
import React from "react";
|
||
|
import PropTypes from "prop-types";
|
||
|
import IconButton from "../icon-button";
|
||
|
import Tooltip from "../tooltip";
|
||
|
import { handleAnyClick } from "../../utils/event";
|
||
|
import uniqueId from "lodash/uniqueId";
|
||
|
|
||
|
class HelpButton extends React.Component {
|
||
|
constructor(props) {
|
||
|
super(props);
|
||
|
|
||
|
this.state = { isOpen: false };
|
||
|
this.ref = React.createRef();
|
||
|
this.refTooltip = React.createRef();
|
||
|
this.id = uniqueId();
|
||
|
}
|
||
|
|
||
|
afterShow = () => {
|
||
|
this.refTooltip.current.updatePosition();
|
||
|
//console.log(`afterShow ${this.props.tooltipId} isOpen=${this.state.isOpen}`, this.ref, e);
|
||
|
this.setState({ isOpen: true }, () => {
|
||
|
handleAnyClick(true, this.handleClick);
|
||
|
});
|
||
|
};
|
||
|
|
||
|
afterHide = () => {
|
||
|
//console.log(`afterHide ${this.props.tooltipId} isOpen=${this.state.isOpen}`, this.ref, e);
|
||
|
if (this.state.isOpen) {
|
||
|
this.setState({ isOpen: false }, () => {
|
||
|
handleAnyClick(false, this.handleClick);
|
||
|
});
|
||
|
}
|
||
|
};
|
||
|
|
||
|
handleClick = e => {
|
||
|
//console.log(`handleClick ${this.props.tooltipId} isOpen=${this.state.isOpen}`, this.ref, e);
|
||
|
|
||
|
if (!this.ref.current.contains(e.target)) {
|
||
|
//console.log(`hideTooltip() tooltipId=${this.props.tooltipId}`, this.refTooltip.current);
|
||
|
this.refTooltip.current.hideTooltip();
|
||
|
}
|
||
|
};
|
||
|
|
||
|
componentWillUnmount() {
|
||
|
handleAnyClick(false, this.handleClick);
|
||
|
}
|
||
|
|
||
|
render() {
|
||
|
const { tooltipContent } = this.props;
|
||
|
|
||
|
return (
|
||
|
<div ref={this.ref}>
|
||
|
<IconButton
|
||
|
id={this.id}
|
||
|
className="icon-button"
|
||
|
isClickable={true}
|
||
|
iconName="QuestionIcon"
|
||
|
size={13}
|
||
|
/>
|
||
|
<Tooltip
|
||
|
id={this.id}
|
||
|
reference={this.refTooltip}
|
||
|
effect="solid"
|
||
|
place="top"
|
||
|
offsetRight={110}
|
||
|
afterShow={this.afterShow}
|
||
|
afterHide={this.afterHide}
|
||
|
>
|
||
|
{tooltipContent}
|
||
|
</Tooltip>
|
||
|
</div>
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
HelpButton.propTypes = {
|
||
|
children: PropTypes.oneOfType([
|
||
|
PropTypes.arrayOf(PropTypes.node),
|
||
|
PropTypes.node
|
||
|
]),
|
||
|
tooltipContent: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),
|
||
|
tooltipOffsetRight: PropTypes.number,
|
||
|
tooltipMaxWidth: PropTypes.number,
|
||
|
tooltipId: PropTypes.string
|
||
|
};
|
||
|
|
||
|
export default HelpButton;
|