make mapper name clickable on the leaderboard
Some checks are pending
Deploy Website / docker (ubuntu-latest) (push) Waiting to run
Deploy Backend / docker (ubuntu-latest) (push) Successful in 1m11s

This commit is contained in:
Lee
2024-10-20 13:43:25 +01:00
parent 4d8debe333
commit 57a9780fe8
5 changed files with 29 additions and 10 deletions

View File

@ -0,0 +1,11 @@
import { BeatSaverMap } from "../model/beatsaver/beatsaver-map";
/**
* Gets the beatSaver mapper profile url.
*
* @param map the beatsaver map
* @returns the beatsaver mapper profile url
*/
export function getBeatSaverMapperProfileUrl(map?: BeatSaverMap) {
return map != undefined ? `https://beatsaver.com/profile/${map?.author.id}` : undefined;
}

View File

@ -1,6 +1,6 @@
import ScoreSaberPlayerToken from "./types/token/scoresaber/score-saber-player-token";
import ScoreSaberLeaderboardPlayerInfoToken from "./types/token/scoresaber/score-saber-leaderboard-player-info-token";
import ScoreSaberPlayer from "./player/impl/scoresaber-player";
import ScoreSaberPlayerToken from "../types/token/scoresaber/score-saber-player-token";
import ScoreSaberLeaderboardPlayerInfoToken from "../types/token/scoresaber/score-saber-leaderboard-player-info-token";
import ScoreSaberPlayer from "../player/impl/scoresaber-player";
type ScoreSaberRole = {
/**

View File

@ -4,6 +4,8 @@ import { LeaderboardSongStarCount } from "@/components/leaderboard/leaderboard-s
import ScoreButtons from "@/components/score/score-buttons";
import ScoreSaberLeaderboard from "@ssr/common/leaderboard/impl/scoresaber-leaderboard";
import { BeatSaverMap } from "@ssr/common/model/beatsaver/beatsaver-map";
import { getBeatSaverMapperProfileUrl } from "@ssr/common/utils/beatsaver.util";
import FallbackLink from "@/components/fallback-link";
type LeaderboardInfoProps = {
/**
@ -35,7 +37,12 @@ export function LeaderboardInfo({ leaderboard, beatSaverMap }: LeaderboardInfoPr
{/* Song Stats */}
<div className="text-sm">
<p>
Mapper: <span className="text-pp font-semibold">{leaderboard.levelAuthorName}</span>
Mapper:{" "}
<FallbackLink href={getBeatSaverMapperProfileUrl(beatSaverMap)}>
<span className="text-pp font-semibold hover:brightness-[66%] transform-gpu transition-all">
{leaderboard.levelAuthorName}
</span>
</FallbackLink>
</p>
<p>
Plays: <span className="font-semibold">{leaderboard.plays}</span> ({leaderboard.dailyPlays} today)

View File

@ -139,9 +139,9 @@ export default function LeaderboardScores({
{currentScores.scores.length === 0 && <p>No scores found. Invalid Page?</p>}
</div>
<div className="flex gap-2 justify-center items-center flex-wrap">
{showDifficulties &&
leaderboard.difficulties.map(({ difficultyRaw, leaderboardId }) => {
{showDifficulties && (
<div className="flex gap-2 justify-center items-center flex-wrap">
{leaderboard.difficulties.map(({ difficultyRaw, leaderboardId }) => {
const difficulty = getDifficultyFromRawDifficulty(difficultyRaw);
// todo: add support for other gamemodes?
if (difficulty.gamemode !== "Standard") {
@ -166,7 +166,8 @@ export default function LeaderboardScores({
</Button>
);
})}
</div>
</div>
)}
<div className="overflow-x-auto relative">
<table className="table w-full table-auto border-spacing-2 border-none text-left text-sm">
@ -179,7 +180,7 @@ export default function LeaderboardScores({
<th className="px-2 py-1 text-center">Accuracy</th>
<th className="px-2 py-1 text-center">Misses</th>
<th className="px-2 py-1 text-center">PP</th>
<th className="px-2 py-1 text-center">Modifiers</th>
<th className="px-2 py-1 text-center">Mods</th>
</tr>
</thead>
<motion.tbody initial="hidden" animate={controls} className="border-none" variants={scoreAnimation}>

View File

@ -3,9 +3,9 @@ import CountryFlag from "@/components/country-flag";
import Link from "next/link";
import ScoreSaberPlayerToken from "@ssr/common/types/token/scoresaber/score-saber-player-token";
import ScoreSaberLeaderboardPlayerInfoToken from "@ssr/common/types/token/scoresaber/score-saber-leaderboard-player-info-token";
import { getScoreSaberRole } from "@ssr/common/scoresaber.util";
import ScoreSaberPlayer from "@ssr/common/player/impl/scoresaber-player";
import { clsx } from "clsx";
import { getScoreSaberRole } from "@ssr/common/scoresaber.util";
type TablePlayerProps = {
/**