Fixed: Episode history details tooltip jumping around

Fixes #503

(cherry picked from commit 796c5e8b6b9e2ba2b97c6144f64a756e76a947a9)
pull/1112/head
Mark McDowall 4 years ago committed by Qstick
parent 0d860de88a
commit 9fe1663267

@ -156,3 +156,35 @@
.body { .body {
padding: 5px; padding: 5px;
} }
.verticalContainer {
max-height: 300px;
}
.horizontalContainer {
max-width: calc($breakpointExtraSmall - 20px);
}
@media only screen and (min-width: $breakpointExtraSmall) {
.horizontalContainer {
max-width: calc($breakpointSmall * 0.8);
}
}
@media only screen and (min-width: $breakpointSmall) {
.horizontalContainer {
max-width: calc($breakpointMedium * 0.8);
}
}
@media only screen and (min-width: $breakpointMedium) {
.horizontalContainer {
max-width: calc($breakpointLarge * 0.8);
}
}
/* @media only screen and (max-width: $breakpointLarge) {
.horizontalContainer {
max-width: calc($breakpointLarge * 0.8);
}
} */

@ -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;

Loading…
Cancel
Save