1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-13 17:13:06 +08:00

Refactor to use API state instead of logged in user state

This commit is contained in:
Dean Herbert 2023-11-22 12:02:37 +09:00
parent 826c82de47
commit fe15b26bd2
No known key found for this signature in database

View File

@ -47,7 +47,7 @@ namespace osu.Game.Overlays
private IUser? user; private IUser? user;
private IRulesetInfo? ruleset; private IRulesetInfo? ruleset;
private IBindable<APIUser> apiUser = null!; private readonly IBindable<APIState> apiState = new Bindable<APIState>();
[Resolved] [Resolved]
private RulesetStore rulesets { get; set; } = null!; private RulesetStore rulesets { get; set; } = null!;
@ -68,10 +68,10 @@ namespace osu.Game.Overlays
[BackgroundDependencyLoader] [BackgroundDependencyLoader]
private void load() private void load()
{ {
apiUser = API.LocalUser.GetBoundCopy(); apiState.BindTo(API.State);
apiUser.BindValueChanged(_ => Schedule(() => apiState.BindValueChanged(state => Schedule(() =>
{ {
if (API.IsLoggedIn) if (state.NewValue == APIState.Online && user != null)
fetchAndSetContent(); fetchAndSetContent();
})); }));
} }
@ -89,7 +89,6 @@ namespace osu.Game.Overlays
ruleset = userRuleset; ruleset = userRuleset;
Show(); Show();
fetchAndSetContent(); fetchAndSetContent();
} }
@ -171,14 +170,15 @@ namespace osu.Game.Overlays
sectionsContainer.ScrollToTop(); sectionsContainer.ScrollToTop();
if (API.State.Value != APIState.Online) if (API.State.Value != APIState.Offline)
return; {
userReq = user.OnlineID > 1 ? new GetUserRequest(user.OnlineID, ruleset) : new GetUserRequest(user.Username, ruleset); userReq = user.OnlineID > 1 ? new GetUserRequest(user.OnlineID, ruleset) : new GetUserRequest(user.Username, ruleset);
userReq.Success += u => userLoadComplete(u, ruleset); userReq.Success += u => userLoadComplete(u, ruleset);
API.Queue(userReq); API.Queue(userReq);
loadingLayer.Show(); loadingLayer.Show();
} }
}
private void userLoadComplete(APIUser loadedUser, IRulesetInfo? userRuleset) private void userLoadComplete(APIUser loadedUser, IRulesetInfo? userRuleset)
{ {