From a46e92e098306c6e919bcee3a7cd04d8a3ddfc92 Mon Sep 17 00:00:00 2001 From: ducdetronquito Date: Mon, 1 Jan 2024 13:40:40 +0100 Subject: [PATCH] feat: Display closest birthday first --- src/output.rs | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/src/output.rs b/src/output.rs index 3383563..d8e15b1 100644 --- a/src/output.rs +++ b/src/output.rs @@ -14,20 +14,24 @@ struct DisplayedBirthday { age: String, #[tabled(rename = "Next birthday")] next_birthday: String, + + #[tabled(skip)] + next_birthday_in_days: i64, } impl DisplayedBirthday { fn from_birthday(birthday: &Birthday, today: NaiveDate) -> DisplayedBirthday { let age = birthday.age(today).unwrap(); let birthyear = birthday.date.year(); - let next_birthday_in_days = (birthday.next(today) - today).num_days(); - let next_birthday = if birthday.is_today(today) { - "today".to_string() + let next_birthday_in_days = if birthday.is_today(today) { + 0 } else { - match next_birthday_in_days { - 1 => "1 day".to_string(), - _ => format!("{next_birthday_in_days} days"), - } + (birthday.next(today) - today).num_days() + }; + let next_birthday = match next_birthday_in_days { + 0 => "today".to_string(), + 1 => "1 day".to_string(), + _ => format!("{next_birthday_in_days} days"), }; DisplayedBirthday { id: birthday.id, @@ -35,15 +39,17 @@ impl DisplayedBirthday { birthday: birthday.date.format("%d %B").to_string(), age: format!("{age} ({birthyear})"), next_birthday, + next_birthday_in_days, } } } pub fn output(birthdays: Vec, today: NaiveDate) { - let displayed_birthdays: Vec = birthdays + let mut displayed_birthdays: Vec = birthdays .iter() .map(|birthday| DisplayedBirthday::from_birthday(birthday, today)) .collect(); + displayed_birthdays.sort_by_key(|birthday| birthday.next_birthday_in_days); let table = Table::new(displayed_birthdays) .with(Style::rounded()) .to_string();