From 1a8886610d6a9662646ddb6c3541546dbe77f8df Mon Sep 17 00:00:00 2001 From: Benedikt Peetz Date: Thu, 26 Dec 2024 17:59:32 +0100 Subject: fix(pkgs/back): Sort the issues by descending date --- pkgs/by-name/ba/back/src/web/mod.rs | 31 ++++++++++++++++++------------- 1 file changed, 18 insertions(+), 13 deletions(-) (limited to 'pkgs/by-name/ba/back/src/web/mod.rs') diff --git a/pkgs/by-name/ba/back/src/web/mod.rs b/pkgs/by-name/ba/back/src/web/mod.rs index 1e6a5af..35dc59f 100644 --- a/pkgs/by-name/ba/back/src/web/mod.rs +++ b/pkgs/by-name/ba/back/src/web/mod.rs @@ -39,20 +39,25 @@ pub fn issue_list_boilerplate( ) -> error::Result> { let repository = &config.repository; - let issue_list = issues_from_repository(&repository.to_thread_local())? + let mut issue_list = issues_from_repository(&repository.to_thread_local())? .into_iter() - .fold(String::new(), |acc, val| { - let issue = val.collaps(); + .map(|issue| issue.collapse()) + .collect::>(); - format!("{}{}", acc, { - if issue.status == wanted_status { - let issue_entry = issue.to_list_entry(); - issue_entry.0 - } else { - String::new() - } - }) - }); + // Sort by date descending. + issue_list.sort_by_key(|issue| unsafe { issue.timestamp.to_unsafe() }); + issue_list.reverse(); + + let issue_list_str = issue_list.into_iter().fold(String::new(), |acc, issue| { + format!("{}{}", acc, { + if issue.status == wanted_status { + let issue_entry = issue.to_list_entry(); + issue_entry.0 + } else { + String::new() + } + }) + }); let counter_status_lower = counter_status.to_string().to_lowercase(); Ok(RawHtml(format!( @@ -81,7 +86,7 @@ pub fn issue_list_boilerplate( -->
    - {issue_list} + {issue_list_str}
-- cgit 1.4.1