Unfloat the MiniAvatarUploader "tooltip"

pull/21833/head
Michael Telatynski 2020-12-27 21:13:01 +00:00
parent f4190ccae2
commit 8ee65258be
2 changed files with 18 additions and 6 deletions

View File

@ -18,6 +18,16 @@ limitations under the License.
position: relative; position: relative;
width: min-content; width: min-content;
// this isn't a floating tooltip so override some things to not need to bother with z-index and floating
.mx_Tooltip {
display: inline-block;
position: absolute;
z-index: unset;
width: max-content;
left: 72px;
top: 0;
}
&::before, &::after { &::before, &::after {
content: ''; content: '';
position: absolute; position: absolute;

View File

@ -19,7 +19,6 @@ import {EventType} from 'matrix-js-sdk/src/@types/event';
import classNames from 'classnames'; import classNames from 'classnames';
import AccessibleButton from "./AccessibleButton"; import AccessibleButton from "./AccessibleButton";
import Tooltip from './Tooltip';
import MatrixClientContext from "../../../contexts/MatrixClientContext"; import MatrixClientContext from "../../../contexts/MatrixClientContext";
import {useTimeout} from "../../../hooks/useTimeout"; import {useTimeout} from "../../../hooks/useTimeout";
import Analytics from "../../../Analytics"; import Analytics from "../../../Analytics";
@ -56,6 +55,7 @@ const MiniAvatarUploader: React.FC<IProps> = ({ hasAvatar, hasAvatarLabel, noAva
const canSetAvatar = room?.currentState.maySendStateEvent(EventType.RoomAvatar, cli.getUserId()); const canSetAvatar = room?.currentState.maySendStateEvent(EventType.RoomAvatar, cli.getUserId());
if (!canSetAvatar) return children; if (!canSetAvatar) return children;
const visible = !!label && (hover || show);
return <React.Fragment> return <React.Fragment>
<input <input
type="file" type="file"
@ -88,11 +88,13 @@ const MiniAvatarUploader: React.FC<IProps> = ({ hasAvatar, hasAvatarLabel, noAva
> >
{ children } { children }
<Tooltip <div className={classNames("mx_Tooltip", {
label={label} "mx_Tooltip_visible": visible,
visible={!!label && (hover || show)} "mx_Tooltip_invisible": !visible,
forceOnRight })}>
/> <div className="mx_Tooltip_chevron" />
{ label }
</div>
</AccessibleButton> </AccessibleButton>
</React.Fragment>; </React.Fragment>;
}; };