diff options
author | Colin Reeder <colin@vpzom.click> | 2020-07-28 20:54:14 -0600 |
---|---|---|
committer | Colin Reeder <colin@vpzom.click> | 2020-07-28 20:54:14 -0600 |
commit | d405e70b780e1b8bc7e2014962624911b42b32ad (patch) | |
tree | 3b0cc24bf88f3addfc39a7e1d43c968c3bc7906a /src | |
parent | 4eba40cc1d5ba8b88dd02f144d1656947cc67104 (diff) |
Add sorting options for community posts
Diffstat (limited to 'src')
-rw-r--r-- | src/main.rs | 26 | ||||
-rw-r--r-- | src/routes/communities.rs | 33 |
2 files changed, 57 insertions, 2 deletions
diff --git a/src/main.rs b/src/main.rs index 2d40dd5..034990b 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,6 +1,7 @@ #![allow(unused_braces)] use crate::resp_types::RespLoginInfo; +use serde_derive::Deserialize; use std::borrow::Cow; use std::collections::HashMap; use std::sync::Arc; @@ -11,6 +12,31 @@ mod resp_types; mod routes; mod util; +#[derive(Deserialize, PartialEq, Clone, Copy)] +#[serde(rename_all = "snake_case")] +pub enum SortType { + Hot, + New, +} + +impl SortType { + pub const VALUES: &'static [SortType] = &[SortType::Hot, SortType::New]; + + pub fn as_str(&self) -> &'static str { + match self { + SortType::Hot => "hot", + SortType::New => "new", + } + } + + pub fn lang_key(&self) -> &'static str { + match self { + SortType::Hot => "sort_hot", + SortType::New => "sort_new", + } + } +} + pub type HttpClient = hyper::Client<hyper_tls::HttpsConnector<hyper::client::HttpConnector>>; pub struct RouteContext { diff --git a/src/routes/communities.rs b/src/routes/communities.rs index 442b958..7a1e906 100644 --- a/src/routes/communities.rs +++ b/src/routes/communities.rs @@ -93,6 +93,18 @@ async fn page_community( ) -> Result<hyper::Response<hyper::Body>, crate::Error> { let (community_id,) = params; + fn default_sort() -> crate::SortType { + crate::SortType::Hot + } + + #[derive(Deserialize)] + struct Query { + #[serde(default = "default_sort")] + sort: crate::SortType, + } + + let query: Query = serde_urlencoded::from_str(req.uri().query().unwrap_or(""))?; + let lang = crate::get_lang_for_req(&req); let cookies = get_cookie_map_for_req(&req)?; @@ -130,8 +142,10 @@ async fn page_community( ctx.http_client .request(for_client( hyper::Request::get(format!( - "{}/api/unstable/communities/{}/posts", - ctx.backend_host, community_id + "{}/api/unstable/communities/{}/posts?sort={}", + ctx.backend_host, + community_id, + query.sort.as_str(), )) .body(Default::default())?, req.headers(), @@ -215,6 +229,21 @@ async fn page_community( } <p>{community_info.description.as_ref()}</p> </div> + <div class={"sortOptions"}> + <span>{lang.tr("sort", None)}</span> + { + crate::SortType::VALUES.iter() + .map(|value| { + let name = lang.tr(value.lang_key(), None); + if query.sort == *value { + render::rsx! { <span>{name}</span> } + } else { + render::rsx! { <a href={format!("/communities/{}?sort={}", community_id, value.as_str())}>{name}</a> } + } + }) + .collect::<Vec<_>>() + } + </div> { if posts.is_empty() { Some(render::rsx! { <p>{lang.tr("nothing", None)}</p> }) |