Only announce new records when stats were not recorded

This commit is contained in:
Natsu Kagami 2024-08-04 20:25:43 +02:00 committed by Natsu Kagami
parent a4407df97c
commit 6e6821510d

View file

@ -118,20 +118,20 @@ impl Announcer {
last_update: now, last_update: now,
}; };
let last = user.modes.insert(mode, stats); let last = user.modes.insert(mode, stats);
let last_update = last.as_ref().map(|v| v.last_update);
// broadcast // broadcast
let mention = user.user_id; let mention = user.user_id;
let broadcast_to = broadcast_to.clone(); let broadcast_to = broadcast_to.clone();
let ctx = ctx.clone(); let ctx = ctx.clone();
let env = env.clone(); let env = env.clone();
if let Some(last) = last {
spawn_future(async move { spawn_future(async move {
let top = top let top = top
.into_iter() .into_iter()
.enumerate() .enumerate()
.filter(|(_, s)| Self::is_announceable_date(s.date, last_update, now)) .filter(|(_, s)| Self::is_announceable_date(s.date, last.last_update, now))
.map(|(rank, score)| { .map(|(rank, score)| {
CollectedScore::from_top_score(&u, score, mode, rank as u8) CollectedScore::from_top_score(&u, score, mode, rank as u8 + 1)
}); });
let recents = events let recents = events
.into_iter() .into_iter()
@ -149,16 +149,17 @@ impl Announcer {
.await .await
}); });
} }
}
user.failures = 0; user.failures = 0;
user user
} }
fn is_announceable_date( fn is_announceable_date(
s: DateTime<Utc>, s: DateTime<Utc>,
last_update: Option<DateTime<Utc>>, last_update: impl Into<Option<DateTime<Utc>>>,
now: DateTime<Utc>, now: DateTime<Utc>,
) -> bool { ) -> bool {
(match last_update { (match last_update.into() {
Some(lu) => s > lu, Some(lu) => s > lu,
None => true, None => true,
}) && s <= now }) && s <= now
@ -303,11 +304,17 @@ impl<'a> CollectedScore<'a> {
&ctx, &ctx,
CreateMessage::new() CreateMessage::new()
.content(match self.kind { .content(match self.kind {
ScoreType::TopRecord(_) => { ScoreType::TopRecord(rank) => {
format!("New top record from {}!", mention.mention()) if rank <= 25 {
format!("New leaderboard record from {}!", mention.mention())
} else {
format!("New leaderboard record from **{}**!", member.distinct())
}
} }
ScoreType::WorldRecord(rank) => { ScoreType::WorldRecord(rank) => {
if rank <= 100 { if (self.mode == Mode::Std && rank <= 100)
|| (self.mode != Mode::Std && rank <= 50)
{
format!("New leaderboard record from {}!", mention.mention()) format!("New leaderboard record from {}!", mention.mention())
} else { } else {
format!("New leaderboard record from **{}**!", member.distinct()) format!("New leaderboard record from **{}**!", member.distinct())