mirror of
https://github.com/ppy/osu.git
synced 2025-01-19 15:42:55 +08:00
Merge branch 'master' into multiplayer-rename-game-type
This commit is contained in:
commit
84c16e592f
@ -51,8 +51,8 @@
|
|||||||
<Reference Include="Java.Interop" />
|
<Reference Include="Java.Interop" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="ppy.osu.Game.Resources" Version="2021.730.0" />
|
<PackageReference Include="ppy.osu.Game.Resources" Version="2021.803.0" />
|
||||||
<PackageReference Include="ppy.osu.Framework.Android" Version="2021.728.0" />
|
<PackageReference Include="ppy.osu.Framework.Android" Version="2021.803.0" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup Label="Transitive Dependencies">
|
<ItemGroup Label="Transitive Dependencies">
|
||||||
<!-- Realm needs to be directly referenced in all Xamarin projects, as it will not pull in its transitive dependencies otherwise. -->
|
<!-- Realm needs to be directly referenced in all Xamarin projects, as it will not pull in its transitive dependencies otherwise. -->
|
||||||
|
@ -13,6 +13,7 @@ using osu.Game.Online.Spectator;
|
|||||||
using osu.Game.Rulesets.Osu;
|
using osu.Game.Rulesets.Osu;
|
||||||
using osu.Game.Rulesets.Osu.Replays;
|
using osu.Game.Rulesets.Osu.Replays;
|
||||||
using osu.Game.Rulesets.UI;
|
using osu.Game.Rulesets.UI;
|
||||||
|
using osu.Game.Screens;
|
||||||
using osu.Game.Screens.Play;
|
using osu.Game.Screens.Play;
|
||||||
using osu.Game.Tests.Beatmaps.IO;
|
using osu.Game.Tests.Beatmaps.IO;
|
||||||
using osu.Game.Tests.Visual.Multiplayer;
|
using osu.Game.Tests.Visual.Multiplayer;
|
||||||
@ -25,41 +26,43 @@ namespace osu.Game.Tests.Visual.Gameplay
|
|||||||
{
|
{
|
||||||
private readonly User streamingUser = new User { Id = MultiplayerTestScene.PLAYER_1_ID, Username = "Test user" };
|
private readonly User streamingUser = new User { Id = MultiplayerTestScene.PLAYER_1_ID, Username = "Test user" };
|
||||||
|
|
||||||
[Cached(typeof(SpectatorClient))]
|
|
||||||
private TestSpectatorClient testSpectatorClient = new TestSpectatorClient();
|
|
||||||
|
|
||||||
[Cached(typeof(UserLookupCache))]
|
[Cached(typeof(UserLookupCache))]
|
||||||
private UserLookupCache lookupCache = new TestUserLookupCache();
|
private UserLookupCache lookupCache = new TestUserLookupCache();
|
||||||
|
|
||||||
// used just to show beatmap card for the time being.
|
// used just to show beatmap card for the time being.
|
||||||
protected override bool UseOnlineAPI => true;
|
protected override bool UseOnlineAPI => true;
|
||||||
|
|
||||||
private SoloSpectator spectatorScreen;
|
|
||||||
|
|
||||||
[Resolved]
|
[Resolved]
|
||||||
private OsuGameBase game { get; set; }
|
private OsuGameBase game { get; set; }
|
||||||
|
|
||||||
private BeatmapSetInfo importedBeatmap;
|
private TestSpectatorClient spectatorClient;
|
||||||
|
private SoloSpectator spectatorScreen;
|
||||||
|
|
||||||
|
private BeatmapSetInfo importedBeatmap;
|
||||||
private int importedBeatmapId;
|
private int importedBeatmapId;
|
||||||
|
|
||||||
public override void SetUpSteps()
|
[SetUpSteps]
|
||||||
|
public void SetupSteps()
|
||||||
{
|
{
|
||||||
base.SetUpSteps();
|
DependenciesScreen dependenciesScreen = null;
|
||||||
|
|
||||||
|
AddStep("load dependencies", () =>
|
||||||
|
{
|
||||||
|
spectatorClient = new TestSpectatorClient();
|
||||||
|
|
||||||
|
// The screen gets suspended so it stops receiving updates.
|
||||||
|
Child = spectatorClient;
|
||||||
|
|
||||||
|
LoadScreen(dependenciesScreen = new DependenciesScreen(spectatorClient));
|
||||||
|
});
|
||||||
|
|
||||||
|
AddUntilStep("wait for dependencies to load", () => dependenciesScreen.IsLoaded);
|
||||||
|
|
||||||
AddStep("import beatmap", () =>
|
AddStep("import beatmap", () =>
|
||||||
{
|
{
|
||||||
importedBeatmap = ImportBeatmapTest.LoadOszIntoOsu(game, virtualTrack: true).Result;
|
importedBeatmap = ImportBeatmapTest.LoadOszIntoOsu(game, virtualTrack: true).Result;
|
||||||
importedBeatmapId = importedBeatmap.Beatmaps.First(b => b.RulesetID == 0).OnlineBeatmapID ?? -1;
|
importedBeatmapId = importedBeatmap.Beatmaps.First(b => b.RulesetID == 0).OnlineBeatmapID ?? -1;
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("add streaming client", () =>
|
|
||||||
{
|
|
||||||
Remove(testSpectatorClient);
|
|
||||||
Add(testSpectatorClient);
|
|
||||||
});
|
|
||||||
|
|
||||||
finish();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
@ -206,22 +209,36 @@ namespace osu.Game.Tests.Visual.Gameplay
|
|||||||
|
|
||||||
private void waitForPlayer() => AddUntilStep("wait for player", () => (Stack.CurrentScreen as Player)?.IsLoaded == true);
|
private void waitForPlayer() => AddUntilStep("wait for player", () => (Stack.CurrentScreen as Player)?.IsLoaded == true);
|
||||||
|
|
||||||
private void start(int? beatmapId = null) => AddStep("start play", () => testSpectatorClient.StartPlay(streamingUser.Id, beatmapId ?? importedBeatmapId));
|
private void start(int? beatmapId = null) => AddStep("start play", () => spectatorClient.StartPlay(streamingUser.Id, beatmapId ?? importedBeatmapId));
|
||||||
|
|
||||||
private void finish() => AddStep("end play", () => testSpectatorClient.EndPlay(streamingUser.Id));
|
private void finish() => AddStep("end play", () => spectatorClient.EndPlay(streamingUser.Id));
|
||||||
|
|
||||||
private void checkPaused(bool state) =>
|
private void checkPaused(bool state) =>
|
||||||
AddUntilStep($"game is {(state ? "paused" : "playing")}", () => player.ChildrenOfType<DrawableRuleset>().First().IsPaused.Value == state);
|
AddUntilStep($"game is {(state ? "paused" : "playing")}", () => player.ChildrenOfType<DrawableRuleset>().First().IsPaused.Value == state);
|
||||||
|
|
||||||
private void sendFrames(int count = 10)
|
private void sendFrames(int count = 10)
|
||||||
{
|
{
|
||||||
AddStep("send frames", () => testSpectatorClient.SendFrames(streamingUser.Id, count));
|
AddStep("send frames", () => spectatorClient.SendFrames(streamingUser.Id, count));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void loadSpectatingScreen()
|
private void loadSpectatingScreen()
|
||||||
{
|
{
|
||||||
AddStep("load screen", () => LoadScreen(spectatorScreen = new SoloSpectator(streamingUser)));
|
AddStep("load spectator", () => LoadScreen(spectatorScreen = new SoloSpectator(streamingUser)));
|
||||||
AddUntilStep("wait for screen load", () => spectatorScreen.LoadState == LoadState.Loaded);
|
AddUntilStep("wait for screen load", () => spectatorScreen.LoadState == LoadState.Loaded);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Used for the sole purpose of adding <see cref="TestSpectatorClient"/> as a resolvable dependency.
|
||||||
|
/// </summary>
|
||||||
|
private class DependenciesScreen : OsuScreen
|
||||||
|
{
|
||||||
|
[Cached(typeof(SpectatorClient))]
|
||||||
|
public readonly TestSpectatorClient Client;
|
||||||
|
|
||||||
|
public DependenciesScreen(TestSpectatorClient client)
|
||||||
|
{
|
||||||
|
Client = client;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,13 +1,12 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Allocation;
|
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
|
||||||
using osu.Framework.Testing;
|
using osu.Framework.Testing;
|
||||||
using osu.Game.Database;
|
using osu.Game.Database;
|
||||||
using osu.Game.Online.Spectator;
|
using osu.Game.Online.Spectator;
|
||||||
@ -21,51 +20,44 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
{
|
{
|
||||||
private readonly User streamingUser = new User { Id = 2, Username = "Test user" };
|
private readonly User streamingUser = new User { Id = 2, Username = "Test user" };
|
||||||
|
|
||||||
[Cached(typeof(SpectatorClient))]
|
private TestSpectatorClient spectatorClient;
|
||||||
private TestSpectatorClient testSpectatorClient = new TestSpectatorClient();
|
|
||||||
|
|
||||||
private CurrentlyPlayingDisplay currentlyPlaying;
|
private CurrentlyPlayingDisplay currentlyPlaying;
|
||||||
|
|
||||||
[Cached(typeof(UserLookupCache))]
|
|
||||||
private UserLookupCache lookupCache = new TestUserLookupCache();
|
|
||||||
|
|
||||||
private Container nestedContainer;
|
|
||||||
|
|
||||||
[SetUpSteps]
|
[SetUpSteps]
|
||||||
public void SetUpSteps()
|
public void SetUpSteps()
|
||||||
{
|
{
|
||||||
AddStep("add streaming client", () =>
|
AddStep("add streaming client", () =>
|
||||||
{
|
{
|
||||||
nestedContainer?.Remove(testSpectatorClient);
|
spectatorClient = new TestSpectatorClient();
|
||||||
Remove(lookupCache);
|
var lookupCache = new TestUserLookupCache();
|
||||||
|
|
||||||
Children = new Drawable[]
|
Children = new Drawable[]
|
||||||
{
|
{
|
||||||
lookupCache,
|
lookupCache,
|
||||||
nestedContainer = new Container
|
spectatorClient,
|
||||||
|
new DependencyProvidingContainer
|
||||||
{
|
{
|
||||||
RelativeSizeAxes = Axes.Both,
|
RelativeSizeAxes = Axes.Both,
|
||||||
Children = new Drawable[]
|
CachedDependencies = new (Type, object)[]
|
||||||
{
|
{
|
||||||
testSpectatorClient,
|
(typeof(SpectatorClient), spectatorClient),
|
||||||
currentlyPlaying = new CurrentlyPlayingDisplay
|
(typeof(UserLookupCache), lookupCache)
|
||||||
{
|
},
|
||||||
RelativeSizeAxes = Axes.Both,
|
Child = currentlyPlaying = new CurrentlyPlayingDisplay
|
||||||
}
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
AddStep("Reset players", () => testSpectatorClient.EndPlay(streamingUser.Id));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestBasicDisplay()
|
public void TestBasicDisplay()
|
||||||
{
|
{
|
||||||
AddStep("Add playing user", () => testSpectatorClient.StartPlay(streamingUser.Id, 0));
|
AddStep("Add playing user", () => spectatorClient.StartPlay(streamingUser.Id, 0));
|
||||||
AddUntilStep("Panel loaded", () => currentlyPlaying.ChildrenOfType<UserGridPanel>()?.FirstOrDefault()?.User.Id == 2);
|
AddUntilStep("Panel loaded", () => currentlyPlaying.ChildrenOfType<UserGridPanel>()?.FirstOrDefault()?.User.Id == 2);
|
||||||
AddStep("Remove playing user", () => testSpectatorClient.EndPlay(streamingUser.Id));
|
AddStep("Remove playing user", () => spectatorClient.EndPlay(streamingUser.Id));
|
||||||
AddUntilStep("Panel no longer present", () => !currentlyPlaying.ChildrenOfType<UserGridPanel>().Any());
|
AddUntilStep("Panel no longer present", () => !currentlyPlaying.ChildrenOfType<UserGridPanel>().Any());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestControl()
|
public void TestControl()
|
||||||
{
|
{
|
||||||
AddAssert("Front page selected", () => header.Current.Value == "frontpage");
|
AddAssert("Front page selected", () => header.Current.Value == NewsHeader.FrontPageString);
|
||||||
AddAssert("1 tab total", () => header.TabCount == 1);
|
AddAssert("1 tab total", () => header.TabCount == 1);
|
||||||
|
|
||||||
AddStep("Set article 1", () => header.SetArticle("1"));
|
AddStep("Set article 1", () => header.SetArticle("1"));
|
||||||
@ -41,7 +41,7 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
AddAssert("2 tabs total", () => header.TabCount == 2);
|
AddAssert("2 tabs total", () => header.TabCount == 2);
|
||||||
|
|
||||||
AddStep("Set front page", () => header.SetFrontPage());
|
AddStep("Set front page", () => header.SetFrontPage());
|
||||||
AddAssert("Front page selected", () => header.Current.Value == "frontpage");
|
AddAssert("Front page selected", () => header.Current.Value == NewsHeader.FrontPageString);
|
||||||
AddAssert("1 tab total", () => header.TabCount == 1);
|
AddAssert("1 tab total", () => header.TabCount == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,7 +44,7 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestWikiHeader()
|
public void TestWikiHeader()
|
||||||
{
|
{
|
||||||
AddAssert("Current is index", () => checkCurrent("index"));
|
AddAssert("Current is index", () => checkCurrent(WikiHeader.IndexPageString));
|
||||||
|
|
||||||
AddStep("Change wiki page data", () => wikiPageData.Value = new APIWikiPage
|
AddStep("Change wiki page data", () => wikiPageData.Value = new APIWikiPage
|
||||||
{
|
{
|
||||||
@ -54,8 +54,8 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
AddAssert("Current is welcome", () => checkCurrent("Welcome"));
|
AddAssert("Current is welcome", () => checkCurrent("Welcome"));
|
||||||
AddAssert("Check breadcrumb", checkBreadcrumb);
|
AddAssert("Check breadcrumb", checkBreadcrumb);
|
||||||
|
|
||||||
AddStep("Change current to index", () => header.Current.Value = "index");
|
AddStep("Change current to index", () => header.Current.Value = WikiHeader.IndexPageString);
|
||||||
AddAssert("Current is index", () => checkCurrent("index"));
|
AddAssert("Current is index", () => checkCurrent(WikiHeader.IndexPageString));
|
||||||
|
|
||||||
AddStep("Change wiki page data", () => wikiPageData.Value = new APIWikiPage
|
AddStep("Change wiki page data", () => wikiPageData.Value = new APIWikiPage
|
||||||
{
|
{
|
||||||
@ -71,7 +71,7 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
AddAssert("Check breadcrumb", checkBreadcrumb);
|
AddAssert("Check breadcrumb", checkBreadcrumb);
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool checkCurrent(string expectedCurrent) => header.Current.Value == expectedCurrent;
|
private bool checkCurrent(LocalisableString expectedCurrent) => header.Current.Value == expectedCurrent;
|
||||||
|
|
||||||
private bool checkBreadcrumb()
|
private bool checkBreadcrumb()
|
||||||
{
|
{
|
||||||
|
@ -1,22 +1,34 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Beatmaps
|
namespace osu.Game.Beatmaps
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(BeatmapSetOnlineStatusEnumLocalisationMapper))]
|
|
||||||
public enum BeatmapSetOnlineStatus
|
public enum BeatmapSetOnlineStatus
|
||||||
{
|
{
|
||||||
None = -3,
|
None = -3,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsetsStrings), nameof(BeatmapsetsStrings.ShowStatusGraveyard))]
|
||||||
Graveyard = -2,
|
Graveyard = -2,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsetsStrings), nameof(BeatmapsetsStrings.ShowStatusWip))]
|
||||||
WIP = -1,
|
WIP = -1,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsetsStrings), nameof(BeatmapsetsStrings.ShowStatusPending))]
|
||||||
Pending = 0,
|
Pending = 0,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsetsStrings), nameof(BeatmapsetsStrings.ShowStatusRanked))]
|
||||||
Ranked = 1,
|
Ranked = 1,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsetsStrings), nameof(BeatmapsetsStrings.ShowStatusApproved))]
|
||||||
Approved = 2,
|
Approved = 2,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsetsStrings), nameof(BeatmapsetsStrings.ShowStatusQualified))]
|
||||||
Qualified = 3,
|
Qualified = 3,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsetsStrings), nameof(BeatmapsetsStrings.ShowStatusLoved))]
|
||||||
Loved = 4,
|
Loved = 4,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -25,40 +37,4 @@ namespace osu.Game.Beatmaps
|
|||||||
public static bool GrantsPerformancePoints(this BeatmapSetOnlineStatus status)
|
public static bool GrantsPerformancePoints(this BeatmapSetOnlineStatus status)
|
||||||
=> status == BeatmapSetOnlineStatus.Ranked || status == BeatmapSetOnlineStatus.Approved;
|
=> status == BeatmapSetOnlineStatus.Ranked || status == BeatmapSetOnlineStatus.Approved;
|
||||||
}
|
}
|
||||||
|
|
||||||
public class BeatmapSetOnlineStatusEnumLocalisationMapper : EnumLocalisationMapper<BeatmapSetOnlineStatus>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(BeatmapSetOnlineStatus value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case BeatmapSetOnlineStatus.None:
|
|
||||||
return string.Empty;
|
|
||||||
|
|
||||||
case BeatmapSetOnlineStatus.Graveyard:
|
|
||||||
return BeatmapsetsStrings.ShowStatusGraveyard;
|
|
||||||
|
|
||||||
case BeatmapSetOnlineStatus.WIP:
|
|
||||||
return BeatmapsetsStrings.ShowStatusWip;
|
|
||||||
|
|
||||||
case BeatmapSetOnlineStatus.Pending:
|
|
||||||
return BeatmapsetsStrings.ShowStatusPending;
|
|
||||||
|
|
||||||
case BeatmapSetOnlineStatus.Ranked:
|
|
||||||
return BeatmapsetsStrings.ShowStatusRanked;
|
|
||||||
|
|
||||||
case BeatmapSetOnlineStatus.Approved:
|
|
||||||
return BeatmapsetsStrings.ShowStatusApproved;
|
|
||||||
|
|
||||||
case BeatmapSetOnlineStatus.Qualified:
|
|
||||||
return BeatmapsetsStrings.ShowStatusQualified;
|
|
||||||
|
|
||||||
case BeatmapSetOnlineStatus.Loved:
|
|
||||||
return BeatmapsetsStrings.ShowStatusLoved;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
44
osu.Game/Localisation/NamedOverlayComponentStrings.cs
Normal file
44
osu.Game/Localisation/NamedOverlayComponentStrings.cs
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
// 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 osu.Framework.Localisation;
|
||||||
|
|
||||||
|
namespace osu.Game.Localisation
|
||||||
|
{
|
||||||
|
public static class NamedOverlayComponentStrings
|
||||||
|
{
|
||||||
|
private const string prefix = @"osu.Game.Resources.Localisation.NamedOverlayComponent";
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// "browse for new beatmaps"
|
||||||
|
/// </summary>
|
||||||
|
public static LocalisableString BeatmapListingDescription => new TranslatableString(getKey(@"beatmap_listing_description"), @"browse for new beatmaps");
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// "track recent dev updates in the osu! ecosystem"
|
||||||
|
/// </summary>
|
||||||
|
public static LocalisableString ChangelogDescription => new TranslatableString(getKey(@"changelog_description"), @"track recent dev updates in the osu! ecosystem");
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// "view your friends and other information"
|
||||||
|
/// </summary>
|
||||||
|
public static LocalisableString DashboardDescription => new TranslatableString(getKey(@"dashboard_description"), @"view your friends and other information");
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// "find out who's the best right now"
|
||||||
|
/// </summary>
|
||||||
|
public static LocalisableString RankingsDescription => new TranslatableString(getKey(@"rankings_description"), @"find out who's the best right now");
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// "get up-to-date on community happenings"
|
||||||
|
/// </summary>
|
||||||
|
public static LocalisableString NewsDescription => new TranslatableString(getKey(@"news_description"), @"get up-to-date on community happenings");
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// "knowledge base"
|
||||||
|
/// </summary>
|
||||||
|
public static LocalisableString WikiDescription => new TranslatableString(getKey(@"wiki_description"), @"knowledge base");
|
||||||
|
|
||||||
|
private static string getKey(string key) => $"{prefix}:{key}";
|
||||||
|
}
|
||||||
|
}
|
@ -1,6 +1,9 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using osu.Game.Localisation;
|
||||||
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.BeatmapListing
|
namespace osu.Game.Overlays.BeatmapListing
|
||||||
{
|
{
|
||||||
public class BeatmapListingHeader : OverlayHeader
|
public class BeatmapListingHeader : OverlayHeader
|
||||||
@ -11,8 +14,8 @@ namespace osu.Game.Overlays.BeatmapListing
|
|||||||
{
|
{
|
||||||
public BeatmapListingTitle()
|
public BeatmapListingTitle()
|
||||||
{
|
{
|
||||||
Title = "beatmap listing";
|
Title = PageTitleStrings.MainBeatmapsetsControllerIndex;
|
||||||
Description = "browse for new beatmaps";
|
Description = NamedOverlayComponentStrings.BeatmapListingDescription;
|
||||||
IconTexture = "Icons/Hexacons/beatmap";
|
IconTexture = "Icons/Hexacons/beatmap";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,69 +1,42 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.BeatmapListing
|
namespace osu.Game.Overlays.BeatmapListing
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(SearchCategoryEnumLocalisationMapper))]
|
|
||||||
public enum SearchCategory
|
public enum SearchCategory
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.StatusAny))]
|
||||||
Any,
|
Any,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.StatusLeaderboard))]
|
||||||
[Description("Has Leaderboard")]
|
[Description("Has Leaderboard")]
|
||||||
Leaderboard,
|
Leaderboard,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.StatusRanked))]
|
||||||
Ranked,
|
Ranked,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.StatusQualified))]
|
||||||
Qualified,
|
Qualified,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.StatusLoved))]
|
||||||
Loved,
|
Loved,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.StatusFavourites))]
|
||||||
Favourites,
|
Favourites,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.StatusPending))]
|
||||||
[Description("Pending & WIP")]
|
[Description("Pending & WIP")]
|
||||||
Pending,
|
Pending,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.StatusGraveyard))]
|
||||||
Graveyard,
|
Graveyard,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.StatusMine))]
|
||||||
[Description("My Maps")]
|
[Description("My Maps")]
|
||||||
Mine,
|
Mine,
|
||||||
}
|
}
|
||||||
|
|
||||||
public class SearchCategoryEnumLocalisationMapper : EnumLocalisationMapper<SearchCategory>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(SearchCategory value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case SearchCategory.Any:
|
|
||||||
return BeatmapsStrings.StatusAny;
|
|
||||||
|
|
||||||
case SearchCategory.Leaderboard:
|
|
||||||
return BeatmapsStrings.StatusLeaderboard;
|
|
||||||
|
|
||||||
case SearchCategory.Ranked:
|
|
||||||
return BeatmapsStrings.StatusRanked;
|
|
||||||
|
|
||||||
case SearchCategory.Qualified:
|
|
||||||
return BeatmapsStrings.StatusQualified;
|
|
||||||
|
|
||||||
case SearchCategory.Loved:
|
|
||||||
return BeatmapsStrings.StatusLoved;
|
|
||||||
|
|
||||||
case SearchCategory.Favourites:
|
|
||||||
return BeatmapsStrings.StatusFavourites;
|
|
||||||
|
|
||||||
case SearchCategory.Pending:
|
|
||||||
return BeatmapsStrings.StatusPending;
|
|
||||||
|
|
||||||
case SearchCategory.Graveyard:
|
|
||||||
return BeatmapsStrings.StatusGraveyard;
|
|
||||||
|
|
||||||
case SearchCategory.Mine:
|
|
||||||
return BeatmapsStrings.StatusMine;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,34 +1,17 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.BeatmapListing
|
namespace osu.Game.Overlays.BeatmapListing
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(SearchExplicitEnumLocalisationMapper))]
|
|
||||||
public enum SearchExplicit
|
public enum SearchExplicit
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.NsfwExclude))]
|
||||||
Hide,
|
Hide,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.NsfwInclude))]
|
||||||
Show
|
Show
|
||||||
}
|
}
|
||||||
|
|
||||||
public class SearchExplicitEnumLocalisationMapper : EnumLocalisationMapper<SearchExplicit>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(SearchExplicit value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case SearchExplicit.Hide:
|
|
||||||
return BeatmapsStrings.NsfwExclude;
|
|
||||||
|
|
||||||
case SearchExplicit.Show:
|
|
||||||
return BeatmapsStrings.NsfwInclude;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,38 +1,20 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.BeatmapListing
|
namespace osu.Game.Overlays.BeatmapListing
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(SearchExtraEnumLocalisationMapper))]
|
|
||||||
public enum SearchExtra
|
public enum SearchExtra
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.ExtraVideo))]
|
||||||
[Description("Has Video")]
|
[Description("Has Video")]
|
||||||
Video,
|
Video,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.ExtraStoryboard))]
|
||||||
[Description("Has Storyboard")]
|
[Description("Has Storyboard")]
|
||||||
Storyboard
|
Storyboard
|
||||||
}
|
}
|
||||||
|
|
||||||
public class SearchExtraEnumLocalisationMapper : EnumLocalisationMapper<SearchExtra>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(SearchExtra value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case SearchExtra.Video:
|
|
||||||
return BeatmapsStrings.ExtraVideo;
|
|
||||||
|
|
||||||
case SearchExtra.Storyboard:
|
|
||||||
return BeatmapsStrings.ExtraStoryboard;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,44 +1,24 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.BeatmapListing
|
namespace osu.Game.Overlays.BeatmapListing
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(SearchGeneralEnumLocalisationMapper))]
|
|
||||||
public enum SearchGeneral
|
public enum SearchGeneral
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GeneralRecommended))]
|
||||||
[Description("Recommended difficulty")]
|
[Description("Recommended difficulty")]
|
||||||
Recommended,
|
Recommended,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GeneralConverts))]
|
||||||
[Description("Include converted beatmaps")]
|
[Description("Include converted beatmaps")]
|
||||||
Converts,
|
Converts,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GeneralFollows))]
|
||||||
[Description("Subscribed mappers")]
|
[Description("Subscribed mappers")]
|
||||||
Follows
|
Follows
|
||||||
}
|
}
|
||||||
|
|
||||||
public class SearchGeneralEnumLocalisationMapper : EnumLocalisationMapper<SearchGeneral>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(SearchGeneral value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case SearchGeneral.Recommended:
|
|
||||||
return BeatmapsStrings.GeneralRecommended;
|
|
||||||
|
|
||||||
case SearchGeneral.Converts:
|
|
||||||
return BeatmapsStrings.GeneralConverts;
|
|
||||||
|
|
||||||
case SearchGeneral.Follows:
|
|
||||||
return BeatmapsStrings.GeneralFollows;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,87 +1,56 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.BeatmapListing
|
namespace osu.Game.Overlays.BeatmapListing
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(SearchGenreEnumLocalisationMapper))]
|
|
||||||
public enum SearchGenre
|
public enum SearchGenre
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreAny))]
|
||||||
Any = 0,
|
Any = 0,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreUnspecified))]
|
||||||
Unspecified = 1,
|
Unspecified = 1,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreVideoGame))]
|
||||||
[Description("Video Game")]
|
[Description("Video Game")]
|
||||||
VideoGame = 2,
|
VideoGame = 2,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreAnime))]
|
||||||
Anime = 3,
|
Anime = 3,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreRock))]
|
||||||
Rock = 4,
|
Rock = 4,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenrePop))]
|
||||||
Pop = 5,
|
Pop = 5,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreOther))]
|
||||||
Other = 6,
|
Other = 6,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreNovelty))]
|
||||||
Novelty = 7,
|
Novelty = 7,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreHipHop))]
|
||||||
[Description("Hip Hop")]
|
[Description("Hip Hop")]
|
||||||
HipHop = 9,
|
HipHop = 9,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreElectronic))]
|
||||||
Electronic = 10,
|
Electronic = 10,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreMetal))]
|
||||||
Metal = 11,
|
Metal = 11,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreClassical))]
|
||||||
Classical = 12,
|
Classical = 12,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreFolk))]
|
||||||
Folk = 13,
|
Folk = 13,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.GenreJazz))]
|
||||||
Jazz = 14
|
Jazz = 14
|
||||||
}
|
}
|
||||||
|
|
||||||
public class SearchGenreEnumLocalisationMapper : EnumLocalisationMapper<SearchGenre>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(SearchGenre value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case SearchGenre.Any:
|
|
||||||
return BeatmapsStrings.GenreAny;
|
|
||||||
|
|
||||||
case SearchGenre.Unspecified:
|
|
||||||
return BeatmapsStrings.GenreUnspecified;
|
|
||||||
|
|
||||||
case SearchGenre.VideoGame:
|
|
||||||
return BeatmapsStrings.GenreVideoGame;
|
|
||||||
|
|
||||||
case SearchGenre.Anime:
|
|
||||||
return BeatmapsStrings.GenreAnime;
|
|
||||||
|
|
||||||
case SearchGenre.Rock:
|
|
||||||
return BeatmapsStrings.GenreRock;
|
|
||||||
|
|
||||||
case SearchGenre.Pop:
|
|
||||||
return BeatmapsStrings.GenrePop;
|
|
||||||
|
|
||||||
case SearchGenre.Other:
|
|
||||||
return BeatmapsStrings.GenreOther;
|
|
||||||
|
|
||||||
case SearchGenre.Novelty:
|
|
||||||
return BeatmapsStrings.GenreNovelty;
|
|
||||||
|
|
||||||
case SearchGenre.HipHop:
|
|
||||||
return BeatmapsStrings.GenreHipHop;
|
|
||||||
|
|
||||||
case SearchGenre.Electronic:
|
|
||||||
return BeatmapsStrings.GenreElectronic;
|
|
||||||
|
|
||||||
case SearchGenre.Metal:
|
|
||||||
return BeatmapsStrings.GenreMetal;
|
|
||||||
|
|
||||||
case SearchGenre.Classical:
|
|
||||||
return BeatmapsStrings.GenreClassical;
|
|
||||||
|
|
||||||
case SearchGenre.Folk:
|
|
||||||
return BeatmapsStrings.GenreFolk;
|
|
||||||
|
|
||||||
case SearchGenre.Jazz:
|
|
||||||
return BeatmapsStrings.GenreJazz;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,117 +1,73 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Framework.Utils;
|
using osu.Framework.Utils;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.BeatmapListing
|
namespace osu.Game.Overlays.BeatmapListing
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(SearchLanguageEnumLocalisationMapper))]
|
|
||||||
[HasOrderedElements]
|
[HasOrderedElements]
|
||||||
public enum SearchLanguage
|
public enum SearchLanguage
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageAny))]
|
||||||
[Order(0)]
|
[Order(0)]
|
||||||
Any,
|
Any,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageUnspecified))]
|
||||||
[Order(14)]
|
[Order(14)]
|
||||||
Unspecified,
|
Unspecified,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageEnglish))]
|
||||||
[Order(1)]
|
[Order(1)]
|
||||||
English,
|
English,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageJapanese))]
|
||||||
[Order(6)]
|
[Order(6)]
|
||||||
Japanese,
|
Japanese,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageChinese))]
|
||||||
[Order(2)]
|
[Order(2)]
|
||||||
Chinese,
|
Chinese,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageInstrumental))]
|
||||||
[Order(12)]
|
[Order(12)]
|
||||||
Instrumental,
|
Instrumental,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageKorean))]
|
||||||
[Order(7)]
|
[Order(7)]
|
||||||
Korean,
|
Korean,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageFrench))]
|
||||||
[Order(3)]
|
[Order(3)]
|
||||||
French,
|
French,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageGerman))]
|
||||||
[Order(4)]
|
[Order(4)]
|
||||||
German,
|
German,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageSwedish))]
|
||||||
[Order(9)]
|
[Order(9)]
|
||||||
Swedish,
|
Swedish,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageSpanish))]
|
||||||
[Order(8)]
|
[Order(8)]
|
||||||
Spanish,
|
Spanish,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageItalian))]
|
||||||
[Order(5)]
|
[Order(5)]
|
||||||
Italian,
|
Italian,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageRussian))]
|
||||||
[Order(10)]
|
[Order(10)]
|
||||||
Russian,
|
Russian,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguagePolish))]
|
||||||
[Order(11)]
|
[Order(11)]
|
||||||
Polish,
|
Polish,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.LanguageOther))]
|
||||||
[Order(13)]
|
[Order(13)]
|
||||||
Other
|
Other
|
||||||
}
|
}
|
||||||
|
|
||||||
public class SearchLanguageEnumLocalisationMapper : EnumLocalisationMapper<SearchLanguage>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(SearchLanguage value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case SearchLanguage.Any:
|
|
||||||
return BeatmapsStrings.LanguageAny;
|
|
||||||
|
|
||||||
case SearchLanguage.Unspecified:
|
|
||||||
return BeatmapsStrings.LanguageUnspecified;
|
|
||||||
|
|
||||||
case SearchLanguage.English:
|
|
||||||
return BeatmapsStrings.LanguageEnglish;
|
|
||||||
|
|
||||||
case SearchLanguage.Japanese:
|
|
||||||
return BeatmapsStrings.LanguageJapanese;
|
|
||||||
|
|
||||||
case SearchLanguage.Chinese:
|
|
||||||
return BeatmapsStrings.LanguageChinese;
|
|
||||||
|
|
||||||
case SearchLanguage.Instrumental:
|
|
||||||
return BeatmapsStrings.LanguageInstrumental;
|
|
||||||
|
|
||||||
case SearchLanguage.Korean:
|
|
||||||
return BeatmapsStrings.LanguageKorean;
|
|
||||||
|
|
||||||
case SearchLanguage.French:
|
|
||||||
return BeatmapsStrings.LanguageFrench;
|
|
||||||
|
|
||||||
case SearchLanguage.German:
|
|
||||||
return BeatmapsStrings.LanguageGerman;
|
|
||||||
|
|
||||||
case SearchLanguage.Swedish:
|
|
||||||
return BeatmapsStrings.LanguageSwedish;
|
|
||||||
|
|
||||||
case SearchLanguage.Spanish:
|
|
||||||
return BeatmapsStrings.LanguageSpanish;
|
|
||||||
|
|
||||||
case SearchLanguage.Italian:
|
|
||||||
return BeatmapsStrings.LanguageItalian;
|
|
||||||
|
|
||||||
case SearchLanguage.Russian:
|
|
||||||
return BeatmapsStrings.LanguageRussian;
|
|
||||||
|
|
||||||
case SearchLanguage.Polish:
|
|
||||||
return BeatmapsStrings.LanguagePolish;
|
|
||||||
|
|
||||||
case SearchLanguage.Other:
|
|
||||||
return BeatmapsStrings.LanguageOther;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,38 +1,20 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.BeatmapListing
|
namespace osu.Game.Overlays.BeatmapListing
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(SearchPlayedEnumLocalisationMapper))]
|
|
||||||
public enum SearchPlayed
|
public enum SearchPlayed
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.PlayedAny))]
|
||||||
Any,
|
Any,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.PlayedPlayed))]
|
||||||
Played,
|
Played,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.PlayedUnplayed))]
|
||||||
Unplayed
|
Unplayed
|
||||||
}
|
}
|
||||||
|
|
||||||
public class SearchPlayedEnumLocalisationMapper : EnumLocalisationMapper<SearchPlayed>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(SearchPlayed value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case SearchPlayed.Any:
|
|
||||||
return BeatmapsStrings.PlayedAny;
|
|
||||||
|
|
||||||
case SearchPlayed.Played:
|
|
||||||
return BeatmapsStrings.PlayedPlayed;
|
|
||||||
|
|
||||||
case SearchPlayed.Unplayed:
|
|
||||||
return BeatmapsStrings.PlayedUnplayed;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,58 +1,35 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.BeatmapListing
|
namespace osu.Game.Overlays.BeatmapListing
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(SortCriteriaLocalisationMapper))]
|
|
||||||
public enum SortCriteria
|
public enum SortCriteria
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.ListingSearchSortingTitle))]
|
||||||
Title,
|
Title,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.ListingSearchSortingArtist))]
|
||||||
Artist,
|
Artist,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.ListingSearchSortingDifficulty))]
|
||||||
Difficulty,
|
Difficulty,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.ListingSearchSortingRanked))]
|
||||||
Ranked,
|
Ranked,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.ListingSearchSortingRating))]
|
||||||
Rating,
|
Rating,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.ListingSearchSortingPlays))]
|
||||||
Plays,
|
Plays,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.ListingSearchSortingFavourites))]
|
||||||
Favourites,
|
Favourites,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.ListingSearchSortingRelevance))]
|
||||||
Relevance
|
Relevance
|
||||||
}
|
}
|
||||||
|
|
||||||
public class SortCriteriaLocalisationMapper : EnumLocalisationMapper<SortCriteria>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(SortCriteria value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case SortCriteria.Title:
|
|
||||||
return BeatmapsStrings.ListingSearchSortingTitle;
|
|
||||||
|
|
||||||
case SortCriteria.Artist:
|
|
||||||
return BeatmapsStrings.ListingSearchSortingArtist;
|
|
||||||
|
|
||||||
case SortCriteria.Difficulty:
|
|
||||||
return BeatmapsStrings.ListingSearchSortingDifficulty;
|
|
||||||
|
|
||||||
case SortCriteria.Ranked:
|
|
||||||
return BeatmapsStrings.ListingSearchSortingRanked;
|
|
||||||
|
|
||||||
case SortCriteria.Rating:
|
|
||||||
return BeatmapsStrings.ListingSearchSortingRating;
|
|
||||||
|
|
||||||
case SortCriteria.Plays:
|
|
||||||
return BeatmapsStrings.ListingSearchSortingPlays;
|
|
||||||
|
|
||||||
case SortCriteria.Favourites:
|
|
||||||
return BeatmapsStrings.ListingSearchSortingFavourites;
|
|
||||||
|
|
||||||
case SortCriteria.Relevance:
|
|
||||||
return BeatmapsStrings.ListingSearchSortingRelevance;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,7 @@ using osu.Framework.Extensions.Color4Extensions;
|
|||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Effects;
|
using osu.Framework.Graphics.Effects;
|
||||||
using osu.Game.Beatmaps;
|
using osu.Game.Beatmaps;
|
||||||
|
using osu.Game.Resources.Localisation.Web;
|
||||||
using osu.Game.Rulesets;
|
using osu.Game.Rulesets;
|
||||||
using osuTK;
|
using osuTK;
|
||||||
using osuTK.Graphics;
|
using osuTK.Graphics;
|
||||||
@ -54,7 +55,7 @@ namespace osu.Game.Overlays.BeatmapSet
|
|||||||
{
|
{
|
||||||
public BeatmapHeaderTitle()
|
public BeatmapHeaderTitle()
|
||||||
{
|
{
|
||||||
Title = "beatmap info";
|
Title = PageTitleStrings.MainBeatmapsetsControllerShow;
|
||||||
IconTexture = "Icons/Hexacons/beatmap";
|
IconTexture = "Icons/Hexacons/beatmap";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,10 @@ using osu.Framework.Bindables;
|
|||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
using osu.Framework.Graphics.Shapes;
|
using osu.Framework.Graphics.Shapes;
|
||||||
|
using osu.Framework.Localisation;
|
||||||
|
using osu.Game.Localisation;
|
||||||
using osu.Game.Online.API.Requests.Responses;
|
using osu.Game.Online.API.Requests.Responses;
|
||||||
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.Changelog
|
namespace osu.Game.Overlays.Changelog
|
||||||
{
|
{
|
||||||
@ -21,16 +24,16 @@ namespace osu.Game.Overlays.Changelog
|
|||||||
|
|
||||||
public ChangelogUpdateStreamControl Streams;
|
public ChangelogUpdateStreamControl Streams;
|
||||||
|
|
||||||
private const string listing_string = "listing";
|
public static LocalisableString ListingString => LayoutStrings.HeaderChangelogIndex;
|
||||||
|
|
||||||
private Box streamsBackground;
|
private Box streamsBackground;
|
||||||
|
|
||||||
public ChangelogHeader()
|
public ChangelogHeader()
|
||||||
{
|
{
|
||||||
TabControl.AddItem(listing_string);
|
TabControl.AddItem(ListingString);
|
||||||
Current.ValueChanged += e =>
|
Current.ValueChanged += e =>
|
||||||
{
|
{
|
||||||
if (e.NewValue == listing_string)
|
if (e.NewValue == ListingString)
|
||||||
ListingSelected?.Invoke();
|
ListingSelected?.Invoke();
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -63,7 +66,7 @@ namespace osu.Game.Overlays.Changelog
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Current.Value = listing_string;
|
Current.Value = ListingString;
|
||||||
Streams.Current.Value = null;
|
Streams.Current.Value = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -114,8 +117,8 @@ namespace osu.Game.Overlays.Changelog
|
|||||||
{
|
{
|
||||||
public ChangelogHeaderTitle()
|
public ChangelogHeaderTitle()
|
||||||
{
|
{
|
||||||
Title = "changelog";
|
Title = PageTitleStrings.MainChangelogControllerDefault;
|
||||||
Description = "track recent dev updates in the osu! ecosystem";
|
Description = NamedOverlayComponentStrings.ChangelogDescription;
|
||||||
IconTexture = "Icons/Hexacons/devtools";
|
IconTexture = "Icons/Hexacons/devtools";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
|
using osu.Game.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.Dashboard
|
namespace osu.Game.Overlays.Dashboard
|
||||||
@ -16,37 +16,19 @@ namespace osu.Game.Overlays.Dashboard
|
|||||||
{
|
{
|
||||||
public DashboardTitle()
|
public DashboardTitle()
|
||||||
{
|
{
|
||||||
Title = HomeStrings.UserTitle;
|
Title = PageTitleStrings.MainHomeControllerIndex;
|
||||||
Description = "view your friends and other information";
|
Description = NamedOverlayComponentStrings.DashboardDescription;
|
||||||
IconTexture = "Icons/Hexacons/social";
|
IconTexture = "Icons/Hexacons/social";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[LocalisableEnum(typeof(DashboardOverlayTabsEnumLocalisationMapper))]
|
|
||||||
public enum DashboardOverlayTabs
|
public enum DashboardOverlayTabs
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(FriendsStrings), nameof(FriendsStrings.TitleCompact))]
|
||||||
Friends,
|
Friends,
|
||||||
|
|
||||||
[Description("Currently Playing")]
|
[Description("Currently Playing")]
|
||||||
CurrentlyPlaying
|
CurrentlyPlaying
|
||||||
}
|
}
|
||||||
|
|
||||||
public class DashboardOverlayTabsEnumLocalisationMapper : EnumLocalisationMapper<DashboardOverlayTabs>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(DashboardOverlayTabs value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case DashboardOverlayTabs.Friends:
|
|
||||||
return FriendsStrings.TitleCompact;
|
|
||||||
|
|
||||||
case DashboardOverlayTabs.CurrentlyPlaying:
|
|
||||||
return @"Currently Playing";
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,38 +1,20 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.Dashboard.Friends
|
namespace osu.Game.Overlays.Dashboard.Friends
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(OnlineStatusEnumLocalisationMapper))]
|
|
||||||
public enum OnlineStatus
|
public enum OnlineStatus
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(UsersStrings), nameof(UsersStrings.StatusAll))]
|
||||||
All,
|
All,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(UsersStrings), nameof(UsersStrings.StatusOnline))]
|
||||||
Online,
|
Online,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(UsersStrings), nameof(UsersStrings.StatusOffline))]
|
||||||
Offline
|
Offline
|
||||||
}
|
}
|
||||||
|
|
||||||
public class OnlineStatusEnumLocalisationMapper : EnumLocalisationMapper<OnlineStatus>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(OnlineStatus value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case OnlineStatus.All:
|
|
||||||
return SortStrings.All;
|
|
||||||
|
|
||||||
case OnlineStatus.Online:
|
|
||||||
return UsersStrings.StatusOnline;
|
|
||||||
|
|
||||||
case OnlineStatus.Offline:
|
|
||||||
return UsersStrings.StatusOffline;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
@ -12,33 +11,16 @@ namespace osu.Game.Overlays.Dashboard.Friends
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
[LocalisableEnum(typeof(UserSortCriteriaEnumLocalisationMappper))]
|
|
||||||
public enum UserSortCriteria
|
public enum UserSortCriteria
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(SortStrings), nameof(SortStrings.LastVisit))]
|
||||||
[Description(@"Recently Active")]
|
[Description(@"Recently Active")]
|
||||||
LastVisit,
|
LastVisit,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(SortStrings), nameof(SortStrings.Rank))]
|
||||||
Rank,
|
Rank,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(SortStrings), nameof(SortStrings.Username))]
|
||||||
Username
|
Username
|
||||||
}
|
}
|
||||||
|
|
||||||
public class UserSortCriteriaEnumLocalisationMappper : EnumLocalisationMapper<UserSortCriteria>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(UserSortCriteria value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case UserSortCriteria.LastVisit:
|
|
||||||
return SortStrings.LastVisit;
|
|
||||||
|
|
||||||
case UserSortCriteria.Rank:
|
|
||||||
return SortStrings.Rank;
|
|
||||||
|
|
||||||
case UserSortCriteria.Username:
|
|
||||||
return SortStrings.Username;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -4,12 +4,15 @@
|
|||||||
using System;
|
using System;
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Localisation;
|
||||||
|
using osu.Game.Localisation;
|
||||||
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.News
|
namespace osu.Game.Overlays.News
|
||||||
{
|
{
|
||||||
public class NewsHeader : BreadcrumbControlOverlayHeader
|
public class NewsHeader : BreadcrumbControlOverlayHeader
|
||||||
{
|
{
|
||||||
private const string front_page_string = "frontpage";
|
public static LocalisableString FrontPageString => NewsStrings.IndexTitleInfo;
|
||||||
|
|
||||||
public Action ShowFrontPage;
|
public Action ShowFrontPage;
|
||||||
|
|
||||||
@ -17,7 +20,7 @@ namespace osu.Game.Overlays.News
|
|||||||
|
|
||||||
public NewsHeader()
|
public NewsHeader()
|
||||||
{
|
{
|
||||||
TabControl.AddItem(front_page_string);
|
TabControl.AddItem(FrontPageString);
|
||||||
|
|
||||||
article.BindValueChanged(onArticleChanged, true);
|
article.BindValueChanged(onArticleChanged, true);
|
||||||
}
|
}
|
||||||
@ -28,7 +31,7 @@ namespace osu.Game.Overlays.News
|
|||||||
|
|
||||||
Current.BindValueChanged(e =>
|
Current.BindValueChanged(e =>
|
||||||
{
|
{
|
||||||
if (e.NewValue == front_page_string)
|
if (e.NewValue == FrontPageString)
|
||||||
ShowFrontPage?.Invoke();
|
ShowFrontPage?.Invoke();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -49,7 +52,7 @@ namespace osu.Game.Overlays.News
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Current.Value = front_page_string;
|
Current.Value = FrontPageString;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,8 +64,8 @@ namespace osu.Game.Overlays.News
|
|||||||
{
|
{
|
||||||
public NewsHeaderTitle()
|
public NewsHeaderTitle()
|
||||||
{
|
{
|
||||||
Title = "news";
|
Title = PageTitleStrings.MainNewsControllerDefault;
|
||||||
Description = "get up-to-date on community happenings";
|
Description = NamedOverlayComponentStrings.NewsDescription;
|
||||||
IconTexture = "Icons/Hexacons/news";
|
IconTexture = "Icons/Hexacons/news";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -12,7 +12,6 @@ using osu.Framework.Allocation;
|
|||||||
using osuTK.Graphics;
|
using osuTK.Graphics;
|
||||||
using osu.Framework.Graphics.Cursor;
|
using osu.Framework.Graphics.Cursor;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using System;
|
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
using osu.Framework.Extensions;
|
using osu.Framework.Extensions;
|
||||||
|
|
||||||
@ -101,32 +100,15 @@ namespace osu.Game.Overlays
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[LocalisableEnum(typeof(OverlayPanelDisplayStyleEnumLocalisationMapper))]
|
|
||||||
public enum OverlayPanelDisplayStyle
|
public enum OverlayPanelDisplayStyle
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(UsersStrings), nameof(UsersStrings.ViewModeCard))]
|
||||||
Card,
|
Card,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(UsersStrings), nameof(UsersStrings.ViewModeList))]
|
||||||
List,
|
List,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(UsersStrings), nameof(UsersStrings.ViewModeBrick))]
|
||||||
Brick
|
Brick
|
||||||
}
|
}
|
||||||
|
|
||||||
public class OverlayPanelDisplayStyleEnumLocalisationMapper : EnumLocalisationMapper<OverlayPanelDisplayStyle>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(OverlayPanelDisplayStyle value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case OverlayPanelDisplayStyle.Card:
|
|
||||||
return UsersStrings.ViewModeCard;
|
|
||||||
|
|
||||||
case OverlayPanelDisplayStyle.List:
|
|
||||||
return UsersStrings.ViewModeList;
|
|
||||||
|
|
||||||
case OverlayPanelDisplayStyle.Brick:
|
|
||||||
return UsersStrings.ViewModeBrick;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,13 +1,12 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using osu.Framework.Graphics;
|
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
|
using osu.Game.Localisation;
|
||||||
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
using osu.Game.Rulesets;
|
using osu.Game.Rulesets;
|
||||||
using osu.Game.Users;
|
using osu.Game.Users;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
|
||||||
using osu.Framework.Localisation;
|
|
||||||
using System;
|
|
||||||
|
|
||||||
namespace osu.Game.Overlays.Rankings
|
namespace osu.Game.Overlays.Rankings
|
||||||
{
|
{
|
||||||
@ -33,42 +32,9 @@ namespace osu.Game.Overlays.Rankings
|
|||||||
public RankingsTitle()
|
public RankingsTitle()
|
||||||
{
|
{
|
||||||
Title = PageTitleStrings.MainRankingControllerDefault;
|
Title = PageTitleStrings.MainRankingControllerDefault;
|
||||||
Description = "find out who's the best right now";
|
Description = NamedOverlayComponentStrings.RankingsDescription;
|
||||||
IconTexture = "Icons/Hexacons/rankings";
|
IconTexture = "Icons/Hexacons/rankings";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[LocalisableEnum(typeof(RankingsScopeEnumLocalisationMapper))]
|
|
||||||
public enum RankingsScope
|
|
||||||
{
|
|
||||||
Performance,
|
|
||||||
Spotlights,
|
|
||||||
Score,
|
|
||||||
Country
|
|
||||||
}
|
|
||||||
|
|
||||||
public class RankingsScopeEnumLocalisationMapper : EnumLocalisationMapper<RankingsScope>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(RankingsScope value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case RankingsScope.Performance:
|
|
||||||
return RankingsStrings.TypePerformance;
|
|
||||||
|
|
||||||
case RankingsScope.Spotlights:
|
|
||||||
return RankingsStrings.TypeCharts;
|
|
||||||
|
|
||||||
case RankingsScope.Score:
|
|
||||||
return RankingsStrings.TypeScore;
|
|
||||||
|
|
||||||
case RankingsScope.Country:
|
|
||||||
return RankingsStrings.TypeCountry;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
23
osu.Game/Overlays/Rankings/RankingsScope.cs
Normal file
23
osu.Game/Overlays/Rankings/RankingsScope.cs
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
// 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 osu.Framework.Localisation;
|
||||||
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
|
namespace osu.Game.Overlays.Rankings
|
||||||
|
{
|
||||||
|
public enum RankingsScope
|
||||||
|
{
|
||||||
|
[LocalisableDescription(typeof(RankingsStrings), nameof(RankingsStrings.TypePerformance))]
|
||||||
|
Performance,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(RankingsStrings), nameof(RankingsStrings.TypeCharts))]
|
||||||
|
Spotlights,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(RankingsStrings), nameof(RankingsStrings.TypeScore))]
|
||||||
|
Score,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(RankingsStrings), nameof(RankingsStrings.TypeCountry))]
|
||||||
|
Country
|
||||||
|
}
|
||||||
|
}
|
@ -1,7 +1,6 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using osu.Framework.Extensions.LocalisationExtensions;
|
using osu.Framework.Extensions.LocalisationExtensions;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
@ -16,28 +15,12 @@ namespace osu.Game.Overlays.Rankings
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[LocalisableEnum(typeof(RankingsSortCriteriaEnumLocalisationMapper))]
|
|
||||||
public enum RankingsSortCriteria
|
public enum RankingsSortCriteria
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(SortStrings), nameof(SortStrings.All))]
|
||||||
All,
|
All,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(SortStrings), nameof(SortStrings.Friends))]
|
||||||
Friends
|
Friends
|
||||||
}
|
}
|
||||||
|
|
||||||
public class RankingsSortCriteriaEnumLocalisationMapper : EnumLocalisationMapper<RankingsSortCriteria>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(RankingsSortCriteria value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case RankingsSortCriteria.All:
|
|
||||||
return SortStrings.All;
|
|
||||||
|
|
||||||
case RankingsSortCriteria.Friends:
|
|
||||||
return SortStrings.Friends;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -6,15 +6,18 @@ using System.Linq;
|
|||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
|
using osu.Game.Localisation;
|
||||||
using osu.Game.Online.API.Requests.Responses;
|
using osu.Game.Online.API.Requests.Responses;
|
||||||
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Overlays.Wiki
|
namespace osu.Game.Overlays.Wiki
|
||||||
{
|
{
|
||||||
public class WikiHeader : BreadcrumbControlOverlayHeader
|
public class WikiHeader : BreadcrumbControlOverlayHeader
|
||||||
{
|
{
|
||||||
private const string index_page_string = "index";
|
|
||||||
private const string index_path = "Main_Page";
|
private const string index_path = "Main_Page";
|
||||||
|
|
||||||
|
public static LocalisableString IndexPageString => LayoutStrings.HeaderHelpIndex;
|
||||||
|
|
||||||
public readonly Bindable<APIWikiPage> WikiPageData = new Bindable<APIWikiPage>();
|
public readonly Bindable<APIWikiPage> WikiPageData = new Bindable<APIWikiPage>();
|
||||||
|
|
||||||
public Action ShowIndexPage;
|
public Action ShowIndexPage;
|
||||||
@ -22,8 +25,8 @@ namespace osu.Game.Overlays.Wiki
|
|||||||
|
|
||||||
public WikiHeader()
|
public WikiHeader()
|
||||||
{
|
{
|
||||||
TabControl.AddItem(index_page_string);
|
TabControl.AddItem(IndexPageString);
|
||||||
Current.Value = index_page_string;
|
Current.Value = IndexPageString;
|
||||||
|
|
||||||
WikiPageData.BindValueChanged(onWikiPageChange);
|
WikiPageData.BindValueChanged(onWikiPageChange);
|
||||||
Current.BindValueChanged(onCurrentChange);
|
Current.BindValueChanged(onCurrentChange);
|
||||||
@ -37,11 +40,11 @@ namespace osu.Game.Overlays.Wiki
|
|||||||
TabControl.Clear();
|
TabControl.Clear();
|
||||||
Current.Value = null;
|
Current.Value = null;
|
||||||
|
|
||||||
TabControl.AddItem(index_page_string);
|
TabControl.AddItem(IndexPageString);
|
||||||
|
|
||||||
if (e.NewValue.Path == index_path)
|
if (e.NewValue.Path == index_path)
|
||||||
{
|
{
|
||||||
Current.Value = index_page_string;
|
Current.Value = IndexPageString;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,7 +60,7 @@ namespace osu.Game.Overlays.Wiki
|
|||||||
if (e.NewValue == TabControl.Items.LastOrDefault())
|
if (e.NewValue == TabControl.Items.LastOrDefault())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (e.NewValue == index_page_string)
|
if (e.NewValue == IndexPageString)
|
||||||
{
|
{
|
||||||
ShowIndexPage?.Invoke();
|
ShowIndexPage?.Invoke();
|
||||||
return;
|
return;
|
||||||
@ -74,8 +77,8 @@ namespace osu.Game.Overlays.Wiki
|
|||||||
{
|
{
|
||||||
public WikiHeaderTitle()
|
public WikiHeaderTitle()
|
||||||
{
|
{
|
||||||
Title = "wiki";
|
Title = PageTitleStrings.MainWikiControllerDefault;
|
||||||
Description = "knowledge base";
|
Description = NamedOverlayComponentStrings.WikiDescription;
|
||||||
IconTexture = "Icons/Hexacons/wiki";
|
IconTexture = "Icons/Hexacons/wiki";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,74 +1,44 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// 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.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.ComponentModel;
|
using System.ComponentModel;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
using osu.Game.Resources.Localisation.Web;
|
using osu.Game.Resources.Localisation.Web;
|
||||||
|
|
||||||
namespace osu.Game.Scoring
|
namespace osu.Game.Scoring
|
||||||
{
|
{
|
||||||
[LocalisableEnum(typeof(ScoreRankEnumLocalisationMapper))]
|
|
||||||
public enum ScoreRank
|
public enum ScoreRank
|
||||||
{
|
{
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.RankD))]
|
||||||
[Description(@"D")]
|
[Description(@"D")]
|
||||||
D,
|
D,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.RankC))]
|
||||||
[Description(@"C")]
|
[Description(@"C")]
|
||||||
C,
|
C,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.RankB))]
|
||||||
[Description(@"B")]
|
[Description(@"B")]
|
||||||
B,
|
B,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.RankA))]
|
||||||
[Description(@"A")]
|
[Description(@"A")]
|
||||||
A,
|
A,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.RankS))]
|
||||||
[Description(@"S")]
|
[Description(@"S")]
|
||||||
S,
|
S,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.RankSH))]
|
||||||
[Description(@"S+")]
|
[Description(@"S+")]
|
||||||
SH,
|
SH,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.RankX))]
|
||||||
[Description(@"SS")]
|
[Description(@"SS")]
|
||||||
X,
|
X,
|
||||||
|
|
||||||
|
[LocalisableDescription(typeof(BeatmapsStrings), nameof(BeatmapsStrings.RankXH))]
|
||||||
[Description(@"SS+")]
|
[Description(@"SS+")]
|
||||||
XH,
|
XH,
|
||||||
}
|
}
|
||||||
|
|
||||||
public class ScoreRankEnumLocalisationMapper : EnumLocalisationMapper<ScoreRank>
|
|
||||||
{
|
|
||||||
public override LocalisableString Map(ScoreRank value)
|
|
||||||
{
|
|
||||||
switch (value)
|
|
||||||
{
|
|
||||||
case ScoreRank.XH:
|
|
||||||
return BeatmapsStrings.RankXH;
|
|
||||||
|
|
||||||
case ScoreRank.X:
|
|
||||||
return BeatmapsStrings.RankX;
|
|
||||||
|
|
||||||
case ScoreRank.SH:
|
|
||||||
return BeatmapsStrings.RankSH;
|
|
||||||
|
|
||||||
case ScoreRank.S:
|
|
||||||
return BeatmapsStrings.RankS;
|
|
||||||
|
|
||||||
case ScoreRank.A:
|
|
||||||
return BeatmapsStrings.RankA;
|
|
||||||
|
|
||||||
case ScoreRank.B:
|
|
||||||
return BeatmapsStrings.RankB;
|
|
||||||
|
|
||||||
case ScoreRank.C:
|
|
||||||
return BeatmapsStrings.RankC;
|
|
||||||
|
|
||||||
case ScoreRank.D:
|
|
||||||
return BeatmapsStrings.RankD;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new ArgumentOutOfRangeException(nameof(value), value, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -36,8 +36,8 @@
|
|||||||
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
||||||
</PackageReference>
|
</PackageReference>
|
||||||
<PackageReference Include="Realm" Version="10.3.0" />
|
<PackageReference Include="Realm" Version="10.3.0" />
|
||||||
<PackageReference Include="ppy.osu.Framework" Version="2021.728.0" />
|
<PackageReference Include="ppy.osu.Framework" Version="2021.803.0" />
|
||||||
<PackageReference Include="ppy.osu.Game.Resources" Version="2021.730.0" />
|
<PackageReference Include="ppy.osu.Game.Resources" Version="2021.803.0" />
|
||||||
<PackageReference Include="Sentry" Version="3.8.3" />
|
<PackageReference Include="Sentry" Version="3.8.3" />
|
||||||
<PackageReference Include="SharpCompress" Version="0.28.3" />
|
<PackageReference Include="SharpCompress" Version="0.28.3" />
|
||||||
<PackageReference Include="NUnit" Version="3.13.2" />
|
<PackageReference Include="NUnit" Version="3.13.2" />
|
||||||
|
@ -70,8 +70,8 @@
|
|||||||
<Reference Include="System.Net.Http" />
|
<Reference Include="System.Net.Http" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup Label="Package References">
|
<ItemGroup Label="Package References">
|
||||||
<PackageReference Include="ppy.osu.Framework.iOS" Version="2021.728.0" />
|
<PackageReference Include="ppy.osu.Framework.iOS" Version="2021.803.0" />
|
||||||
<PackageReference Include="ppy.osu.Game.Resources" Version="2021.730.0" />
|
<PackageReference Include="ppy.osu.Game.Resources" Version="2021.803.0" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<!-- See https://github.com/dotnet/runtime/issues/35988 (can be removed after Xamarin uses net5.0 / net6.0) -->
|
<!-- See https://github.com/dotnet/runtime/issues/35988 (can be removed after Xamarin uses net5.0 / net6.0) -->
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
@ -93,7 +93,7 @@
|
|||||||
<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="2.2.6" />
|
<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="2.2.6" />
|
||||||
<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite.Core" Version="2.2.6" />
|
<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite.Core" Version="2.2.6" />
|
||||||
<PackageReference Include="Newtonsoft.Json" Version="13.0.1" />
|
<PackageReference Include="Newtonsoft.Json" Version="13.0.1" />
|
||||||
<PackageReference Include="ppy.osu.Framework" Version="2021.728.0" />
|
<PackageReference Include="ppy.osu.Framework" Version="2021.803.0" />
|
||||||
<PackageReference Include="SharpCompress" Version="0.28.3" />
|
<PackageReference Include="SharpCompress" Version="0.28.3" />
|
||||||
<PackageReference Include="NUnit" Version="3.13.2" />
|
<PackageReference Include="NUnit" Version="3.13.2" />
|
||||||
<PackageReference Include="SharpRaven" Version="2.4.0" />
|
<PackageReference Include="SharpRaven" Version="2.4.0" />
|
||||||
|
Loading…
Reference in New Issue
Block a user