import { formatNumberWithCommas, formatPp } from "@ssr/common/utils/number-utils";
import { GlobeAmericasIcon } from "@heroicons/react/24/solid";
import { useQuery } from "@tanstack/react-query";
import Link from "next/link";
import { ReactElement } from "react";
import Card from "../card";
import CountryFlag from "../country-flag";
import { PlayerRankingSkeleton } from "@/components/ranking/player-ranking-skeleton";
import ScoreSaberPlayer from "@ssr/common/player/impl/scoresaber-player";
import { getPlayersAroundPlayer } from "@ssr/common/utils/player-utils";
import { AroundPlayer } from "@ssr/common/types/around-player";
import { PlayerInfo } from "@/components/player/player-info";
const PLAYER_NAME_MAX_LENGTH = 18;
type MiniProps = {
/**
* The type of ranking to display.
*/
type: "Global" | "Country";
/**
* The player on this profile.
*/
player: ScoreSaberPlayer;
/**
* Whether the data should be updated
*/
shouldUpdate?: boolean;
};
type Variants = {
[key: string]: {
icon: (player: ScoreSaberPlayer) => ReactElement;
};
};
const miniVariants: Variants = {
Global: {
icon: () =>
Error loading ranking
; } return ({type} Ranking
#{formatNumberWithCommas(rank)}
{formatPp(playerRanking.pp)}pp
{playerRanking.id !== player.id && (0 ? "text-green-400" : "text-red-400"}`}> {ppDifference > 0 ? "+" : ""} {formatPp(ppDifference)}
)}