authorizer/app/src/Root.tsx
2021-08-09 08:46:07 +05:30

46 lines
927 B
TypeScript

import React, { useEffect } from 'react';
import { Switch, Route } from 'react-router-dom';
import { useAuthorizer } from '@authorizerdev/authorizer-react';
import Dashboard from './pages/dashboard';
import Login from './pages/login';
import ResetPassword from './pages/rest-password';
export default function Root() {
const { token, loading, config } = useAuthorizer();
useEffect(() => {
if (token) {
const url = new URL(config.redirectURL);
if (url.origin !== window.location.origin) {
window.location.href = config.redirectURL;
}
}
return () => {};
}, [token]);
if (loading) {
return <h1>Loading...</h1>;
}
if (token) {
return (
<Switch>
<Route path="/app" exact>
<Dashboard />
</Route>
</Switch>
);
}
return (
<Switch>
<Route path="/app" exact>
<Login />
</Route>
<Route path="/app/reset-password">
<ResetPassword />
</Route>
</Switch>
);
}