1
0
Fork 0
panel/components/cards/ServerCard.tsx

34 lines
926 B
TypeScript

import { Server } from "revolt-api";
import { Card, CardDescription, CardHeader, CardTitle } from "../ui/card";
import { Avatar, AvatarFallback, AvatarImage } from "../ui/avatar";
import { AUTUMN_URL } from "@/lib/constants";
export function ServerCard({
server,
subtitle,
}: {
server: Server;
subtitle: string;
}) {
return (
<Card>
<CardHeader>
<CardTitle className="flex items-center gap-1">
<Avatar>
<AvatarImage src={`${AUTUMN_URL}/icons/${server.icon?._id}`} />
<AvatarFallback>
{server.name
.split(" ")
.slice(0, 2)
.map((x) => String.fromCodePoint(x.codePointAt(0) ?? 32) ?? "")
.join("")}
</AvatarFallback>
</Avatar>
{server.name}
</CardTitle>
<CardDescription>{subtitle}</CardDescription>
</CardHeader>
</Card>
);
}