mirror of
https://github.com/ppy/osu
synced 2024-12-14 10:57:41 +00:00
Use lookup instead of dictionary to distribute posts
This commit is contained in:
parent
711e7ba860
commit
e736240a06
@ -26,7 +26,7 @@ namespace osu.Game.Overlays.News.Sidebar
|
||||
|
||||
private readonly FillFlowContainer postsFlow;
|
||||
|
||||
public MonthPanel(List<APINewsPost> posts)
|
||||
public MonthPanel(IEnumerable<APINewsPost> posts)
|
||||
{
|
||||
Width = 160;
|
||||
Masking = true;
|
||||
@ -38,7 +38,7 @@ namespace osu.Game.Overlays.News.Sidebar
|
||||
Spacing = new Vector2(0, 5),
|
||||
Children = new Drawable[]
|
||||
{
|
||||
new DropdownButton(posts[0].PublishedAt)
|
||||
new DropdownButton(posts.ElementAt(0).PublishedAt)
|
||||
{
|
||||
IsOpen = { BindTarget = IsOpen }
|
||||
},
|
||||
|
@ -8,7 +8,7 @@ using osu.Framework.Graphics;
|
||||
using osu.Game.Online.API.Requests.Responses;
|
||||
using osu.Framework.Graphics.Shapes;
|
||||
using osuTK;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
namespace osu.Game.Overlays.News.Sidebar
|
||||
{
|
||||
@ -81,30 +81,17 @@ namespace osu.Game.Overlays.News.Sidebar
|
||||
|
||||
if (metadata.NewValue != null)
|
||||
{
|
||||
var dict = new Dictionary<int, List<APINewsPost>>();
|
||||
var lookup = metadata.NewValue.NewsPosts.ToLookup(post => post.PublishedAt.Month);
|
||||
|
||||
foreach (var p in metadata.NewValue.NewsPosts)
|
||||
var keys = lookup.Select(kvp => kvp.Key);
|
||||
var sortedKeys = keys.OrderByDescending(k => k).ToList();
|
||||
|
||||
for (int i = 0; i < sortedKeys.Count; i++)
|
||||
{
|
||||
var month = p.PublishedAt.Month;
|
||||
|
||||
if (dict.ContainsKey(month))
|
||||
dict[month].Add(p);
|
||||
else
|
||||
monthsFlow.Add(new MonthPanel(lookup[sortedKeys[i]])
|
||||
{
|
||||
dict.Add(month, new List<APINewsPost>(new[] { p }));
|
||||
}
|
||||
}
|
||||
|
||||
bool isFirst = true;
|
||||
|
||||
foreach (var keyValuePair in dict)
|
||||
{
|
||||
monthsFlow.Add(new MonthPanel(keyValuePair.Value)
|
||||
{
|
||||
IsOpen = { Value = isFirst }
|
||||
IsOpen = { Value = i == 0 }
|
||||
});
|
||||
|
||||
isFirst = false;
|
||||
}
|
||||
}
|
||||
}, true);
|
||||
|
Loading…
Reference in New Issue
Block a user