/* * MHSF, Minehut Server List * All external content is rather licensed under the ECA Agreement * located here: https://mhsf.app/docs/legal/external-content-agreement * * All code under MHSF is licensed under the MIT License * by open source contributors * * Copyright (c) 2025 dvelo * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to * deal in the Software without restriction, including without limitation the * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or * sell copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR * OTHER DEALINGS IN THE SOFTWARE. */ "use client"; import { Button } from "@/components/ui/button"; import { Skeleton } from "@/components/ui/skeleton"; import { useClerk, useUser } from "@clerk/nextjs"; import { ArrowDown, GalleryVertical, Star } from "lucide-react"; import { useTheme } from "@/lib/hooks/use-theme"; import { useRouter } from "next/navigation"; import { use, useEffect, useState } from "react"; import { Gradient } from "stripe-gradient"; import { Material } from "@/components/ui/material"; import { Badge } from "@/components/ui/badge"; import { AuroraText } from "./aurora-text"; import { AnimatedList } from "./animated-list"; import { cn } from "@/lib/utils"; import { ExampleChart } from "./example-chart"; import { Link } from "@/components/util/link"; import { type Avatar, AvatarCircles } from "./avatar-circles"; import { Ripple } from "./ripple"; const getGitHubDetails = async () => { const githubRepo = await ( await fetch("https://api.github.com/repos/DeveloLongScript/mhsf") ).json(); const githubStargazers = await ( await fetch("https://api.github.com/repos/DeveloLongScript/mhsf/stargazers") ).json(); return { stars: githubRepo.stargazers_count as number, stargazers: ( githubStargazers as Array<{ avatar_url: string; html_url: string }> ).map((c) => { return { imageUrl: c.avatar_url, profileUrl: c.html_url }; }), }; }; export default function HomePageComponent() { const clerk = useClerk(); const router = useRouter(); const { isSignedIn } = useUser(); const theme = useTheme(); const { resolvedTheme } = useTheme(); const [stars, setStars] = useState(0); const [stargazers, setStargazers] = useState([]); const [gradientId, setGradientId] = useState("gradient-banner"); useEffect(() => { setGradientId("gradient-banner"); const gradient = new Gradient(); gradient.initGradient(`#${gradientId}`); }, [gradientId]); useEffect(() => { getGitHubDetails().then((c) => { setStars(c.stars); setStargazers(c.stargazers); }); }, []); return (

The missing half of Minehut

MHSF is the next generation Minehut server list wrapper, with
interactive filters, customizable web-pages, a modern interface and{" "}
everything in-between.






An open-source unofficial project brought to you by dvelo

For server hunters

Find what you want now.
Not later.

MHSF is built for finding servers, and only that, along with{" "}
allowing for maximum customizability with
both your experience and the webpages you interact with.{" "}

{" "} Filter Demo{" "}

Build your dream server list

Server lists are massive. Using custom filters and sorting systems
allow you to shrink the amount of information you see in the way{" "}
you want it.

{Array.from({ length: 100 }, () => [ { name: "Cannot find name 'flse'.", code: "2304" }, { name: "Type 'string' is not assignable to type 'boolean'.", code: "2322", }, { name: "'mhsf' has no exported member named 'Mincehut'. Did you mean 'Minehut'?", code: "2724", }, { name: "Cannot find namespace 'React'.", code: "2503" }, { name: "'server' is declared but its value is never read.", code: "6133", }, { name: "This comparison appears to be unintentional because the types 'string' and 'boolean' have no overlap", code: "2367", }, ]) .reverse() .flat() .map((c) => ( ))} Type-safety across the board

Completely safe TypeScript code is easily achieveable when using MHSF custom modification with fully functioning TypeScript error detection.

Alert Demo Lint your code instantly

Worried your code is broken? Run a simulation of your modification or lint it very quickly.

Interactive Demo Interactively edit your code

MHSF uses the Monaco Editor as the editor of choice for all custom modifications; the same editor that powers the Visual Studio Code editor.

For data hunters

Your data? No problem.

Data for servers are openly accessible behind no paywall or{" "}
verification for thousands of servers over millions of total{" "}
entries.


Don't trust us? We're open-source.

MHSF's entire codebase from microservice to frontend is
completely open-source under the MIT License.


For server owners
); } function TypeScriptError({ name, code }: { name: string; code: string }) { return (

{name} ยท ts({code})

); }