diff --git a/src/search.rs b/src/search.rs index 5ea99e3..9911217 100644 --- a/src/search.rs +++ b/src/search.rs @@ -4,20 +4,26 @@ use actix_web::{HttpRequest, HttpResponse}; use askama::Template; // STRUCTS +struct SearchParams { + q: String, + sort: String, + t: String, + before: String, + after: String, + restrict_sr: String, +} + #[derive(Template)] #[template(path = "search.html", escape = "none")] struct SearchTemplate { posts: Vec, - query: String, sub: String, - sort: (String, String), - ends: (String, String), + params: SearchParams, } // SERVICES pub async fn find(req: HttpRequest) -> HttpResponse { let path = format!("{}.json?{}", req.path(), req.query_string()); - let q = param(&path, "q"); let sort = if param(&path, "sort").is_empty() { "relevance".to_string() } else { @@ -29,10 +35,15 @@ pub async fn find(req: HttpRequest) -> HttpResponse { Ok(posts) => HttpResponse::Ok().content_type("text/html").body( SearchTemplate { posts: posts.0, - query: q, sub, - sort: (sort, param(&path, "t")), - ends: (param(&path, "after"), posts.1), + params: SearchParams { + q: param(&path, "q"), + sort, + t: param(&path, "t"), + before: param(&path, "after"), + after: posts.1, + restrict_sr: param(&path, "restrict_sr"), + }, } .render() .unwrap(), diff --git a/src/utils.rs b/src/utils.rs index e0d601e..171d422 100644 --- a/src/utils.rs +++ b/src/utils.rs @@ -97,7 +97,7 @@ pub struct ErrorTemplate { // Grab a query param from a url pub fn param(path: &str, value: &str) -> String { - let url = Url::parse(format!("https://reddit.com/{}", path).as_str()).unwrap(); + let url = Url::parse(format!("https://libredd.it/{}", path).as_str()).unwrap(); let pairs: std::collections::HashMap<_, _> = url.query_pairs().into_owned().collect(); pairs.get(value).unwrap_or(&String::new()).to_owned() } diff --git a/templates/search.html b/templates/search.html index 1ec5374..8b2735d 100644 --- a/templates/search.html +++ b/templates/search.html @@ -1,22 +1,22 @@ {% extends "base.html" %} {% import "utils.html" as utils %} -{% block title %}Libreddit: search results - {{ query }}{% endblock %} +{% block title %}Libreddit: search results - {{ params.q }}{% endblock %} {% block content %}
- + {% if sub != "" %}
- +
{% endif %} {% if sort.0 != "new" %}{% if params.sort != "new" %}{% endif %}
{% for post in posts %} @@ -62,12 +62,16 @@ {% endfor %}