2025-04-01 10:38:02 +09:00

30 lines
672 B
TypeScript

import { css } from '@emotion/css';
import { ReactNode } from 'react';
import Skeleton from 'react-loading-skeleton';
import { GrafanaTheme2 } from '@grafana/data';
import { useStyles2 } from '@grafana/ui';
export interface ScopesTreeLoadingProps {
children: ReactNode;
isNodeLoading: boolean;
}
export function ScopesTreeLoading({ children, isNodeLoading }: ScopesTreeLoadingProps) {
const styles = useStyles2(getStyles);
if (isNodeLoading) {
return <Skeleton count={5} className={styles.loader} />;
}
return children;
}
const getStyles = (theme: GrafanaTheme2) => {
return {
loader: css({
margin: theme.spacing(0.5, 0),
}),
};
};