revite/src/context/revoltjs/RequiresOnline.tsx

48 lines
1.2 KiB
TypeScript
Raw Normal View History

2021-07-05 06:23:23 -04:00
import { WifiOff } from "@styled-icons/boxicons-regular";
import styled from "styled-components/macro";
2021-07-05 06:23:23 -04:00
import { Text } from "preact-i18n";
2021-06-19 17:37:12 -04:00
import { useContext } from "preact/hooks";
2021-07-05 06:23:23 -04:00
2021-06-19 17:37:12 -04:00
import Preloader from "../../components/ui/Preloader";
2021-07-05 06:23:23 -04:00
import { Children } from "../../types/Preact";
2021-06-19 17:37:12 -04:00
import { ClientStatus, StatusContext } from "./RevoltClient";
interface Props {
2021-07-05 06:25:20 -04:00
children: Children;
2021-06-19 17:37:12 -04:00
}
const Base = styled.div`
2021-07-05 06:25:20 -04:00
gap: 16px;
padding: 1em;
display: flex;
user-select: none;
align-items: center;
flex-direction: row;
justify-content: center;
color: var(--tertiary-foreground);
background: var(--secondary-header);
> div {
font-size: 18px;
}
2021-06-19 17:37:12 -04:00
`;
export default function RequiresOnline(props: Props) {
2021-07-05 06:25:20 -04:00
const status = useContext(StatusContext);
if (status === ClientStatus.CONNECTING) return <Preloader type="ring" />;
if (status !== ClientStatus.ONLINE && status !== ClientStatus.READY)
return (
<Base>
<WifiOff size={16} />
<div>
<Text id="app.special.requires_online" />
</div>
</Base>
);
return <>{props.children}</>;
2021-06-19 17:37:12 -04:00
}