mirror of
https://github.com/DeveloLongScript/MHSF.git
synced 2026-05-07 19:24:59 -05:00
115 lines
3.2 KiB
TypeScript
115 lines
3.2 KiB
TypeScript
|
|
import ServerView from "@/components/ServerView";
|
||
|
|
import {
|
||
|
|
Breadcrumb,
|
||
|
|
BreadcrumbItem,
|
||
|
|
BreadcrumbLink,
|
||
|
|
BreadcrumbList,
|
||
|
|
BreadcrumbPage,
|
||
|
|
BreadcrumbSeparator,
|
||
|
|
} from "@/components/ui/breadcrumb";
|
||
|
|
import TopBar from "@/components/clerk/Topbar";
|
||
|
|
import { Server } from "lucide-react";
|
||
|
|
import type { Metadata, ResolvingMetadata } from "next";
|
||
|
|
import { IconDisplayClient } from "@/components/IconDisplay";
|
||
|
|
import { banner } from "@/banner";
|
||
|
|
|
||
|
|
type Props = {
|
||
|
|
params: { server: string };
|
||
|
|
};
|
||
|
|
|
||
|
|
export async function generateMetadata(
|
||
|
|
{ params }: Props,
|
||
|
|
parent: ResolvingMetadata,
|
||
|
|
): Promise<Metadata> {
|
||
|
|
// read route params
|
||
|
|
const { server } = params;
|
||
|
|
const json = await (
|
||
|
|
await fetch("https://api.minehut.com/server/" + server + "?byName=true")
|
||
|
|
).json();
|
||
|
|
|
||
|
|
return {
|
||
|
|
title:
|
||
|
|
json.server == null
|
||
|
|
? "Server doesn't exist | MHSF"
|
||
|
|
: json.server.name +
|
||
|
|
", " +
|
||
|
|
(json.server.online
|
||
|
|
? json.server.playerCount +
|
||
|
|
(json.server.maxPlayers != 10
|
||
|
|
? "/" + json.server.maxPlayers
|
||
|
|
: "") +
|
||
|
|
" online"
|
||
|
|
: "Offline") +
|
||
|
|
" | MHSF",
|
||
|
|
description:
|
||
|
|
json.server == null
|
||
|
|
? `The server ${server} doesn't exist.`
|
||
|
|
: `View ${server} on Minehut Server Finder!`,
|
||
|
|
authors: json.server == null ? undefined : { name: json.server.owner },
|
||
|
|
applicationName: "MHSF (Minehut Server Finder)",
|
||
|
|
icons:
|
||
|
|
json.server == null
|
||
|
|
? undefined
|
||
|
|
: "https://mcapi.marveldc.me/item/" +
|
||
|
|
(json.server.icon == undefined ? "OAK_SIGN" : json.server.icon) +
|
||
|
|
"?width=64&height=64",
|
||
|
|
openGraph: {
|
||
|
|
type: "profile",
|
||
|
|
siteName: "MHSF (Minehut Server Finder)",
|
||
|
|
images: [
|
||
|
|
{
|
||
|
|
url:
|
||
|
|
"https://mcapi.marveldc.me/item/" +
|
||
|
|
json.server.icon +
|
||
|
|
"?width=64&height=64",
|
||
|
|
},
|
||
|
|
{
|
||
|
|
url: "/favicon.ico",
|
||
|
|
},
|
||
|
|
],
|
||
|
|
},
|
||
|
|
};
|
||
|
|
}
|
||
|
|
|
||
|
|
export default function ServerPage({ params }: { params: { server: string } }) {
|
||
|
|
return (
|
||
|
|
<main>
|
||
|
|
{banner.isBanner && (
|
||
|
|
<div className="bg-orange-600 w-screen h-8 border-b fixed text-black flex items-center text-center font-medium pl-2">
|
||
|
|
{banner.bannerText}
|
||
|
|
</div>
|
||
|
|
)}
|
||
|
|
|
||
|
|
<div
|
||
|
|
className={
|
||
|
|
"w-screen h-12 border-b fixed backdrop-blur flex " +
|
||
|
|
(banner.isBanner == true ? "mt-8" : "")
|
||
|
|
}
|
||
|
|
>
|
||
|
|
<div className=" me-auto mt-3 pl-7">
|
||
|
|
<Breadcrumb className=" ">
|
||
|
|
<BreadcrumbList>
|
||
|
|
<BreadcrumbItem className=" max-sm:hidden">
|
||
|
|
<Server />
|
||
|
|
</BreadcrumbItem>
|
||
|
|
<BreadcrumbSeparator className=" max-sm:hidden" />
|
||
|
|
<BreadcrumbItem className=" max-sm:hidden">
|
||
|
|
Server
|
||
|
|
</BreadcrumbItem>
|
||
|
|
<BreadcrumbSeparator className=" max-sm:hidden" />
|
||
|
|
<BreadcrumbItem>
|
||
|
|
<BreadcrumbPage>{params.server}</BreadcrumbPage>
|
||
|
|
</BreadcrumbItem>
|
||
|
|
</BreadcrumbList>
|
||
|
|
</Breadcrumb>
|
||
|
|
</div>
|
||
|
|
<TopBar />
|
||
|
|
</div>
|
||
|
|
|
||
|
|
<div className=" pt-24">
|
||
|
|
<ServerView server={params.server} />
|
||
|
|
</div>
|
||
|
|
</main>
|
||
|
|
);
|
||
|
|
}
|