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:
parent
0ca8448d33
commit
0fe0b33c67
8
src/renderer/components/animate/animate.scss
vendored
8
src/renderer/components/animate/animate.scss
vendored
@ -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;
|
||||
}
|
||||
}
|
||||
|
||||
@ -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,
|
||||
},
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
Loading…
Reference in New Issue
Block a user