1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00

Fix cluster dropdown invisible overlay (#4411)

* Use setTimeout instead of unstable onTransitionEnd

Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com>

* Remove clicking Disconnect after each test

Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com>

* Fixing tests harder

Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com>

* Clean up

Signed-off-by: Alex Andreev <alex.andreev.email@gmail.com>
This commit is contained in:
Alex Andreev 2021-11-24 18:52:35 +03:00 committed by GitHub
parent 0ca8448d33
commit 0fe0b33c67
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 23 additions and 23 deletions

View File

@ -21,7 +21,7 @@
// Animations
@mixin animate-opacity($enterDuration: 100ms, $leaveDuration: 150ms) {
@mixin animate-opacity($enterDuration: var(--enter-duration), $leaveDuration: var(--leave-duration)) {
opacity: 0;
&.enter {
@ -37,7 +37,7 @@
}
}
@mixin animate-slide-right($enterDuration: 100ms, $leaveDuration: 150ms) {
@mixin animate-slide-right($enterDuration: var(--enter-duration), $leaveDuration: var(--leave-duration)) {
transform: translateX(100%);
will-change: transform;
@ -53,7 +53,7 @@
}
}
@mixin animate-opacity-scale($enterDuration: 250ms, $leaveDuration: 150ms) {
@mixin animate-opacity-scale($enterDuration: var(--enter-duration), $leaveDuration: var(--leave-duration)) {
opacity: 0;
&.enter {
@ -84,6 +84,6 @@
}
&.opacity-scale {
@include animate-opacity-scale(100ms);
@include animate-opacity-scale;
}
}

View File

@ -23,7 +23,7 @@ import "./animate.scss";
import React from "react";
import { observable, reaction, makeObservable } from "mobx";
import { disposeOnUnmount, observer } from "mobx-react";
import { boundMethod, cssNames, noop } from "../../utils";
import { cssNames, noop } from "../../utils";
export type AnimateName = "opacity" | "slide-right" | "opacity-scale" | string;
@ -32,17 +32,19 @@ export interface AnimateProps {
enter?: boolean;
onEnter?: () => void;
onLeave?: () => void;
enterDuration?: number;
leaveDuration?: number;
}
@observer
export class Animate extends React.Component<AnimateProps> {
static VISIBILITY_DELAY_MS = 0;
static defaultProps: AnimateProps = {
name: "opacity",
enter: true,
onEnter: noop,
onLeave: noop,
enterDuration: 100,
leaveDuration: 100,
};
@observable isVisible = !!this.props.enter;
@ -66,7 +68,6 @@ export class Animate extends React.Component<AnimateProps> {
if (enter) this.enter();
else this.leave();
}, {
delay: Animate.VISIBILITY_DELAY_MS,
fireImmediately: true,
}),
]);
@ -84,6 +85,11 @@ export class Animate extends React.Component<AnimateProps> {
if (!this.isVisible) return;
this.statusClassName.leave = true;
this.props.onLeave();
this.resetAfterLeaveDuration();
}
resetAfterLeaveDuration() {
setTimeout(() => this.reset(), this.props.leaveDuration);
}
reset() {
@ -92,27 +98,21 @@ export class Animate extends React.Component<AnimateProps> {
this.statusClassName.leave = false;
}
@boundMethod
onTransitionEnd(evt: React.TransitionEvent) {
const { enter, leave } = this.statusClassName;
const { onTransitionEnd } = this.contentElem.props;
if (onTransitionEnd) onTransitionEnd(evt);
// todo: check evt.propertyName and make sure all animating props has finished their transition
if (enter && leave) {
this.reset();
}
}
render() {
const { name } = this.props;
const { name, enterDuration, leaveDuration } = this.props;
const contentElem = this.contentElem;
const durations = {
"--enter-duration": `${enterDuration}ms`,
"--leave-duration": `${leaveDuration}ms`,
} as React.CSSProperties;
return React.cloneElement(contentElem, {
className: cssNames("Animate", name, contentElem.props.className, this.statusClassName),
children: this.isVisible ? contentElem.props.children : null,
onTransitionEnd: this.onTransitionEnd,
style: {
...contentElem.props.style,
...durations,
},
});
}
}