1
0
mirror of https://github.com/ppy/osu.git synced 2024-11-11 18:27:26 +08:00
osu-lazer/osu.Game/Overlays/ChangelogOverlay.cs

179 lines
5.7 KiB
C#
Raw Normal View History

2019-05-13 16:14:52 +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.
2018-07-17 05:50:22 +08:00
using System.Collections.Generic;
2018-07-20 01:07:24 +08:00
using osu.Framework.Allocation;
using osu.Framework.Audio;
using osu.Framework.Audio.Sample;
2018-07-17 05:50:22 +08: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-19 01:32:15 +08:00
using osu.Game.Input.Bindings;
2018-07-20 01:07:24 +08:00
using osu.Game.Online.API.Requests;
using osu.Game.Online.API.Requests.Responses;
2018-07-17 05:50:22 +08:00
using osu.Game.Overlays.Changelog;
2019-05-12 23:36:05 +08:00
using osuTK.Graphics;
2018-07-17 05:50:22 +08:00
namespace osu.Game.Overlays
{
public class ChangelogOverlay : FullscreenOverlay
2018-07-17 05:50:22 +08:00
{
private ChangelogHeader header;
2019-05-12 23:36:05 +08:00
2019-05-15 17:08:19 +08:00
private BadgeDisplay badges;
2019-05-12 23:36:05 +08:00
private Container content;
2018-07-23 00:35:29 +08:00
2018-07-25 00:41:47 +08:00
private SampleChannel sampleBack;
private List<APIChangelogBuild> builds;
[BackgroundDependencyLoader]
private void load(AudioManager audio, OsuColour colour)
2018-07-17 05:50:22 +08:00
{
Waves.FirstWaveColour = colour.Violet;
2018-07-18 00:32:11 +08:00
Waves.SecondWaveColour = OsuColour.FromHex(@"8F03BF");
Waves.ThirdWaveColour = OsuColour.FromHex(@"600280");
Waves.FourthWaveColour = OsuColour.FromHex(@"300140");
2018-07-17 05:50:22 +08:00
Children = new Drawable[]
{
new Box
{
RelativeSizeAxes = Axes.Both,
2018-07-22 05:00:05 +08:00
Colour = new Color4(49, 36, 54, 255),
2018-07-17 05:50:22 +08:00
},
2019-05-17 11:42:08 +08:00
new ScrollContainer
2018-07-17 05:50:22 +08: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(),
2019-05-15 17:08:19 +08:00
badges = new BadgeDisplay(),
content = new Container
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
}
2018-07-17 05:50:22 +08:00
},
},
},
};
header.ListingSelected += ShowListing;
2019-05-15 17:08:19 +08:00
2019-05-17 10:43:36 +08:00
// todo: better
badges.Current.ValueChanged += e =>
{
if (e.NewValue?.LatestBuild != null)
ShowBuild(e.NewValue.LatestBuild);
};
sampleBack = audio.Sample.Get(@"UI/generic-select-soft");
2018-07-25 00:41:47 +08:00
}
2018-07-19 01:32:15 +08:00
2018-07-25 00:41:47 +08:00
protected override void LoadComplete()
{
base.LoadComplete();
fetchListing();
2018-07-19 01:32:15 +08:00
}
2018-07-17 05:50:22 +08:00
protected override void PopIn()
{
base.PopIn();
FadeEdgeEffectTo(0.25f, WaveContainer.APPEAR_DURATION, Easing.In);
}
protected override void PopOut()
{
base.PopOut();
FadeEdgeEffectTo(0, WaveContainer.DISAPPEAR_DURATION, Easing.Out);
}
2018-07-20 01:07:24 +08:00
2018-07-25 00:41:47 +08:00
public override bool OnPressed(GlobalAction action)
2018-07-23 02:27:50 +08:00
{
2018-07-25 00:41:47 +08:00
switch (action)
{
case GlobalAction.Back:
if (content.Child is ChangelogContent)
{
2019-05-17 11:42:08 +08:00
State = Visibility.Hidden;
}
2018-07-25 00:41:47 +08:00
else
{
ShowListing();
2018-07-25 00:41:47 +08:00
sampleBack?.Play();
}
2019-05-12 23:36:05 +08:00
2018-07-25 00:41:47 +08:00
return true;
}
2018-07-23 02:27:50 +08:00
2018-07-25 00:41:47 +08:00
return false;
2018-07-20 01:07:24 +08:00
}
private void fetchListing()
2018-07-20 01:07:24 +08:00
{
header.ShowListing();
2018-07-23 04:13:14 +08:00
var req = new GetChangelogRequest();
req.Success += res =>
{
2019-05-17 10:43:36 +08:00
// 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;
ShowListing();
2019-05-15 17:08:19 +08:00
badges.Populate(res.Streams);
};
API.Queue(req);
2018-07-23 00:35:29 +08:00
}
public void ShowListing()
{
header.ShowListing();
badges.Current.Value = null;
content.Child = new ChangelogListing(builds);
}
2018-07-23 00:35:29 +08:00
/// <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>
2019-05-15 17:08:19 +08:00
public void ShowBuild(APIChangelogBuild build)
2018-07-23 00:35:29 +08:00
{
2019-05-17 10:43:36 +08:00
if (build == null)
{
ShowListing();
return;
}
2019-05-15 17:21:06 +08:00
header.ShowBuild(build.UpdateStream.DisplayName, build.DisplayVersion);
2019-05-17 10:43:36 +08:00
badges.Current.Value = build.UpdateStream;
void displayBuild(APIChangelogBuild populatedBuild) =>
content.Child = new ChangelogBuild(populatedBuild);
2019-05-15 17:21:06 +08:00
if (build.Versions != null)
displayBuild(build);
else
{
var req = new GetChangelogBuildRequest(build.UpdateStream.Name, build.Version);
req.Success += displayBuild;
API.Queue(req);
}
2018-07-20 01:07:24 +08:00
}
2018-07-17 05:50:22 +08:00
}
}