✨ 首页应用列表完成
This commit is contained in:
@@ -1,13 +1,13 @@
|
||||
use crate::handlers::server::get_img_server_url;
|
||||
use crate::models::home::HomeLink;
|
||||
use crate::utils::UA;
|
||||
use crate::models::home::{HomeLink, HomeList, HomeListApp};
|
||||
use crate::utils::{format_icon_url, UA};
|
||||
use super::server::get_json_server_url;
|
||||
|
||||
#[tauri::command]
|
||||
pub async fn get_home_links() -> Result<Vec<HomeLink>, String> {
|
||||
let json_server_url = get_json_server_url();
|
||||
let img_server_url = get_img_server_url();
|
||||
let url = format!("{}home/homelinks.json", json_server_url);
|
||||
let url = format!("{}/home/homelinks.json", json_server_url);
|
||||
|
||||
let client = reqwest::Client::new();
|
||||
let response = client
|
||||
@@ -33,4 +33,56 @@ pub async fn get_home_links() -> Result<Vec<HomeLink>, String> {
|
||||
}
|
||||
|
||||
Ok(links)
|
||||
}
|
||||
|
||||
#[tauri::command]
|
||||
pub async fn get_home_list_apps(json_url: String) -> Result<Vec<HomeListApp>, String> {
|
||||
let json_server_url = get_json_server_url();
|
||||
let url = format!("{}{}", json_server_url, json_url);
|
||||
|
||||
let client = reqwest::Client::new();
|
||||
let response = client
|
||||
.get(&url)
|
||||
.header("User-Agent", UA)
|
||||
.send()
|
||||
.await
|
||||
.map_err(|e| e.to_string())?;
|
||||
|
||||
let response_text = response
|
||||
.text()
|
||||
.await
|
||||
.map_err(|e| e.to_string())?;
|
||||
|
||||
let mut apps: Vec<HomeListApp> = serde_json::from_str(&response_text)
|
||||
.map_err(|e| e.to_string())?;
|
||||
|
||||
for app in &mut apps {
|
||||
app.icon = Some(format_icon_url(&app.category, &app.pkgname));
|
||||
}
|
||||
|
||||
Ok(apps)
|
||||
}
|
||||
|
||||
#[tauri::command]
|
||||
pub async fn get_home_lists() -> Result<Vec<HomeList>, String> {
|
||||
let json_server_url = get_json_server_url();
|
||||
let url = format!("{}/home/homelist.json", json_server_url);
|
||||
|
||||
let client = reqwest::Client::new();
|
||||
let response = client
|
||||
.get(&url)
|
||||
.header("User-Agent", UA)
|
||||
.send()
|
||||
.await
|
||||
.map_err(|e| e.to_string())?;
|
||||
|
||||
let response_text = response
|
||||
.text()
|
||||
.await
|
||||
.map_err(|e| e.to_string())?;
|
||||
|
||||
let lists: Vec<HomeList> = serde_json::from_str(&response_text)
|
||||
.map_err(|e| e.to_string())?;
|
||||
|
||||
Ok(lists)
|
||||
}
|
||||
@@ -17,6 +17,8 @@ pub fn run() {
|
||||
handlers::app::get_app_info,
|
||||
handlers::app::search_all_apps,
|
||||
handlers::home::get_home_links,
|
||||
handlers::home::get_home_lists,
|
||||
handlers::home::get_home_list_apps,
|
||||
utils::get_user_agent,
|
||||
])
|
||||
.run(tauri::generate_context!())
|
||||
|
||||
@@ -1,5 +1,19 @@
|
||||
use serde::{Deserialize, Serialize};
|
||||
|
||||
#[derive(Serialize, Deserialize, Clone, Debug)]
|
||||
pub struct HomeListApp {
|
||||
#[serde(rename = "Name")]
|
||||
pub name: String,
|
||||
#[serde(rename = "Pkgname")]
|
||||
pub pkgname: String,
|
||||
#[serde(rename = "Category")]
|
||||
pub category: String,
|
||||
#[serde(rename = "More")]
|
||||
pub more: String,
|
||||
#[serde(rename = "Icon")]
|
||||
pub icon: Option<String>,
|
||||
}
|
||||
|
||||
#[derive(Serialize, Deserialize, Clone)]
|
||||
pub struct HomeLink {
|
||||
pub name: String,
|
||||
@@ -9,4 +23,13 @@ pub struct HomeLink {
|
||||
#[serde(rename = "type")]
|
||||
pub link_type: String,
|
||||
pub url: String,
|
||||
}
|
||||
|
||||
#[derive(Serialize, Deserialize, Clone)]
|
||||
pub struct HomeList {
|
||||
pub name: String,
|
||||
#[serde(rename = "type")]
|
||||
pub list_type: String,
|
||||
#[serde(rename = "jsonUrl")]
|
||||
pub json_url: String,
|
||||
}
|
||||
Reference in New Issue
Block a user