Add role placeholder to Discord message format (#4329)

Co-authored-by: Josh Roy <10731363+JRoy@users.noreply.github.com>
This commit is contained in:
pop4959 2021-07-07 08:55:25 -07:00 committed by GitHub
parent ff58d8e443
commit 2858bd3784
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 19 additions and 2 deletions

View File

@ -347,7 +347,7 @@ public class DiscordSettings implements IConf {
"timestamp", "level", "message"); "timestamp", "level", "message");
discordToMcFormat = generateMessageFormat(getFormatString("discord-to-mc"), "&6[#{channel}] &3{fullname}&7: &f{message}", true, discordToMcFormat = generateMessageFormat(getFormatString("discord-to-mc"), "&6[#{channel}] &3{fullname}&7: &f{message}", true,
"channel", "username", "discriminator", "fullname", "nickname", "color", "message"); "channel", "username", "discriminator", "fullname", "nickname", "color", "message", "role");
unmuteFormat = generateMessageFormat(getFormatString("unmute"), "{displayname} unmuted.", false, "username", "displayname"); unmuteFormat = generateMessageFormat(getFormatString("unmute"), "{displayname} unmuted.", false, "username", "displayname");
tempMuteFormat = generateMessageFormat(getFormatString("temporary-mute"), "{controllerdisplayname} has muted player {displayname} for {time}.", false, tempMuteFormat = generateMessageFormat(getFormatString("temporary-mute"), "{controllerdisplayname} has muted player {displayname} for {time}.", false,
"username", "displayname", "controllername", "controllerdisplayname", "time"); "username", "displayname", "controllername", "controllerdisplayname", "time");

View File

@ -86,7 +86,7 @@ public class DiscordListener extends ListenerAdapter {
final String formattedMessage = EmojiParser.parseToAliases(MessageUtil.formatMessage(plugin.getPlugin().getSettings().getDiscordToMcFormat(), final String formattedMessage = EmojiParser.parseToAliases(MessageUtil.formatMessage(plugin.getPlugin().getSettings().getDiscordToMcFormat(),
event.getChannel().getName(), user.getName(), user.getDiscriminator(), user.getAsTag(), event.getChannel().getName(), user.getName(), user.getDiscriminator(), user.getAsTag(),
member.getEffectiveName(), DiscordUtil.getRoleColorFormat(member), finalMessage), EmojiParser.FitzpatrickAction.REMOVE); member.getEffectiveName(), DiscordUtil.getRoleColorFormat(member), finalMessage, DiscordUtil.getRoleFormat(member)), EmojiParser.FitzpatrickAction.REMOVE);
for (IUser essUser : plugin.getPlugin().getEss().getOnlineUsers()) { for (IUser essUser : plugin.getPlugin().getEss().getOnlineUsers()) {
for (String group : keys) { for (String group : keys) {

View File

@ -121,6 +121,22 @@ public final class DiscordUtil {
return future; return future;
} }
/**
* Gets the highest role of a given member or an empty string if the member has no roles.
*
* @param member The target member.
* @return The highest role or blank string.
*/
public static String getRoleFormat(Member member) {
final List<Role> roles = member.getRoles();
if (roles.isEmpty()) {
return "";
}
return roles.get(0).getName();
}
/** /**
* Gets the uppermost bukkit color code of a given member or an empty string if the server version is &lt; 1.16. * Gets the uppermost bukkit color code of a given member or an empty string if the server version is &lt; 1.16.
* *

View File

@ -212,6 +212,7 @@ messages:
# - {discriminator}: The four numbers displayed after the user's name # - {discriminator}: The four numbers displayed after the user's name
# - {fullname}: Equivalent to typing "{username}#{discriminator}" # - {fullname}: Equivalent to typing "{username}#{discriminator}"
# - {nickname}: The nickname of the user who sent the message. (Will return username if user has no nickname) # - {nickname}: The nickname of the user who sent the message. (Will return username if user has no nickname)
# - {role}: The name of the user's topmost role on Discord. If the user doesn't have a role, the placeholder is empty.
# - {color}: The minecraft color representative of the user's topmost role color on discord. If the user doesn't have a role color, the placeholder is empty. # - {color}: The minecraft color representative of the user's topmost role color on discord. If the user doesn't have a role color, the placeholder is empty.
# - {message}: The content of the message being sent # - {message}: The content of the message being sent
discord-to-mc: "&6[#{channel}] &3{fullname}&7: &f{message}" discord-to-mc: "&6[#{channel}] &3{fullname}&7: &f{message}"