From 4665332d16435fba0151cc8290a6bce7ebcd3447 Mon Sep 17 00:00:00 2001 From: Pinapelz Date: Sun, 6 Jul 2025 01:20:12 -0700 Subject: implement Dancerush custom scoreview --- frontend/src/pages/Score.tsx | 23 ++++++++++++++++++----- 1 file changed, 18 insertions(+), 5 deletions(-) (limited to 'frontend/src/pages') diff --git a/frontend/src/pages/Score.tsx b/frontend/src/pages/Score.tsx index a39ce25..8e16a86 100644 --- a/frontend/src/pages/Score.tsx +++ b/frontend/src/pages/Score.tsx @@ -3,8 +3,9 @@ import { useAuth } from "../contexts/AuthContext"; import { useNavigate } from "react-router"; import { NavBar } from "../components/NavBar"; import SessionExpiredPopup from "../components/SessionExpiredPopup"; -import ScoreDisplay from "../components/tables/GenericScoreTable"; - +import ScoreDisplay from "../components/displays/GenericScoreDisplay"; +import DancerushScoreDisplay from "../components/displays/DancerushScoreDisplay"; +// TODO: selector for PB/Recent type SortField = string; type SortDirection = "asc" | "desc"; @@ -17,8 +18,8 @@ const Score = () => { const [currentPage, setCurrentPage] = useState(1); const [numPages, setNumPages] = useState(1); const [viewMode, setViewMode] = useState<"cards" | "table">("cards"); - const [sortField, setSortField] = useState("timestamp"); - const [sortDirection, setSortDirection] = useState("desc"); + const [sortField, setSortField] = useState(""); + const [sortDirection, setSortDirection] = useState("asc"); const gameName = new URLSearchParams(window.location.search).get("game") || "dancerush"; @@ -50,6 +51,8 @@ const Score = () => { url.searchParams.append("userId", user.id); url.searchParams.append("internalGameName", gameName); url.searchParams.append("pageNum", pageNum.toString()); + url.searchParams.append("sortKey", 'timestamp'); + url.searchParams.append("direction", "asc"); const response = await fetch(url.toString()); if (!response.ok) throw new Error("Failed to fetch scores"); @@ -134,7 +137,17 @@ const Score = () => { {(() => { - switch (viewMode) { + switch (gameName) { + case "dancerush": + return ( + + ); default: return (