Use trait for username display, fix suggestion username
This commit is contained in:
parent
58dbb425ba
commit
6a0a99c193
2 changed files with 16 additions and 7 deletions
|
@ -149,11 +149,7 @@ pub async fn submit(ctx: Context<'_>, submission: serenity::Attachment) -> Resul
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
let username = if author.discriminator == 0 { // new usernames
|
let username = author.username();
|
||||||
author.name.clone()
|
|
||||||
} else {
|
|
||||||
format!("{}#{}", author.name, author.discriminator)
|
|
||||||
};
|
|
||||||
let username = &username;
|
let username = &username;
|
||||||
if !existing_submitter {
|
if !existing_submitter {
|
||||||
let mut submitter_data = Map::new();
|
let mut submitter_data = Map::new();
|
||||||
|
@ -470,7 +466,6 @@ pub async fn suggest(
|
||||||
am
|
am
|
||||||
});
|
});
|
||||||
m.embed(|e| {
|
m.embed(|e| {
|
||||||
let username = format!("{}#{}", author.name, author.discriminator);
|
|
||||||
e.title("New suggestion");
|
e.title("New suggestion");
|
||||||
e.description(if let Context::Prefix(ctx) = ctx {
|
e.description(if let Context::Prefix(ctx) = ctx {
|
||||||
format!("{suggestion}\n\n[See original message]({})", ctx.msg.link(),)
|
format!("{suggestion}\n\n[See original message]({})", ctx.msg.link(),)
|
||||||
|
@ -480,7 +475,7 @@ pub async fn suggest(
|
||||||
let mut embed_author = serenity::builder::CreateEmbedAuthor::default();
|
let mut embed_author = serenity::builder::CreateEmbedAuthor::default();
|
||||||
embed_author
|
embed_author
|
||||||
.icon_url(get_avatar(author))
|
.icon_url(get_avatar(author))
|
||||||
.name(username)
|
.name(author.username())
|
||||||
.url(format!("https://discord.com/users/{}", author.id));
|
.url(format!("https://discord.com/users/{}", author.id));
|
||||||
e.set_author(embed_author);
|
e.set_author(embed_author);
|
||||||
if let Some(accent_color) = accent_color {
|
if let Some(accent_color) = accent_color {
|
||||||
|
|
14
src/utils.rs
14
src/utils.rs
|
@ -13,6 +13,19 @@ use std::io::Read;
|
||||||
use std::io::Write;
|
use std::io::Write;
|
||||||
use std::process::Command;
|
use std::process::Command;
|
||||||
|
|
||||||
|
pub trait User {
|
||||||
|
fn username(&self) -> String;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl User for serenity::User {
|
||||||
|
fn username(&self) -> String {
|
||||||
|
if self.discriminator == 0 {
|
||||||
|
return self.name.clone();
|
||||||
|
}
|
||||||
|
format!("{}#{}", self.name, self.discriminator)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn get_challenge_number() -> i32 {
|
pub fn get_challenge_number() -> i32 {
|
||||||
let challenge_dir = format!("{}/content/challenges", env::var("HUGO").unwrap());
|
let challenge_dir = format!("{}/content/challenges", env::var("HUGO").unwrap());
|
||||||
let paths = fs::read_dir(challenge_dir).unwrap();
|
let paths = fs::read_dir(challenge_dir).unwrap();
|
||||||
|
@ -386,6 +399,7 @@ pub async fn leaderboard(ctx: &Context<'_>) -> Result<(), Error> {
|
||||||
let discriminator = user.discriminator;
|
let discriminator = user.discriminator;
|
||||||
leaderboard_html.push_str(&format!("<tr><td>{place}</td><td><a href=\"{profile}\" target=\"_blank\" class=\"no-underline\"><img src=\"{avatar}\" onerror=\"this.src='/default.png'\"> <span class=\"underline\">{name}"));
|
leaderboard_html.push_str(&format!("<tr><td>{place}</td><td><a href=\"{profile}\" target=\"_blank\" class=\"no-underline\"><img src=\"{avatar}\" onerror=\"this.src='/default.png'\"> <span class=\"underline\">{name}"));
|
||||||
// New usernames have #0000 discriminator
|
// New usernames have #0000 discriminator
|
||||||
|
// Can't use User trait user.display_name() because of muted span
|
||||||
if discriminator != 0 {
|
if discriminator != 0 {
|
||||||
leaderboard_html.push_str(&format!("<span class=\"muted\">#{:0>4}</span>", discriminator));
|
leaderboard_html.push_str(&format!("<span class=\"muted\">#{:0>4}</span>", discriminator));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue