scoresaber-reloaded-v2/src/components/player/PlayerRankingMobile.tsx

55 lines
1.6 KiB
TypeScript
Raw Normal View History

2023-10-22 05:53:53 +00:00
import { ScoresaberPlayer } from "@/schemas/scoresaber/player";
import { useSettingsStore } from "@/store/settingsStore";
import { formatNumber } from "@/utils/number";
import { useStore } from "zustand";
import Avatar from "../Avatar";
2023-10-27 22:37:57 +00:00
import CountyFlag from "../CountryFlag";
2023-10-22 05:53:53 +00:00
import Label from "../Label";
type PlayerRankingProps = {
player: ScoresaberPlayer;
showCountryFlag?: boolean;
};
export default function PlayerRankingMobile({
player,
showCountryFlag = true,
}: PlayerRankingProps) {
const settingsStore = useStore(useSettingsStore, (store) => store);
return (
<div>
<div className="m-3 flex flex-col gap-2">
2023-10-24 10:18:51 +00:00
<p className="flex items-center gap-2">
2023-10-22 05:53:53 +00:00
<p>#{formatNumber(player.rank)}</p>
<Avatar url={player.profilePicture} label="Avatar" size={24} />
{showCountryFlag && (
2023-10-27 22:37:57 +00:00
<CountyFlag countryCode={player.country} className="!h-5 !w-5" />
2023-10-22 05:53:53 +00:00
)}
<p
className={
2023-10-22 09:50:10 +00:00
player.id == settingsStore.player?.id
2023-10-22 05:53:53 +00:00
? "transform-gpu text-red-500 transition-all hover:text-blue-500"
: ""
}
>
{player.name}
</p>
2023-10-24 10:18:51 +00:00
</p>
2023-10-22 05:53:53 +00:00
<div className="flex flex-wrap justify-center gap-2">
<Label
title="PP"
hoverValue="Total amount of pp"
value={`${formatNumber(player.pp)}`}
/>
<Label
title="Total play count"
hoverValue="Total ranked song play count"
value={formatNumber(player.scoreStats.totalPlayCount)}
/>
</div>
</div>
</div>
);
}