add joined date stat
All checks were successful
Deploy Backend / deploy (push) Successful in 2m52s
Deploy Website / deploy (push) Successful in 4m36s

This commit is contained in:
Lee 2024-10-17 02:21:59 +01:00
parent 5263509bac
commit ae4e6912e5
2 changed files with 83 additions and 8 deletions

View File

@ -53,6 +53,46 @@ export function formatDateMinimal(date: Date) {
});
}
/**
* Formats the date
*
* @param date the date to format
* @param format the format to return
* @returns the formatted date
*/
export function formatDate(date: Date, format: "MMMM YYYY" | "DD MMMM YYYY" | "DD MMMM YYYY HH:mm" = "MMMM YYYY") {
switch (format) {
case "MMMM YYYY": {
return date.toLocaleString("en-US", {
timeZone: "Europe/London",
month: "long",
year: "numeric",
});
}
case "DD MMMM YYYY": {
return date.toLocaleString("en-US", {
timeZone: "Europe/London",
day: "numeric",
month: "long",
year: "numeric",
});
}
case "DD MMMM YYYY HH:mm": {
return date.toLocaleString("en-US", {
timeZone: "Europe/London",
day: "numeric",
month: "long",
year: "numeric",
hour: "numeric",
minute: "numeric",
});
}
default: {
return formatDateMinimal(date);
}
}
}
/**
* Gets the midnight aligned date
*

View File

@ -1,11 +1,17 @@
import { formatNumberWithCommas } from "@ssr/common/utils/number-utils";
import StatValue from "@/components/stat-value";
import ScoreSaberPlayer from "@ssr/common/types/player/impl/scoresaber-player";
import { formatDate } from "@ssr/common/utils/time-utils";
import { ReactNode } from "react";
import Tooltip from "@/components/tooltip";
type Badge = {
name: string;
color?: string;
create: (player: ScoreSaberPlayer) => string | React.ReactNode | undefined;
create: (player: ScoreSaberPlayer) => {
tooltip?: string | ReactNode;
value: string | ReactNode;
};
};
const badges: Badge[] = [
@ -13,39 +19,60 @@ const badges: Badge[] = [
name: "Ranked Play Count",
color: "bg-pp",
create: (player: ScoreSaberPlayer) => {
return formatNumberWithCommas(player.statistics.rankedPlayCount);
return {
value: formatNumberWithCommas(player.statistics.rankedPlayCount),
};
},
},
{
name: "Total Ranked Score",
color: "bg-pp",
create: (player: ScoreSaberPlayer) => {
return formatNumberWithCommas(player.statistics.totalRankedScore);
return {
value: formatNumberWithCommas(player.statistics.totalRankedScore),
};
},
},
{
name: "Average Ranked Accuracy",
color: "bg-pp",
create: (player: ScoreSaberPlayer) => {
return player.statistics.averageRankedAccuracy.toFixed(2) + "%";
return {
value: player.statistics.averageRankedAccuracy.toFixed(2) + "%",
};
},
},
{
name: "Total Play Count",
create: (player: ScoreSaberPlayer) => {
return formatNumberWithCommas(player.statistics.totalPlayCount);
return {
value: formatNumberWithCommas(player.statistics.totalPlayCount),
};
},
},
{
name: "Total Score",
create: (player: ScoreSaberPlayer) => {
return formatNumberWithCommas(player.statistics.totalScore);
return {
value: formatNumberWithCommas(player.statistics.totalScore),
};
},
},
{
name: "Total Replays Watched",
create: (player: ScoreSaberPlayer) => {
return formatNumberWithCommas(player.statistics.replaysWatched);
return {
value: formatNumberWithCommas(player.statistics.replaysWatched),
};
},
},
{
name: "Joined Date",
create: (player: ScoreSaberPlayer) => {
return {
tooltip: formatDate(player.joinedDate, "DD MMMM YYYY HH:mm"),
value: formatDate(player.joinedDate),
};
},
},
];
@ -62,8 +89,16 @@ export default function PlayerStats({ player }: Props) {
if (toRender === undefined) {
return <div key={index} />;
}
const { tooltip, value } = toRender;
const stat = <StatValue key={index} color={badge.color} name={badge.name} value={value} />;
return <StatValue key={index} color={badge.color} name={badge.name} value={toRender} />;
return tooltip ? (
<Tooltip asChild={false} display={tooltip}>
{stat}
</Tooltip>
) : (
stat
);
})}
</div>
);