Redirect after login
This commit is contained in:
parent
6d39f8bae0
commit
0bd8800402
3 changed files with 69 additions and 20 deletions
33
src/App.jsx
33
src/App.jsx
|
|
@ -20,6 +20,7 @@ import {
|
|||
Switch,
|
||||
Route,
|
||||
Redirect,
|
||||
useLocation,
|
||||
} from "react-router-dom";
|
||||
import { useConferenceCallManager } from "./ConferenceCallManagerHooks";
|
||||
import { JoinOrCreateRoom } from "./JoinOrCreateRoom";
|
||||
|
|
@ -48,16 +49,34 @@ export default function App() {
|
|||
<LoginOrRegister onRegister={register} onLogin={login} />
|
||||
)}
|
||||
</Route>
|
||||
<Route path="/room/:roomId">
|
||||
{!authenticated ? (
|
||||
<Redirect to="/" />
|
||||
) : (
|
||||
<Room manager={manager} />
|
||||
)}
|
||||
</Route>
|
||||
<AuthenticatedRoute
|
||||
authenticated={authenticated}
|
||||
path="/room/:roomId"
|
||||
>
|
||||
<Room manager={manager} />
|
||||
</AuthenticatedRoute>
|
||||
</Switch>
|
||||
)}
|
||||
</div>
|
||||
</Router>
|
||||
);
|
||||
}
|
||||
|
||||
function AuthenticatedRoute({ authenticated, children, ...rest }) {
|
||||
const location = useLocation();
|
||||
|
||||
return (
|
||||
<Route {...rest}>
|
||||
{authenticated ? (
|
||||
children
|
||||
) : (
|
||||
<Redirect
|
||||
to={{
|
||||
pathname: "/",
|
||||
state: { from: location },
|
||||
}}
|
||||
/>
|
||||
)}
|
||||
</Route>
|
||||
);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue