only show extra charts if the player is being tracked
Some checks failed
Deploy / deploy (push) Has been cancelled

This commit is contained in:
Lee 2024-10-02 10:48:28 +01:00
parent 859df1dea3
commit 37ea0f4244
3 changed files with 45 additions and 28 deletions

View File

@ -37,7 +37,7 @@ export default interface ScoreSaberPlayer extends Player {
/**
* The rank history for this player.
*/
statisticHistory: { [date: string]: PlayerHistory };
statisticHistory: { [key: string]: PlayerHistory };
/**
* The statistics for this player.
@ -58,6 +58,12 @@ export default interface ScoreSaberPlayer extends Player {
* Whether the player is inactive or not.
*/
inactive: boolean;
/**
* Whether the player is having their
* statistics being tracked or not.
*/
isBeingTracked?: boolean;
}
export async function getScoreSaberPlayerFromToken(token: ScoreSaberPlayerToken): Promise<ScoreSaberPlayer> {
@ -74,6 +80,7 @@ export async function getScoreSaberPlayerFromToken(token: ScoreSaberPlayerToken)
};
}) || [];
let isBeingTracked = false;
const todayDate = formatDateMinimal(getMidnightAlignedDate(new Date()));
let statisticHistory: { [key: string]: PlayerHistory } = {};
try {
@ -96,6 +103,8 @@ export async function getScoreSaberPlayerFromToken(token: ScoreSaberPlayerToken)
averageRankedAccuracy: token.scoreStats.averageRankedAccuracy,
},
};
isBeingTracked = true;
}
statisticHistory = history;
} catch (error) {
@ -168,6 +177,7 @@ export async function getScoreSaberPlayerFromToken(token: ScoreSaberPlayerToken)
permissions: token.permissions,
banned: token.banned,
inactive: token.inactive,
isBeingTracked: isBeingTracked,
};
}

View File

@ -1,10 +1,10 @@
"use client";
import ScoreSaberPlayer from "@/common/model/player/impl/scoresaber-player";
import PlayerAccuracyChart from "@/components/player/chart/player-accuracy-chart";
import PlayerRankingChart from "@/components/player/chart/player-ranking-chart";
import { FC, useState } from "react";
import Tooltip from "@/components/tooltip";
import PlayerAccuracyChart from "@/components/player/chart/player-accuracy-chart";
type PlayerChartsProps = {
/**
@ -37,12 +37,15 @@ export default function PlayerCharts({ player }: PlayerChartsProps) {
chart: PlayerRankingChart,
label: "Ranking",
},
{
];
if (player.isBeingTracked) {
charts.push({
index: 1,
chart: PlayerAccuracyChart,
label: "Accuracy",
},
];
});
}
const [selectedChart, setSelectedChart] = useState<SelectedChart>(charts[0]);
return (
@ -50,26 +53,27 @@ export default function PlayerCharts({ player }: PlayerChartsProps) {
{selectedChart.chart({ player })}
<div className="flex items-center justify-center gap-2">
{charts.map(chart => {
const isSelected = chart.index === selectedChart.index;
{charts.length > 1 &&
charts.map(chart => {
const isSelected = chart.index === selectedChart.index;
return (
<Tooltip
key={chart.index}
display={
<div className="flex justify-center items-center flex-col">
<p>{chart.label} Chart</p>
<p className="text-gray-600">{isSelected ? "Currently Selected" : "Click to view"}</p>
</div>
}
>
<button
onClick={() => setSelectedChart(chart)}
className={`border ${isSelected ? "bg-input brightness-75" : "border-input"} w-fit p-2 rounded-full`}
/>
</Tooltip>
);
})}
return (
<Tooltip
key={chart.index}
display={
<div className="flex justify-center items-center flex-col">
<p>{chart.label} Chart</p>
<p className="text-gray-600">{isSelected ? "Currently Selected" : "Click to view"}</p>
</div>
}
>
<button
onClick={() => setSelectedChart(chart)}
className={`border ${isSelected ? "bg-input brightness-75" : "border-input"} w-fit p-2 rounded-full`}
/>
</Tooltip>
);
})}
</div>
</>
);

View File

@ -126,9 +126,12 @@ export default function PlayerScores({ initialScoreData, initialSearch, player,
/**
* Gets the URL to the page.
*/
const getUrl = (page: number) => {
return `/player/${player.id}/${pageState.sort}/${page}${isSearchActive ? `?search=${debouncedSearchTerm}` : ""}`;
};
const getUrl = useCallback(
(page: number) => {
return `/player/${player.id}/${pageState.sort}/${page}${isSearchActive ? `?search=${debouncedSearchTerm}` : ""}`;
},
[debouncedSearchTerm, player.id, pageState.sort]
);
/**
* Handle updating the URL when the page number,
@ -137,7 +140,7 @@ export default function PlayerScores({ initialScoreData, initialSearch, player,
useEffect(() => {
const newUrl = getUrl(pageState.page);
window.history.replaceState({ ...window.history.state, as: newUrl, url: newUrl }, "", newUrl);
}, [pageState, debouncedSearchTerm, player.id, isSearchActive, getUrl]);
}, [pageState, debouncedSearchTerm, player.id, isSearchActive]);
/**k
* Handle scrolling to the top of the