mirror of
https://github.com/grafana/grafana.git
synced 2025-01-16 19:52:33 -06:00
53 lines
1.4 KiB
TypeScript
53 lines
1.4 KiB
TypeScript
import React, { CSSProperties, FC } from 'react';
|
|
import Transition from 'react-transition-group/Transition';
|
|
|
|
interface Style {
|
|
transition?: string;
|
|
overflow?: string;
|
|
}
|
|
|
|
// When animating using max-height we need to use a static value.
|
|
// If this is not enough, pass in <SlideDown maxHeight="....
|
|
const defaultMaxHeight = '200px';
|
|
const defaultDuration = 200;
|
|
|
|
export const defaultStyle: Style = {
|
|
transition: `max-height ${defaultDuration}ms ease-in-out`,
|
|
overflow: 'hidden',
|
|
};
|
|
|
|
export interface Props {
|
|
children: React.ReactNode;
|
|
in: boolean;
|
|
maxHeight?: number;
|
|
style?: CSSProperties;
|
|
}
|
|
|
|
export const SlideDown: FC<Props> = ({ children, in: inProp, maxHeight = defaultMaxHeight, style = defaultStyle }) => {
|
|
// There are 4 main states a Transition can be in:
|
|
// ENTERING, ENTERED, EXITING, EXITED
|
|
// https://reactcommunity.or[g/react-transition-group/
|
|
const transitionStyles: { [str: string]: CSSProperties } = {
|
|
exited: { maxHeight: 0 },
|
|
entering: { maxHeight: maxHeight },
|
|
entered: { maxHeight: 'unset', overflow: 'visible' },
|
|
exiting: { maxHeight: 0 },
|
|
};
|
|
|
|
return (
|
|
<Transition in={inProp} timeout={defaultDuration}>
|
|
{state => (
|
|
<div
|
|
style={{
|
|
...style,
|
|
...transitionStyles[state],
|
|
inProp,
|
|
}}
|
|
>
|
|
{children}
|
|
</div>
|
|
)}
|
|
</Transition>
|
|
);
|
|
};
|