1
0
mirror of https://github.com/ppy/osu.git synced 2024-12-17 14:33:21 +08:00
osu-lazer/osu.Game/Overlays/News/Displays/ArticleListing.cs

130 lines
4.0 KiB
C#
Raw Normal View History

2020-07-09 09:02:14 +08:00
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
using System;
2020-07-09 09:02:14 +08:00
using System.Linq;
using System.Threading;
using osu.Framework.Allocation;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Game.Graphics.UserInterface;
using osu.Game.Online.API;
using osu.Game.Online.API.Requests;
using osu.Game.Online.API.Requests.Responses;
2020-07-09 09:02:14 +08:00
using osuTK;
namespace osu.Game.Overlays.News.Displays
{
/// <summary>
/// Lists articles in a vertical flow for a specified year.
/// </summary>
public class ArticleListing : CompositeDrawable
2020-07-09 09:02:14 +08:00
{
public Action<APINewsSidebar> SidebarMetadataUpdated;
[Resolved]
private IAPIProvider api { get; set; }
2020-07-09 09:02:14 +08:00
2020-07-25 14:26:29 +08:00
private FillFlowContainer content;
private ShowMoreButton showMore;
2020-07-09 09:02:14 +08:00
private GetNewsRequest request;
2020-07-09 09:02:14 +08:00
private Cursor lastCursor;
private readonly int? year;
/// <summary>
/// Instantiate a listing for the specified year.
/// </summary>
/// <param name="year">The year to load articles from. If null, will show the most recent articles.</param>
public ArticleListing(int? year = null)
{
this.year = year;
}
2020-07-25 14:26:29 +08:00
[BackgroundDependencyLoader]
private void load()
2020-07-09 09:02:14 +08:00
{
RelativeSizeAxes = Axes.X;
AutoSizeAxes = Axes.Y;
Padding = new MarginPadding
{
Vertical = 20,
Left = 30,
Right = 50
};
InternalChild = new FillFlowContainer
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Vertical,
Spacing = new Vector2(0, 10),
Children = new Drawable[]
{
content = new FillFlowContainer
{
Anchor = Anchor.TopCentre,
Origin = Anchor.TopCentre,
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Vertical,
Spacing = new Vector2(0, 10)
},
showMore = new ShowMoreButton
{
Anchor = Anchor.TopCentre,
Origin = Anchor.TopCentre,
Margin = new MarginPadding
{
Top = 15
},
Action = performFetch,
2020-07-09 09:02:14 +08:00
Alpha = 0
}
}
};
performFetch();
}
private void performFetch()
{
request?.Cancel();
request = new GetNewsRequest(year, lastCursor);
request.Success += response => Schedule(() => onSuccess(response));
api.PerformAsync(request);
2020-07-09 09:02:14 +08:00
}
private CancellationTokenSource cancellationToken;
private void onSuccess(GetNewsResponse response)
2020-07-09 09:02:14 +08:00
{
2020-07-25 14:26:29 +08:00
cancellationToken?.Cancel();
// only needs to be updated on the initial load, as the content won't change during pagination.
if (lastCursor == null)
SidebarMetadataUpdated?.Invoke(response.SidebarMetadata);
// store cursor for next pagination request.
2020-07-09 09:02:14 +08:00
lastCursor = response.Cursor;
LoadComponentsAsync(response.NewsPosts.Select(p => new NewsCard(p)).ToList(), loaded =>
2020-07-09 09:02:14 +08:00
{
content.AddRange(loaded);
2020-07-09 09:02:14 +08:00
showMore.IsLoading = false;
showMore.Alpha = response.Cursor != null ? 1 : 0;
2020-07-09 09:02:14 +08:00
}, (cancellationToken = new CancellationTokenSource()).Token);
}
protected override void Dispose(bool isDisposing)
{
request?.Cancel();
2020-07-09 09:02:14 +08:00
cancellationToken?.Cancel();
base.Dispose(isDisposing);
}
}
}