sort upgrade for okporn

This commit is contained in:
Simon
2025-08-10 15:41:57 +00:00
parent 102fc37683
commit 5b544dbbf6
2 changed files with 28 additions and 2 deletions

View File

@@ -502,7 +502,28 @@ async fn status(req: HttpRequest) -> Result<impl web::Responder, web::Error> {
favicon: "https://www.google.com/s2/favicons?sz=64&domain=ok.porn".to_string(),
status: "active".to_string(),
categories: vec![],
options: vec![],
options: vec![ChannelOption {
id: "sort".to_string(),
title: "Sort".to_string(),
description: "Sort the Videos".to_string(), //"Sort the videos by Date or Name.".to_string(),
systemImage: "list.number".to_string(),
colorName: "blue".to_string(),
options: vec![
FilterOption {
id: "new".to_string(),
title: "New".to_string(),
},
FilterOption {
id: "popular".to_string(),
title: "Popular".to_string(),
},
FilterOption {
id: "trending".to_string(),
title: "Trending".to_string(),
},
],
multiSelect: false,
}],
nsfw: true,
});

View File

@@ -37,7 +37,12 @@ impl OkpornProvider {
page: u8,
sort: &str,
) -> Result<Vec<VideoItem>> {
let video_url = format!("{}/{}/", self.url, page);
let sort_string = match sort {
"trending" => "/trending",
"popular" => "/popular",
_ => "",
};
let video_url = format!("{}{}/{}/", self.url, sort_string, page);
let old_items = match cache.get(&video_url) {
Some((time, items)) => {
if time.elapsed().unwrap_or_default().as_secs() < 60 * 5 {