diff --git a/dashboard/src/app.js b/dashboard/src/app.js index 5cafa93a92..4e9c9e9e6d 100644 --- a/dashboard/src/app.js +++ b/dashboard/src/app.js @@ -33,7 +33,7 @@ import ScrollToTop from './components/ScrollToTop'; import TopBar from './components/TopBar'; import VersionOutdatedAlert from './components/VersionOutdatedAlert'; import ModalConfirm from './components/ModalConfirm'; -import DataLoader, { useDataLoader } from './components/DataLoader'; +import DataLoader, { initialLoadState, useDataLoader } from './components/DataLoader'; import { Bounce, cssTransition, ToastContainer } from 'react-toastify'; import 'react-toastify/dist/ReactToastify.css'; import SentryRoute from './components/Sentryroute'; @@ -90,6 +90,7 @@ if (ENV === 'production') { const App = ({ resetRecoil }) => { const authToken = useRecoilValue(authTokenState); const user = useRecoilValue(userState); + const initialLoad = useRecoilValue(initialLoadState); const recoilResetKey = useRecoilValue(recoilResetKeyState); useEffect(() => { @@ -104,14 +105,22 @@ const App = ({ resetRecoil }) => { const onWindowFocus = (e) => { if (authToken && e.newState === 'active') { API.get({ path: '/check-auth' }) // will force logout if session is expired - .then(() => refresh()); // will refresh data if session is still valid + .then(() => { + if (!!initialLoad) { + // if the app is already loaded + // will refresh data if session is still valid + refresh(); + } else { + console.log('initial load not done'); + } + }); } }; lifecycle.addEventListener('statechange', onWindowFocus); return () => { lifecycle.removeEventListener('statechange', onWindowFocus); }; - }, [authToken, refresh]); + }, [authToken, refresh, initialLoad]); return (