From aeeaa523f9bcf27d421c13b02a606dfb4d4c22fb Mon Sep 17 00:00:00 2001 From: Liam Date: Sat, 21 Oct 2023 22:25:41 +0100 Subject: [PATCH] make "You" button in navbar show up w/o refreshing page --- src/app/player/[id]/page.tsx | 14 ++++++++--- src/components/Navbar.tsx | 2 +- src/store/settingsStore.ts | 34 +++++++++++++------------- src/utils/{useState.ts => useStore.ts} | 5 +++- 4 files changed, 33 insertions(+), 22 deletions(-) rename src/utils/{useState.ts => useStore.ts} (81%) diff --git a/src/app/player/[id]/page.tsx b/src/app/player/[id]/page.tsx index 16a714e..68a55ea 100644 --- a/src/app/player/[id]/page.tsx +++ b/src/app/player/[id]/page.tsx @@ -13,6 +13,7 @@ import { ScoresaberPlayerScore } from "@/schemas/scoresaber/playerScore"; import { useSettingsStore } from "@/store/settingsStore"; import { formatNumber } from "@/utils/number"; import { fetchScores, getPlayerInfo } from "@/utils/scoresaber/api"; +import useStore from "@/utils/useStore"; import { ClockIcon, GlobeAsiaAustraliaIcon, @@ -59,7 +60,13 @@ const sortTypes: { [key: string]: SortType } = { const DEFAULT_SORT_TYPE = sortTypes.top; export default function Player({ params }: { params: { id: string } }) { - const settingsStore = useSettingsStore(); + const settingsStore = useStore(useSettingsStore, (state) => { + return { + userId: state.userId, + setUserId: state.setUserId, + refreshProfile: state.refreshProfile, + }; + }); const searchParams = useSearchParams(); const router = useRouter(); @@ -135,7 +142,8 @@ export default function Player({ params }: { params: { id: string } }) { ); function claimProfile() { - settingsStore.setUserId(params.id); + settingsStore?.setUserId(params.id); + settingsStore?.refreshProfile(); toast.success("Successfully claimed profile"); } @@ -206,7 +214,7 @@ export default function Player({ params }: { params: { id: string } }) { {/* Settings Buttons */}
- {settingsStore.userId !== params.id && ( + {settingsStore?.userId !== params.id && (