mirror of
https://github.com/revoltchat/revite.git
synced 2025-01-06 12:44:46 -05:00
45 lines
1.1 KiB
TypeScript
45 lines
1.1 KiB
TypeScript
|
import { Text } from "preact-i18n";
|
||
|
import styled from "styled-components";
|
||
|
import { useContext } from "preact/hooks";
|
||
|
import { Children } from "../../types/Preact";
|
||
|
import { WifiOff } from "@styled-icons/feather";
|
||
|
import Preloader from "../../components/ui/Preloader";
|
||
|
import { ClientStatus, StatusContext } from "./RevoltClient";
|
||
|
|
||
|
interface Props {
|
||
|
children: Children;
|
||
|
}
|
||
|
|
||
|
const Base = styled.div`
|
||
|
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;
|
||
|
}
|
||
|
`;
|
||
|
|
||
|
export default function RequiresOnline(props: Props) {
|
||
|
const status = useContext(StatusContext);
|
||
|
|
||
|
if (status === ClientStatus.CONNECTING) return <Preloader />;
|
||
|
if (status !== ClientStatus.ONLINE && status !== ClientStatus.READY)
|
||
|
return (
|
||
|
<Base>
|
||
|
<WifiOff size={16} />
|
||
|
<div>
|
||
|
<Text id="app.special.requires_online" />
|
||
|
</div>
|
||
|
</Base>
|
||
|
);
|
||
|
|
||
|
return <>{ props.children }</>;
|
||
|
}
|