// @ts-nocheck import Head from "next/head" import useSWR from "swr" import {useRouter} from "next/router" type LeaderboardEntry = { name: string, score: number, } const NOTABLE_BOARDS = { "ld52": { title: "Pineapple Surf", decimals: 3, suffix: "s" }, "ld54": { title: "Swear Jar", decimals: 2, prefix: "$" }, "ld54pj3": { title: "Swear Jar v0.6", decimals: 2, prefix: "$" } } // @ts-ignore const fetcher = (...args) => fetch(...args).then(res => res.json()) export default function Home() { const location = useRouter() const hostHeader = location?.query?.["host"] const boardHeader = location?.query?.["board"] let host = typeof hostHeader == "string" ? hostHeader : process.env.NEXT_PUBLIC_DEFAULT_HOST let board = typeof boardHeader == "string" ? boardHeader : process.env.NEXT_PUBLIC_DEFAULT_BOARD const titleHeader = location?.query?.["title"] const decimalsHeader = location?.query?.["decimals"] const prefixHeader = location?.query?.["prefix"] const suffixHeader = location?.query?.["suffix"] let title = typeof titleHeader == "string" ? titleHeader : NOTABLE_BOARDS[board ?? ""]?.title ?? "" let decimals = typeof decimalsHeader == "string" ? parseInt(decimalsHeader) || 0 : NOTABLE_BOARDS[board ?? ""]?.decimals ?? 0 let prefix = typeof prefixHeader == "string" ? prefixHeader : NOTABLE_BOARDS[board ?? ""]?.prefix ?? "" let suffix = typeof suffixHeader == "string" ? suffixHeader : NOTABLE_BOARDS[board ?? ""]?.suffix ?? "" const swr = useSWR(`${host}/board/?board=${board}&offset=0&size=500`, fetcher, {refreshInterval: 30000}) let content if(swr.isLoading || swr.data === undefined) { content = (

Loading

Please wait...

) } else if(swr.error) { content = (

Error

{swr.error}

) } else { const rows = swr.data.map((entry, rank) => { let className = "" rank += 1 if(rank == 1) { className += "gold" } else if(rank == 2) { className += "silver" } else if(rank == 3) { className += "bronze" } return ( {rank} {entry.name} {prefix && `${prefix} `}{entry.score.toFixed(decimals)}{suffix && ` ${suffix}`} ) }) content = ( {rows}
Rank Player Score
) } return ( <> {title} ({board})

{title}

Leaderboards

{content}
) }