|
|
@ -4,9 +4,30 @@ import React, { Component } from 'react';
|
|
|
|
import { Manager, Popper, Reference } from 'react-popper';
|
|
|
|
import { Manager, Popper, Reference } from 'react-popper';
|
|
|
|
import Portal from 'Components/Portal';
|
|
|
|
import Portal from 'Components/Portal';
|
|
|
|
import { kinds, tooltipPositions } from 'Helpers/Props';
|
|
|
|
import { kinds, tooltipPositions } from 'Helpers/Props';
|
|
|
|
|
|
|
|
import dimensions from 'Styles/Variables/dimensions';
|
|
|
|
import { isMobile as isMobileUtil } from 'Utilities/mobile';
|
|
|
|
import { isMobile as isMobileUtil } from 'Utilities/mobile';
|
|
|
|
import styles from './Tooltip.css';
|
|
|
|
import styles from './Tooltip.css';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let maxWidth = null;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function getMaxWidth() {
|
|
|
|
|
|
|
|
const windowWidth = window.innerWidth;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (windowWidth > parseInt(dimensions.breakpointLarge)) {
|
|
|
|
|
|
|
|
maxWidth = 800;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (windowWidth > parseInt(dimensions.breakpointMedium)) {
|
|
|
|
|
|
|
|
maxWidth = 650;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (windowWidth > parseInt(dimensions.breakpointSmall)) {
|
|
|
|
|
|
|
|
maxWidth = 500;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
maxWidth = 450;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
class Tooltip extends Component {
|
|
|
|
class Tooltip extends Component {
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
//
|
|
|
@ -17,6 +38,7 @@ class Tooltip extends Component {
|
|
|
|
|
|
|
|
|
|
|
|
this._scheduleUpdate = null;
|
|
|
|
this._scheduleUpdate = null;
|
|
|
|
this._closeTimeout = null;
|
|
|
|
this._closeTimeout = null;
|
|
|
|
|
|
|
|
this._maxWidth = maxWidth || getMaxWidth();
|
|
|
|
|
|
|
|
|
|
|
|
this.state = {
|
|
|
|
this.state = {
|
|
|
|
isOpen: false
|
|
|
|
isOpen: false
|
|
|
@ -54,9 +76,11 @@ class Tooltip extends Component {
|
|
|
|
} else if ((/^bottom/).test(data.placement)) {
|
|
|
|
} else if ((/^bottom/).test(data.placement)) {
|
|
|
|
data.styles.maxHeight = windowHeight - bottom - 20;
|
|
|
|
data.styles.maxHeight = windowHeight - bottom - 20;
|
|
|
|
} else if ((/^right/).test(data.placement)) {
|
|
|
|
} else if ((/^right/).test(data.placement)) {
|
|
|
|
data.styles.maxWidth = windowWidth - right - 50;
|
|
|
|
data.styles.maxWidth = Math.min(this._maxWidth, windowWidth - right - 20);
|
|
|
|
|
|
|
|
data.styles.maxHeight = top - 20;
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
data.styles.maxWidth = left - 35;
|
|
|
|
data.styles.maxWidth = Math.min(this._maxWidth, left - 20);
|
|
|
|
|
|
|
|
data.styles.maxHeight = top - 20;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return data;
|
|
|
|
return data;
|
|
|
@ -144,10 +168,16 @@ class Tooltip extends Component {
|
|
|
|
{({ ref, style, placement, arrowProps, scheduleUpdate }) => {
|
|
|
|
{({ ref, style, placement, arrowProps, scheduleUpdate }) => {
|
|
|
|
this._scheduleUpdate = scheduleUpdate;
|
|
|
|
this._scheduleUpdate = scheduleUpdate;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const popperPlacement = placement ? placement.split('-')[0] : position;
|
|
|
|
|
|
|
|
const vertical = popperPlacement === 'top' || popperPlacement === 'bottom';
|
|
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
return (
|
|
|
|
<div
|
|
|
|
<div
|
|
|
|
ref={ref}
|
|
|
|
ref={ref}
|
|
|
|
className={styles.tooltipContainer}
|
|
|
|
className={classNames(
|
|
|
|
|
|
|
|
styles.tooltipContainer,
|
|
|
|
|
|
|
|
vertical ? styles.verticalContainer : styles.horizontalContainer
|
|
|
|
|
|
|
|
)}
|
|
|
|
style={style}
|
|
|
|
style={style}
|
|
|
|
onMouseEnter={this.onMouseEnter}
|
|
|
|
onMouseEnter={this.onMouseEnter}
|
|
|
|
onMouseLeave={this.onMouseLeave}
|
|
|
|
onMouseLeave={this.onMouseLeave}
|
|
|
@ -156,7 +186,7 @@ class Tooltip extends Component {
|
|
|
|
className={this.state.isOpen ? classNames(
|
|
|
|
className={this.state.isOpen ? classNames(
|
|
|
|
styles.arrow,
|
|
|
|
styles.arrow,
|
|
|
|
styles[kind],
|
|
|
|
styles[kind],
|
|
|
|
styles[placement.split('-')[0]]
|
|
|
|
styles[popperPlacement]
|
|
|
|
) : styles.arrowDisabled}
|
|
|
|
) : styles.arrowDisabled}
|
|
|
|
ref={arrowProps.ref}
|
|
|
|
ref={arrowProps.ref}
|
|
|
|
style={arrowProps.style}
|
|
|
|
style={arrowProps.style}
|
|
|
@ -201,7 +231,7 @@ Tooltip.defaultProps = {
|
|
|
|
bodyClassName: styles.body,
|
|
|
|
bodyClassName: styles.body,
|
|
|
|
kind: kinds.DEFAULT,
|
|
|
|
kind: kinds.DEFAULT,
|
|
|
|
position: tooltipPositions.TOP,
|
|
|
|
position: tooltipPositions.TOP,
|
|
|
|
canFlip: true
|
|
|
|
canFlip: false
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
export default Tooltip;
|
|
|
|
export default Tooltip;
|
|
|
|