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

Create placeholder classes instead of changing Children.

- Add MessagePlaceholder
- Use MessagePlacholder for when API is offline/user isn't a supporter
- Remove unnecessary placeholderFlow field
- Hook into API state changes
This commit is contained in:
naoey 2017-12-20 20:00:52 +05:30
parent 6d471da459
commit 23f4799840

View File

@ -34,7 +34,6 @@ namespace osu.Game.Screens.Select.Leaderboards
private readonly ScrollContainer scrollContainer; private readonly ScrollContainer scrollContainer;
private readonly Container placeholderContainer; private readonly Container placeholderContainer;
private readonly FillFlowContainer placeholderFlow;
private FillFlowContainer<LeaderboardScore> scrollFlow; private FillFlowContainer<LeaderboardScore> scrollFlow;
@ -63,22 +62,7 @@ namespace osu.Game.Screens.Select.Leaderboards
if (!scores.Any()) if (!scores.Any())
{ {
placeholderFlow.Children = new Drawable[] replacePlaceholder(new MessagePlaceholder(@"No records yet!"));
{
new SpriteIcon
{
Icon = FontAwesome.fa_exclamation_circle,
Size = new Vector2(26),
Margin = new MarginPadding { Right = 10 },
},
new OsuSpriteText
{
Text = @"No records yet!",
TextSize = 22,
},
};
placeholderContainer.FadeIn(fade_duration);
return; return;
} }
@ -135,17 +119,9 @@ namespace osu.Game.Screens.Select.Leaderboards
placeholderContainer = new Container placeholderContainer = new Container
{ {
Alpha = 0, Alpha = 0,
RelativeSizeAxes = Axes.Both, AutoSizeAxes = Axes.Both,
Children = new Drawable[]
{
placeholderFlow = new FillFlowContainer
{
Direction = FillDirection.Horizontal,
Anchor = Anchor.Centre, Anchor = Anchor.Centre,
Origin = Anchor.Centre, Origin = Anchor.Centre,
AutoSizeAxes = Axes.Both,
},
},
}, },
}; };
} }
@ -181,6 +157,9 @@ namespace osu.Game.Screens.Select.Leaderboards
if (osuGame != null) if (osuGame != null)
osuGame.Ruleset.ValueChanged += handleRulesetChange; osuGame.Ruleset.ValueChanged += handleRulesetChange;
if (api != null)
api.OnStateChange += handleApiStateChange;
} }
protected override void Dispose(bool isDisposing) protected override void Dispose(bool isDisposing)
@ -195,6 +174,23 @@ namespace osu.Game.Screens.Select.Leaderboards
private void handleRulesetChange(RulesetInfo ruleset) => UpdateScores(); private void handleRulesetChange(RulesetInfo ruleset) => UpdateScores();
private void handleApiStateChange(APIState oldState, APIState newState)
{
if (Scope == LeaderboardScope.Local)
// No need to respond to API state change while current scope is local
return;
if (newState == APIState.Offline)
{
Scores = null;
replacePlaceholder(new MessagePlaceholder(@"Please login to view online leaderboards!"));
return;
}
if (newState == APIState.Online)
UpdateScores();
}
protected virtual void UpdateScores() protected virtual void UpdateScores()
{ {
if (!IsLoaded) return; if (!IsLoaded) return;
@ -215,6 +211,20 @@ namespace osu.Game.Screens.Select.Leaderboards
return; return;
} }
if (!api.IsLoggedIn)
{
loading.Hide();
replacePlaceholder(new MessagePlaceholder(@"Please login to view online leaderboards!"));
return;
}
if (Scope != LeaderboardScope.Global && !api.LocalUser.Value.IsSupporter)
{
loading.Hide();
replacePlaceholder(new MessagePlaceholder(@"Please invest in a supporter tag to view this leaderboard!"));
return;
}
getScoresRequest = new GetScoresRequest(Beatmap, osuGame?.Ruleset.Value ?? Beatmap.Ruleset, Scope); getScoresRequest = new GetScoresRequest(Beatmap, osuGame?.Ruleset.Value ?? Beatmap.Ruleset, Scope);
getScoresRequest.Success += r => getScoresRequest.Success += r =>
{ {
@ -230,24 +240,21 @@ namespace osu.Game.Screens.Select.Leaderboards
if (e is OperationCanceledException) return; if (e is OperationCanceledException) return;
Scores = null; Scores = null;
placeholderFlow.Children = new Drawable[] replacePlaceholder(new RetrievalFailurePlaceholder
{ {
new RetryButton OnRetry = UpdateScores,
{ });
Action = UpdateScores,
Margin = new MarginPadding { Right = 10 },
},
new OsuSpriteText
{
Anchor = Anchor.TopLeft,
Text = @"Couldn't retrieve scores!",
TextSize = 22,
},
};
placeholderContainer.FadeIn(fade_duration);
Logger.Error(e, @"Couldn't fetch beatmap scores!"); Logger.Error(e, @"Couldn't fetch beatmap scores!");
} }
private void replacePlaceholder(Drawable placeholder)
{
placeholderContainer.FadeOutFromOne(fade_duration, Easing.OutQuint);
placeholderContainer.Clear(true);
placeholderContainer.Child = placeholder;
placeholderContainer.FadeInFromZero(fade_duration, Easing.OutQuint);
}
protected override void Update() protected override void Update()
{ {
base.Update(); base.Update();
@ -277,6 +284,54 @@ namespace osu.Game.Screens.Select.Leaderboards
} }
} }
private class MessagePlaceholder : FillFlowContainer
{
public MessagePlaceholder(string message)
{
Direction = FillDirection.Horizontal;
AutoSizeAxes = Axes.Both;
Children = new Drawable[]
{
new SpriteIcon
{
Icon = FontAwesome.fa_exclamation_circle,
Size = new Vector2(26),
Margin = new MarginPadding { Right = 10 },
},
new OsuSpriteText
{
Text = message,
TextSize = 22,
},
};
}
}
private class RetrievalFailurePlaceholder : FillFlowContainer
{
public Action OnRetry;
public RetrievalFailurePlaceholder()
{
Direction = FillDirection.Horizontal;
AutoSizeAxes = Axes.Both;
Children = new Drawable[]
{
new RetryButton
{
Action = () => OnRetry?.Invoke(),
Margin = new MarginPadding { Right = 10 },
},
new OsuSpriteText
{
Anchor = Anchor.TopLeft,
Text = @"Couldn't retrieve scores!",
TextSize = 22,
},
};
}
}
private class RetryButton : BeatSyncedContainer private class RetryButton : BeatSyncedContainer
{ {
private readonly SpriteIcon icon; private readonly SpriteIcon icon;