revite/src/components/common/ServerHeader.tsx

43 lines
1.3 KiB
TypeScript
Raw Normal View History

2021-06-27 06:17:59 -04:00
import { Cog } from "@styled-icons/boxicons-solid";
2021-07-29 14:01:40 -04:00
import { observer } from "mobx-react-lite";
2021-07-05 06:23:23 -04:00
import { Link } from "react-router-dom";
import { ServerPermission } from "revolt.js/dist/api/permissions";
2021-07-30 17:40:49 -04:00
import { Server } from "revolt.js/dist/maps/Servers";
2021-07-05 06:23:23 -04:00
import styled from "styled-components";
import Header from "../ui/Header";
import IconButton from "../ui/IconButton";
interface Props {
2021-07-05 06:25:20 -04:00
server: Server;
}
const ServerName = styled.div`
2021-07-05 06:25:20 -04:00
flex-grow: 1;
`;
2021-07-29 14:01:40 -04:00
export default observer(({ server }: Props) => {
2021-07-30 17:40:49 -04:00
const bannerURL = server.generateBannerURL({ width: 480 });
2021-07-05 06:25:20 -04:00
return (
<Header
borders
placement="secondary"
background={typeof bannerURL !== "undefined"}
style={{
background: bannerURL ? `url('${bannerURL}')` : undefined,
}}>
<ServerName>{server.name}</ServerName>
2021-07-30 17:40:49 -04:00
{(server.permission & ServerPermission.ManageServer) > 0 && (
2021-07-05 06:25:20 -04:00
<div className="actions">
<Link to={`/server/${server._id}/settings`}>
<IconButton>
<Cog size={24} />
</IconButton>
</Link>
</div>
)}
</Header>
);
2021-07-29 14:01:40 -04:00
});