1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-14 03:15:45 +08:00

use a bindable instead

This commit is contained in:
jorolf 2019-03-02 19:13:38 +01:00
parent 176cbc7f2e
commit e8d568470d

View File

@ -36,8 +36,7 @@ namespace osu.Game.Screens.Menu
private const float icon_y = -85;
[Resolved]
private APIAccess api { get; set; }
private readonly Bindable<User> currentUser = new Bindable<User>();
public Disclaimer()
{
@ -45,7 +44,7 @@ namespace osu.Game.Screens.Menu
}
[BackgroundDependencyLoader]
private void load(OsuColour colours)
private void load(OsuColour colours, APIAccess api)
{
InternalChildren = new Drawable[]
{
@ -102,14 +101,19 @@ namespace osu.Game.Screens.Menu
}).First());
iconColour = colours.Yellow;
currentUser.BindTo(api.LocalUser);
currentUser.BindValueChanged(e =>
{
if (e.NewValue.IsSupporter)
supporterDrawables.ForEach(d => d.FadeOut(200, Easing.OutQuint).Expire());
}, true);
}
protected override void LoadComplete()
{
base.LoadComplete();
LoadComponentAsync(intro = new Intro());
api.LocalUser.BindValueChanged(userChanged, true);
}
public override void OnEntering(IScreen last)
@ -140,12 +144,7 @@ namespace osu.Game.Screens.Menu
{
base.OnSuspending(next);
api.LocalUser.ValueChanged -= userChanged;
}
private void userChanged(ValueChangedEvent<User> user)
{
if (user.NewValue.IsSupporter) supporterDrawables.ForEach(d => d.FadeOut(200, Easing.OutQuint).Expire());
currentUser.UnbindAll();
}
}
}