Files
bigcapital/client/src/components/LoadingIndicator.js
2020-04-05 17:49:44 +02:00

40 lines
994 B
JavaScript

import React, {useState, useEffect, useMemo} from 'react';
import { Spinner } from '@blueprintjs/core';
export default function LoadingIndicator({
loading,
spinnerSize = 40,
children,
mount = true,
}) {
const [rendered, setRendered] = useState(mount);
useEffect(() => {
if (!loading) { setRendered(true); }
}, [loading]);
const componentStyle = useMemo(() => {
return {display: !loading ? 'block' : 'none'};
}, [loading]);
const loadingComponent = useMemo(() => (
<div class='dashboard__loading-indicator'>
<Spinner size={spinnerSize} value={null} />
</div>
), [spinnerSize]);
const renderComponent = useMemo(() => (
<div style={componentStyle}>{ children }</div>
), [children, componentStyle]);
const maybeRenderComponent = (rendered && children) && renderComponent;
const maybeRenderLoadingSpinner = loading && loadingComponent;
return (
<>
{ maybeRenderLoadingSpinner }
{ maybeRenderComponent }
</>
);
}