1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-06 00:07:44 +01:00
unleash.unleash/frontend/src/component/splash/SplashPage/SplashPage.tsx

66 lines
2.1 KiB
TypeScript
Raw Normal View History

import { Switch, Route, useHistory, Redirect } from 'react-router-dom';
import { SplashPageEnvironments } from '../SplashPageEnvironments/SplashPageEnvironments';
import { useRequiredPathParam } from 'hooks/useRequiredPathParam';
import useSplashApi from 'hooks/api/actions/useSplashApi/useSplashApi';
import { SplashPageOperators } from 'component/splash/SplashPageOperators/SplashPageOperators';
import { useEffect } from 'react';
import { useAuthSplash } from 'hooks/api/getters/useAuth/useAuthSplash';
import { splashIds, SplashId } from 'component/splash/splash';
export const SplashPage = () => {
const splashId = useRequiredPathParam('splashId');
const isKnownId = isKnownSplashId(splashId);
const { refetchSplash } = useAuthSplash();
const { setSplashSeen } = useSplashApi();
// Close the splash "modal" on escape.
useNavigationOnKeydown('Escape', '/');
// Mark the splash ID as seen.
useEffect(() => {
if (splashId && isKnownId) {
setSplashSeen(splashId)
.then(() => refetchSplash())
.catch(console.warn);
}
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [splashId, isKnownId]);
if (!isKnownId) {
return null;
}
return (
<Switch>
<Route path="/splash/environments">
<SplashPageEnvironments />
</Route>
<Route path="/splash/operators">
<SplashPageOperators />
</Route>
<Route>
<Redirect to="/" />
</Route>
</Switch>
);
};
const useNavigationOnKeydown = (key: string, path: string) => {
const { push } = useHistory();
useEffect(() => {
const handler = (event: KeyboardEvent) => {
if (event.code === key) {
push(path);
}
};
window.addEventListener('keydown', handler);
return () => window.removeEventListener('keydown', handler);
}, [key, path, push]);
};
const isKnownSplashId = (value: string): value is SplashId => {
return (splashIds as Readonly<string[]>).includes(value);
};