From 517abf7ff14deec856d30d1d877381a55814ce6f Mon Sep 17 00:00:00 2001 From: spiral Date: Sat, 1 May 2021 19:20:00 +0100 Subject: [PATCH] feat: show member color in reply embed --- PluralKit.Bot/Proxy/ProxyService.cs | 9 ++++++--- PluralKit.Core/Database/Functions/ProxyMember.cs | 2 ++ PluralKit.Core/Database/Functions/functions.sql | 6 +++++- 3 files changed, 13 insertions(+), 4 deletions(-) diff --git a/PluralKit.Bot/Proxy/ProxyService.cs b/PluralKit.Bot/Proxy/ProxyService.cs index 32781447..e1ac5ac8 100644 --- a/PluralKit.Bot/Proxy/ProxyService.cs +++ b/PluralKit.Bot/Proxy/ProxyService.cs @@ -116,7 +116,7 @@ namespace PluralKit.Bot if (repliedTo != null) { var nickname = await FetchReferencedMessageAuthorNickname(trigger, repliedTo); - var embed = CreateReplyEmbed(trigger, repliedTo, nickname); + var embed = CreateReplyEmbed(match, trigger, repliedTo, nickname); if (embed != null) embeds.Add(embed); } @@ -160,7 +160,7 @@ namespace PluralKit.Bot } } - private Embed CreateReplyEmbed(Message trigger, Message repliedTo, string? nickname) + private Embed CreateReplyEmbed(ProxyMatch match, Message trigger, Message repliedTo, string? nickname) { // repliedTo doesn't have a GuildId field :/ var jumpLink = $"https://discord.com/channels/{trigger.GuildId}/{repliedTo.ChannelId}/{repliedTo.Id}"; @@ -194,11 +194,14 @@ namespace PluralKit.Bot var username = nickname ?? repliedTo.Author.Username; var avatarUrl = $"https://cdn.discordapp.com/avatars/{repliedTo.Author.Id}/{repliedTo.Author.Avatar}.png"; + Console.WriteLine($"color {match.Member.Color}"); + return new Embed { // unicodes: [three-per-em space] [left arrow emoji] [force emoji presentation] Author = new($"{username}\u2004\u21a9\ufe0f", IconUrl: avatarUrl), - Description = content.ToString() + Description = content.ToString(), + Color = match.Member.Color?.ToDiscordColor(), }; } diff --git a/PluralKit.Core/Database/Functions/ProxyMember.cs b/PluralKit.Core/Database/Functions/ProxyMember.cs index fc18a582..681ef179 100644 --- a/PluralKit.Core/Database/Functions/ProxyMember.cs +++ b/PluralKit.Core/Database/Functions/ProxyMember.cs @@ -19,7 +19,9 @@ namespace PluralKit.Core public string? ServerAvatar { get; } public string? Avatar { get; } + public bool AllowAutoproxy { get; } + public string? Color { get; } public string ProxyName(MessageContext ctx) => ctx.SystemTag != null ? $"{ServerName ?? DisplayName ?? Name} {ctx.SystemTag}" diff --git a/PluralKit.Core/Database/Functions/functions.sql b/PluralKit.Core/Database/Functions/functions.sql index f959f447..55628d49 100644 --- a/PluralKit.Core/Database/Functions/functions.sql +++ b/PluralKit.Core/Database/Functions/functions.sql @@ -64,10 +64,12 @@ create function proxy_members(account_id bigint, guild_id bigint) server_name text, display_name text, name text, - + server_avatar text, avatar text, + color char(6), + allow_autoproxy bool ) as $$ @@ -86,6 +88,8 @@ as $$ member_guild.avatar_url as server_avatar, members.avatar_url as avatar, + members.color as color, + members.allow_autoproxy as allow_autoproxy from accounts inner join systems on systems.id = accounts.system