mirror of
https://github.com/ppy/osu.git
synced 2025-01-26 17:02:57 +08:00
Added rulesets rankings updating for Discord RPC
This commit is contained in:
parent
20701edc23
commit
0d7fa3b55c
@ -2,6 +2,7 @@
|
||||
// See the LICENCE file in the repository root for full licence text.
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Text;
|
||||
using DiscordRPC;
|
||||
using DiscordRPC.Message;
|
||||
@ -12,6 +13,7 @@ using osu.Framework.Logging;
|
||||
using osu.Game.Configuration;
|
||||
using osu.Game.Extensions;
|
||||
using osu.Game.Online.API;
|
||||
using osu.Game.Online.API.Requests;
|
||||
using osu.Game.Online.API.Requests.Responses;
|
||||
using osu.Game.Rulesets;
|
||||
using osu.Game.Users;
|
||||
@ -30,6 +32,9 @@ namespace osu.Desktop
|
||||
|
||||
private IBindable<APIUser> user;
|
||||
|
||||
[Resolved]
|
||||
private IAPIProvider api { get; set; }
|
||||
|
||||
private readonly IBindable<UserStatus> status = new Bindable<UserStatus>();
|
||||
private readonly IBindable<UserActivity> activity = new Bindable<UserActivity>();
|
||||
|
||||
@ -66,7 +71,7 @@ namespace osu.Desktop
|
||||
activity.BindTo(u.NewValue.Activity);
|
||||
}, true);
|
||||
|
||||
ruleset.BindValueChanged(_ => updateStatus());
|
||||
ruleset.BindValueChanged(_ => requestUserRulesetsRankings());
|
||||
status.BindValueChanged(_ => updateStatus());
|
||||
activity.BindValueChanged(_ => updateStatus());
|
||||
privacyMode.BindValueChanged(_ => updateStatus());
|
||||
@ -77,7 +82,7 @@ namespace osu.Desktop
|
||||
private void onReady(object _, ReadyMessage __)
|
||||
{
|
||||
Logger.Log("Discord RPC Client ready.", LoggingTarget.Network, LogLevel.Debug);
|
||||
updateStatus();
|
||||
requestUserRulesetsRankings();
|
||||
}
|
||||
|
||||
private void updateStatus()
|
||||
@ -106,7 +111,12 @@ namespace osu.Desktop
|
||||
if (privacyMode.Value == DiscordRichPresenceMode.Limited)
|
||||
presence.Assets.LargeImageText = string.Empty;
|
||||
else
|
||||
presence.Assets.LargeImageText = $"{user.Value.Username}" + (user.Value.Statistics?.GlobalRank > 0 ? $" (rank #{user.Value.Statistics.GlobalRank:N0})" : string.Empty);
|
||||
{
|
||||
if (user.Value.RulesetsStatistics != null && user.Value.RulesetsStatistics.TryGetValue(ruleset.Value.ShortName, out UserStatistics statistics))
|
||||
presence.Assets.LargeImageText = $"{user.Value.Username}" + (statistics.GlobalRank > 0 ? $" (rank #{statistics.GlobalRank:N0})" : string.Empty);
|
||||
else
|
||||
presence.Assets.LargeImageText = $"{user.Value.Username}" + (user.Value.Statistics?.GlobalRank > 0 ? $" (rank #{user.Value.Statistics.GlobalRank:N0})" : string.Empty);
|
||||
}
|
||||
|
||||
// update ruleset
|
||||
presence.Assets.SmallImageKey = ruleset.Value.IsLegacyRuleset() ? $"mode_{ruleset.Value.OnlineID}" : "mode_custom";
|
||||
@ -115,6 +125,47 @@ namespace osu.Desktop
|
||||
client.SetPresence(presence);
|
||||
}
|
||||
|
||||
private void requestUserRulesetsRankings()
|
||||
{
|
||||
RulesetInfo cachedRuleset = ruleset.Value;
|
||||
|
||||
// When first logging in, we can't send a request with an empty id
|
||||
if (api.LocalUser.Value.Id > 1)
|
||||
{
|
||||
var req = new GetUsersRequest(new int[] { api.LocalUser.Value.Id });
|
||||
req.Success += result =>
|
||||
{
|
||||
if (result.Users.Count == 1)
|
||||
{
|
||||
APIUser apiUser = result.Users[0];
|
||||
user.Value.RulesetsStatistics = apiUser.RulesetsStatistics;
|
||||
}
|
||||
|
||||
updateStatus();
|
||||
};
|
||||
req.Failure += _ => updateStatus();
|
||||
|
||||
api.Queue(req);
|
||||
}
|
||||
else
|
||||
{
|
||||
var req = new GetUserRequest(api.LocalUser.Value.Username, ruleset.Value);
|
||||
|
||||
req.Success += result =>
|
||||
{
|
||||
user.Value.RulesetsStatistics ??= new Dictionary<string, UserStatistics>();
|
||||
user.Value.RulesetsStatistics[ruleset.Value.ShortName] = result.Statistics;
|
||||
updateStatus();
|
||||
};
|
||||
req.Failure += error =>
|
||||
{
|
||||
updateStatus();
|
||||
};
|
||||
|
||||
api.Queue(req);
|
||||
}
|
||||
}
|
||||
|
||||
private static readonly int ellipsis_length = Encoding.UTF8.GetByteCount(new[] { '…' });
|
||||
|
||||
private string truncate(string str)
|
||||
|
Loading…
Reference in New Issue
Block a user