diff --git a/projects/website/src/components/player/player-stats.tsx b/projects/website/src/components/player/player-stats.tsx
index 250bac3..86452a5 100644
--- a/projects/website/src/components/player/player-stats.tsx
+++ b/projects/website/src/components/player/player-stats.tsx
@@ -4,13 +4,11 @@ import ScoreSaberPlayer from "@ssr/common/player/impl/scoresaber-player";
import { formatDate } from "@ssr/common/utils/time-utils";
import { ReactNode } from "react";
import Tooltip from "@/components/tooltip";
-import { DailyChange } from "@/components/statistic/daily-change";
import { getScoreSaberRole } from "@ssr/common/utils/scoresaber.util";
-import { PlayerStatChange } from "@ssr/common/player/player-stat-change";
type Stat = {
name: string;
- color?: string;
+ color?: (player: ScoreSaberPlayer) => string;
create: (player: ScoreSaberPlayer) => {
tooltip?: string | ReactNode;
value: string | ReactNode;
@@ -20,43 +18,28 @@ type Stat = {
const playerStats: Stat[] = [
{
name: "Ranked Play Count",
- color: "bg-pp",
+ color: () => "bg-pp",
create: (player: ScoreSaberPlayer) => {
return {
- value: (
- <>
- {formatNumberWithCommas(player.statistics.rankedPlayCount)}{" "}
-
- >
- ),
+ value: <>{formatNumberWithCommas(player.statistics.rankedPlayCount)}>,
};
},
},
{
name: "Total Ranked Score",
- color: "bg-pp",
+ color: () => "bg-pp",
create: (player: ScoreSaberPlayer) => {
return {
- value: (
- <>
- {formatNumberWithCommas(player.statistics.totalRankedScore)}{" "}
-
- >
- ),
+ value: <>{formatNumberWithCommas(player.statistics.totalRankedScore)}>,
};
},
},
{
name: "Average Ranked Accuracy",
- color: "bg-pp",
+ color: () => "bg-pp",
create: (player: ScoreSaberPlayer) => {
return {
- value: (
- <>
- {player.statistics.averageRankedAccuracy.toFixed(2) + "%"}{" "}
-
- >
- ),
+ value: <>{player.statistics.averageRankedAccuracy.toFixed(2) + "%"}>,
};
},
},
@@ -64,12 +47,7 @@ const playerStats: Stat[] = [
name: "Total Play Count",
create: (player: ScoreSaberPlayer) => {
return {
- value: (
- <>
- {formatNumberWithCommas(player.statistics.totalPlayCount)}{" "}
-
- >
- ),
+ value: <>{formatNumberWithCommas(player.statistics.totalPlayCount)}>,
};
},
},
@@ -77,12 +55,7 @@ const playerStats: Stat[] = [
name: "Total Score",
create: (player: ScoreSaberPlayer) => {
return {
- value: (
- <>
- {formatNumberWithCommas(player.statistics.totalScore)}{" "}
-
- >
- ),
+ value: <>{formatNumberWithCommas(player.statistics.totalScore)}>,
};
},
},
@@ -90,12 +63,7 @@ const playerStats: Stat[] = [
name: "Total Replays Watched",
create: (player: ScoreSaberPlayer) => {
return {
- value: (
- <>
- {formatNumberWithCommas(player.statistics.replaysWatched)}{" "}
-
- >
- ),
+ value: <>{formatNumberWithCommas(player.statistics.replaysWatched)}>,
};
},
},
@@ -114,7 +82,15 @@ const playerStats: Stat[] = [
const role = getScoreSaberRole(player);
return {
- value: role?.name,
+ value: !role ? undefined : (
+
+ {role.name}
+
+ ),
};
},
},
@@ -133,7 +109,7 @@ export default function PlayerStats({ player }: Props) {
return ;
}
const { tooltip, value } = toRender;
- const stat = ;
+ const stat = ;
return (
diff --git a/projects/website/src/components/statistic/daily-change.tsx b/projects/website/src/components/statistic/daily-change.tsx
index e81ad71..35b0921 100644
--- a/projects/website/src/components/statistic/daily-change.tsx
+++ b/projects/website/src/components/statistic/daily-change.tsx
@@ -36,7 +36,7 @@ export function DailyChange({ type, player, change, tooltip }: DailyChangeProps)
}
const value = (
-
0 ? "text-green-400" : "text-red-400"}`}>
+
0 ? "text-green-400" : "text-red-400"}`}>
{change > 0 ? "+" : ""}
{`${formatValue(change)}${type.type == "Performance Points" ? "pp" : ""}`}