Files
Frontend/src/app/(pages)/server/[platform]/[hostname]/page.tsx

101 lines
3.2 KiB
TypeScript
Raw Normal View History

2024-04-16 19:12:26 +01:00
import { NotFound } from "@/app/components/not-found";
import { LookupServer } from "@/app/components/server/lookup-server";
import { Card } from "@/app/components/ui/card";
2024-04-16 18:14:15 +01:00
import { generateEmbed } from "@/common/embed";
2024-04-16 17:54:22 +01:00
import { capitalizeFirstLetter } from "@/common/string-utils";
import { getServer } from "mcutils-library";
import JavaMinecraftServer from "mcutils-library/dist/types/server/javaServer";
import { ServerPlatform } from "mcutils-library/dist/types/server/platform";
import { MinecraftServer } from "mcutils-library/dist/types/server/server";
import { Metadata } from "next";
2024-04-16 18:49:23 +01:00
import Image from "next/image";
2024-04-16 17:54:22 +01:00
type Params = {
params: {
platform: ServerPlatform;
hostname: string;
};
};
export async function generateMetadata({ params: { platform, hostname } }: Params): Promise<Metadata> {
const server = await getData(platform, hostname);
if (server == null) {
2024-04-16 19:35:07 +01:00
return generateEmbed({ title: "Unknown Server", description: "Server not responding" });
2024-04-16 17:54:22 +01:00
}
const { hostname: serverHostname, players } = server;
let favicon = null; // Server favicon
2024-04-16 17:54:22 +01:00
// Java specific
2024-04-16 17:54:22 +01:00
if (platform === ServerPlatform.Java) {
const javaServer = server as JavaMinecraftServer;
favicon = javaServer.favicon && javaServer.favicon.url;
}
const description = `
${capitalizeFirstLetter(platform)} Server
Hostname: ${serverHostname}
${players.online}/${players.max} players online`;
2024-04-16 18:14:15 +01:00
return generateEmbed({
title: `${serverHostname}`,
description: description,
image: favicon,
});
2024-04-16 17:54:22 +01:00
}
async function getData(platform: ServerPlatform, id: string): Promise<MinecraftServer | null> {
try {
const cachedServer = await getServer(platform, id);
return cachedServer.server;
} catch (error) {
return null; // Server not found
}
}
export default async function Page({ params: { platform, hostname } }: Params) {
const server = await getData(platform, hostname);
2024-04-16 18:49:23 +01:00
let favicon = null; // Server favicon
// Java specific
if (server && platform === ServerPlatform.Java) {
2024-04-16 18:49:23 +01:00
const javaServer = server as JavaMinecraftServer;
favicon = javaServer.favicon && javaServer.favicon.url;
}
2024-04-16 17:54:22 +01:00
return (
<div className="h-full flex flex-col items-center">
<div className="mb-4 text-center">
2024-04-16 18:49:23 +01:00
<h1 className="text-xl">Lookup a {capitalizeFirstLetter(platform)} Server</h1>
2024-04-16 17:54:22 +01:00
<p>You can enter a server hostname to get information about the server.</p>
<LookupServer />
</div>
<Card>
2024-04-16 19:35:07 +01:00
{server == null && <NotFound message="Server not responding" />}
2024-04-16 17:54:22 +01:00
{server != null && (
2024-04-16 18:49:23 +01:00
<div className="flex gap-2 flex-col md:flex-row">
{favicon && (
<div className="flex justify-center md:justify-start">
<Image className="w-[96px] h-[96px]" src={favicon} width={96} height={96} alt="The server's favicon" />
2024-04-16 18:49:23 +01:00
</div>
)}
<div className="flex flex-col">
<h2 className="text-xl">{server.hostname}</h2>
<div className="text-gray-300">
<p>
Players online: {server.players.online}/{server.players.max}
</p>
</div>
</div>
2024-04-16 17:54:22 +01:00
</div>
)}
</Card>
</div>
);
}