osu/osu.Game/Overlays/ChangelogOverlay.cs

175 lines
5.6 KiB
C#
Raw Normal View History

2019-05-13 08:14:52 +00: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.
2018-07-16 21:50:22 +00:00
2019-05-21 04:34:35 +00:00
using System;
using System.Collections.Generic;
using System.Threading;
2019-05-21 04:34:35 +00:00
using JetBrains.Annotations;
2018-07-19 17:07:24 +00:00
using osu.Framework.Allocation;
using osu.Framework.Audio;
using osu.Framework.Audio.Sample;
2019-05-21 04:34:35 +00:00
using osu.Framework.Bindables;
2018-07-16 21:50:22 +00:00
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Shapes;
using osu.Game.Graphics;
using osu.Game.Graphics.Containers;
2018-07-18 17:32:15 +00:00
using osu.Game.Input.Bindings;
2018-07-19 17:07:24 +00:00
using osu.Game.Online.API.Requests;
using osu.Game.Online.API.Requests.Responses;
2018-07-16 21:50:22 +00:00
using osu.Game.Overlays.Changelog;
2019-05-12 15:36:05 +00:00
using osuTK.Graphics;
2018-07-16 21:50:22 +00:00
namespace osu.Game.Overlays
{
public class ChangelogOverlay : FullscreenOverlay
2018-07-16 21:50:22 +00:00
{
private ChangelogHeader header;
2019-05-12 15:36:05 +00:00
private Container<ChangelogContent> content;
2018-07-22 16:35:29 +00:00
2018-07-24 16:41:47 +00:00
private SampleChannel sampleBack;
private List<APIChangelogBuild> builds;
2019-05-21 04:34:35 +00:00
public readonly Bindable<APIChangelogBuild> Current = new Bindable<APIChangelogBuild>();
public void ShowListing() => Current.Value = null;
/// <summary>
/// Fetches and shows a specific build from a specific update stream.
/// </summary>
/// <param name="build">Must contain at least <see cref="APIUpdateStream.Name"/> and
/// <see cref="APIChangelogBuild.Version"/>. If <see cref="APIUpdateStream.DisplayName"/> and
/// <see cref="APIChangelogBuild.DisplayVersion"/> are specified, the header will instantly display them.</param>
public void ShowBuild([NotNull] APIChangelogBuild build)
{
if (build == null) throw new ArgumentNullException(nameof(build));
Current.Value = build;
}
[BackgroundDependencyLoader]
private void load(AudioManager audio, OsuColour colour)
2018-07-16 21:50:22 +00:00
{
2019-05-17 08:20:50 +00:00
Waves.FirstWaveColour = colour.GreyVioletLight;
Waves.SecondWaveColour = colour.GreyViolet;
Waves.ThirdWaveColour = colour.GreyVioletDark;
Waves.FourthWaveColour = colour.GreyVioletDarker;
2018-07-16 21:50:22 +00:00
Children = new Drawable[]
{
new Box
{
RelativeSizeAxes = Axes.Both,
2018-07-21 21:00:05 +00:00
Colour = new Color4(49, 36, 54, 255),
2018-07-16 21:50:22 +00:00
},
2019-05-17 03:42:08 +00:00
new ScrollContainer
2018-07-16 21:50:22 +00:00
{
RelativeSizeAxes = Axes.Both,
ScrollbarVisible = false,
Child = new ReverseChildIDFillFlowContainer<Drawable>
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Vertical,
Children = new Drawable[]
{
header = new ChangelogHeader
{
ListingSelected = ShowListing,
},
content = new Container<ChangelogContent>
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
}
2018-07-16 21:50:22 +00:00
},
},
},
};
sampleBack = audio.Sample.Get(@"UI/generic-select-soft");
2018-07-18 17:32:15 +00:00
2019-05-21 04:34:35 +00:00
header.Current.BindTo(Current);
2018-07-16 21:50:22 +00:00
2019-05-21 04:34:35 +00:00
Current.BindValueChanged(e =>
{
if (e.NewValue != null)
loadContent(new ChangelogSingleBuild(e.NewValue));
else
loadContent(new ChangelogListing(builds));
});
2018-07-16 21:50:22 +00:00
}
2018-07-19 17:07:24 +00:00
2018-07-24 16:41:47 +00:00
public override bool OnPressed(GlobalAction action)
2018-07-22 18:27:50 +00:00
{
2018-07-24 16:41:47 +00:00
switch (action)
{
case GlobalAction.Back:
2019-05-21 04:34:35 +00:00
if (Current.Value == null)
{
2019-05-17 03:42:08 +00:00
State = Visibility.Hidden;
}
2018-07-24 16:41:47 +00:00
else
{
2019-05-21 04:34:35 +00:00
Current.Value = null;
2018-07-24 16:41:47 +00:00
sampleBack?.Play();
}
2019-05-12 15:36:05 +00:00
2018-07-24 16:41:47 +00:00
return true;
}
2018-07-22 18:27:50 +00:00
2018-07-24 16:41:47 +00:00
return false;
2018-07-19 17:07:24 +00:00
}
2019-05-21 04:34:35 +00:00
protected override void PopIn()
2018-07-22 16:35:29 +00:00
{
2019-05-21 04:34:35 +00:00
base.PopIn();
2019-05-21 04:34:35 +00:00
if (!initialFetchPerformed)
fetchListing();
}
2019-05-17 08:49:05 +00:00
private bool initialFetchPerformed;
private void fetchListing()
{
2019-05-17 08:49:05 +00:00
initialFetchPerformed = true;
var req = new GetChangelogRequest();
req.Success += res =>
{
// remap streams to builds to ensure model equality
res.Builds.ForEach(b => b.UpdateStream = res.Streams.Find(s => s.Id == b.UpdateStream.Id));
res.Streams.ForEach(s => s.LatestBuild.UpdateStream = res.Streams.Find(s2 => s2.Id == s.LatestBuild.UpdateStream.Id));
builds = res.Builds;
header.Streams.Populate(res.Streams);
2019-05-21 04:34:35 +00:00
Current.TriggerChange();
};
2019-05-17 08:49:05 +00:00
req.Failure += _ => initialFetchPerformed = false;
API.Queue(req);
}
private CancellationTokenSource loadContentTask;
private void loadContent(ChangelogContent newContent)
{
content.FadeTo(0.2f, 300, Easing.OutQuint);
loadContentTask?.Cancel();
LoadComponentAsync(newContent, c =>
2019-05-15 09:21:06 +00:00
{
content.FadeIn(300, Easing.OutQuint);
c.BuildSelected = ShowBuild;
content.Child = c;
}, (loadContentTask = new CancellationTokenSource()).Token);
2018-07-19 17:07:24 +00:00
}
2018-07-16 21:50:22 +00:00
}
}