This commit is contained in:
@ -59,7 +59,7 @@ export default function Player({ params }: { params: { id: string } }) {
|
||||
return;
|
||||
}
|
||||
|
||||
ScoreSaberAPI.getPlayerInfo(params.id).then((playerResponse) => {
|
||||
ScoreSaberAPI.fetchPlayerData(params.id).then((playerResponse) => {
|
||||
if (!playerResponse) {
|
||||
setError(true);
|
||||
setErrorMessage("Failed to fetch player. Is the ID correct?");
|
||||
|
@ -27,7 +27,7 @@ export default function SearchPlayer() {
|
||||
const id = search.split("/").pop();
|
||||
if (id == undefined) return;
|
||||
|
||||
const player = await ScoreSaberAPI.getPlayerInfo(id);
|
||||
const player = await ScoreSaberAPI.fetchPlayerData(id);
|
||||
if (player == undefined) return;
|
||||
|
||||
setPlayers([player]);
|
||||
|
@ -314,7 +314,6 @@ export const useScoresaberScoresStore = create<ScoreSaberScoresStore>()(
|
||||
players: newPlayers,
|
||||
lastUpdated: Date.now(),
|
||||
});
|
||||
console.log(friends);
|
||||
}
|
||||
},
|
||||
}),
|
||||
|
@ -9,16 +9,16 @@ import { createJSONStorage, persist } from "zustand/middleware";
|
||||
|
||||
interface SettingsStore {
|
||||
player: ScoresaberPlayer | undefined;
|
||||
lastUsedSortType: SortType;
|
||||
friends: ScoresaberPlayer[];
|
||||
lastUsedSortType: SortType;
|
||||
profilesLastUpdated: number;
|
||||
|
||||
setProfile: (playerData: ScoresaberPlayer) => void;
|
||||
setLastUsedSortType: (sortType: SortType) => void;
|
||||
addFriend: (friendId: string) => Promise<boolean>;
|
||||
removeFriend: (friendId: string) => void;
|
||||
isFriend: (friendId: string) => boolean;
|
||||
clearFriends: () => void;
|
||||
setLastUsedSortType: (sortType: SortType) => void;
|
||||
setProfilesLastUpdated: (profilesLastUpdated: number) => void;
|
||||
refreshProfiles: () => void;
|
||||
}
|
||||
@ -39,16 +39,13 @@ export const useSettingsStore = create<SettingsStore>()(
|
||||
});
|
||||
},
|
||||
|
||||
setLastUsedSortType: (sortType: SortType) =>
|
||||
set({ lastUsedSortType: sortType }),
|
||||
|
||||
async addFriend(friendId: string) {
|
||||
const friends = useSettingsStore.getState().friends;
|
||||
if (friends.some((friend) => friend.id == friendId)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
const friend = await ScoreSaberAPI.getPlayerInfo(friendId);
|
||||
const friend = await ScoreSaberAPI.fetchPlayerData(friendId);
|
||||
if (friend == undefined || friend == null) return false;
|
||||
|
||||
set({ friends: [...friends, friend] });
|
||||
@ -73,6 +70,10 @@ export const useSettingsStore = create<SettingsStore>()(
|
||||
set({ profilesLastUpdated });
|
||||
},
|
||||
|
||||
setLastUsedSortType: (sortType: SortType) => {
|
||||
set({ lastUsedSortType: sortType });
|
||||
},
|
||||
|
||||
async refreshProfiles() {
|
||||
const timeUntilRefreshMs =
|
||||
UPDATE_INTERVAL -
|
||||
@ -87,6 +88,26 @@ export const useSettingsStore = create<SettingsStore>()(
|
||||
return;
|
||||
}
|
||||
|
||||
const player = useSettingsStore.getState().player;
|
||||
if (player != undefined) {
|
||||
const newPlayer = await ScoreSaberAPI.fetchPlayerData(player.id);
|
||||
if (newPlayer != undefined && newPlayer != null) {
|
||||
console.log("Updated player data for", newPlayer.name);
|
||||
set({ player: newPlayer });
|
||||
}
|
||||
}
|
||||
|
||||
const friends = useSettingsStore.getState().friends;
|
||||
const newFriends = await Promise.all(
|
||||
friends.map(async (friend) => {
|
||||
const newFriend = await ScoreSaberAPI.fetchPlayerData(friend.id);
|
||||
if (newFriend == undefined || newFriend == null) return friend;
|
||||
console.log("Updated friend data for", newFriend.name);
|
||||
return newFriend;
|
||||
}),
|
||||
);
|
||||
set({ friends: newFriends });
|
||||
|
||||
useSettingsStore.setState({ profilesLastUpdated: Date.now() });
|
||||
},
|
||||
}),
|
||||
|
@ -50,7 +50,7 @@ async function searchByName(
|
||||
* @param playerId the id of the player
|
||||
* @returns the player info
|
||||
*/
|
||||
async function getPlayerInfo(
|
||||
async function fetchPlayerData(
|
||||
playerId: string,
|
||||
): Promise<ScoresaberPlayer | undefined | null> {
|
||||
const response = await fetchQueue.fetch(
|
||||
@ -201,7 +201,7 @@ async function fetchTopPlayers(
|
||||
|
||||
export const ScoreSaberAPI = {
|
||||
searchByName,
|
||||
getPlayerInfo,
|
||||
fetchPlayerData,
|
||||
fetchScores,
|
||||
fetchAllScores,
|
||||
fetchTopPlayers,
|
||||
|
Reference in New Issue
Block a user