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
|
// Animations
|
||||||
|
|
||||||
@mixin animate-opacity($enterDuration: 100ms, $leaveDuration: 150ms) {
|
@mixin animate-opacity($enterDuration: var(--enter-duration), $leaveDuration: var(--leave-duration)) {
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
|
|
||||||
&.enter {
|
&.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%);
|
transform: translateX(100%);
|
||||||
will-change: transform;
|
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;
|
opacity: 0;
|
||||||
|
|
||||||
&.enter {
|
&.enter {
|
||||||
@ -84,6 +84,6 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
&.opacity-scale {
|
&.opacity-scale {
|
||||||
@include animate-opacity-scale(100ms);
|
@include animate-opacity-scale;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -23,7 +23,7 @@ import "./animate.scss";
|
|||||||
import React from "react";
|
import React from "react";
|
||||||
import { observable, reaction, makeObservable } from "mobx";
|
import { observable, reaction, makeObservable } from "mobx";
|
||||||
import { disposeOnUnmount, observer } from "mobx-react";
|
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;
|
export type AnimateName = "opacity" | "slide-right" | "opacity-scale" | string;
|
||||||
|
|
||||||
@ -32,17 +32,19 @@ export interface AnimateProps {
|
|||||||
enter?: boolean;
|
enter?: boolean;
|
||||||
onEnter?: () => void;
|
onEnter?: () => void;
|
||||||
onLeave?: () => void;
|
onLeave?: () => void;
|
||||||
|
enterDuration?: number;
|
||||||
|
leaveDuration?: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
@observer
|
@observer
|
||||||
export class Animate extends React.Component<AnimateProps> {
|
export class Animate extends React.Component<AnimateProps> {
|
||||||
static VISIBILITY_DELAY_MS = 0;
|
|
||||||
|
|
||||||
static defaultProps: AnimateProps = {
|
static defaultProps: AnimateProps = {
|
||||||
name: "opacity",
|
name: "opacity",
|
||||||
enter: true,
|
enter: true,
|
||||||
onEnter: noop,
|
onEnter: noop,
|
||||||
onLeave: noop,
|
onLeave: noop,
|
||||||
|
enterDuration: 100,
|
||||||
|
leaveDuration: 100,
|
||||||
};
|
};
|
||||||
|
|
||||||
@observable isVisible = !!this.props.enter;
|
@observable isVisible = !!this.props.enter;
|
||||||
@ -66,7 +68,6 @@ export class Animate extends React.Component<AnimateProps> {
|
|||||||
if (enter) this.enter();
|
if (enter) this.enter();
|
||||||
else this.leave();
|
else this.leave();
|
||||||
}, {
|
}, {
|
||||||
delay: Animate.VISIBILITY_DELAY_MS,
|
|
||||||
fireImmediately: true,
|
fireImmediately: true,
|
||||||
}),
|
}),
|
||||||
]);
|
]);
|
||||||
@ -84,6 +85,11 @@ export class Animate extends React.Component<AnimateProps> {
|
|||||||
if (!this.isVisible) return;
|
if (!this.isVisible) return;
|
||||||
this.statusClassName.leave = true;
|
this.statusClassName.leave = true;
|
||||||
this.props.onLeave();
|
this.props.onLeave();
|
||||||
|
this.resetAfterLeaveDuration();
|
||||||
|
}
|
||||||
|
|
||||||
|
resetAfterLeaveDuration() {
|
||||||
|
setTimeout(() => this.reset(), this.props.leaveDuration);
|
||||||
}
|
}
|
||||||
|
|
||||||
reset() {
|
reset() {
|
||||||
@ -92,27 +98,21 @@ export class Animate extends React.Component<AnimateProps> {
|
|||||||
this.statusClassName.leave = false;
|
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() {
|
render() {
|
||||||
const { name } = this.props;
|
const { name, enterDuration, leaveDuration } = this.props;
|
||||||
const contentElem = this.contentElem;
|
const contentElem = this.contentElem;
|
||||||
|
const durations = {
|
||||||
|
"--enter-duration": `${enterDuration}ms`,
|
||||||
|
"--leave-duration": `${leaveDuration}ms`,
|
||||||
|
} as React.CSSProperties;
|
||||||
|
|
||||||
return React.cloneElement(contentElem, {
|
return React.cloneElement(contentElem, {
|
||||||
className: cssNames("Animate", name, contentElem.props.className, this.statusClassName),
|
className: cssNames("Animate", name, contentElem.props.className, this.statusClassName),
|
||||||
children: this.isVisible ? contentElem.props.children : null,
|
children: this.isVisible ? contentElem.props.children : null,
|
||||||
onTransitionEnd: this.onTransitionEnd,
|
style: {
|
||||||
|
...contentElem.props.style,
|
||||||
|
...durations,
|
||||||
|
},
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user