diff options
author | metamuffin <metamuffin@disroot.org> | 2025-01-30 18:34:09 +0100 |
---|---|---|
committer | metamuffin <metamuffin@disroot.org> | 2025-01-30 18:34:09 +0100 |
commit | 9d6411fd92e73c204425f8dd37dc3cf567f604e4 (patch) | |
tree | d61d3e0b6bcd803e6ccb6d01669d40a1454ec009 /server | |
parent | bfc5552a8eba07897c2ed626b49c085d97fdfa0d (diff) | |
download | jellything-9d6411fd92e73c204425f8dd37dc3cf567f604e4.tar jellything-9d6411fd92e73c204425f8dd37dc3cf567f604e4.tar.bz2 jellything-9d6411fd92e73c204425f8dd37dc3cf567f604e4.tar.zst |
avoid transitive crate deps by re-export
Diffstat (limited to 'server')
-rw-r--r-- | server/src/routes/external_compat.rs | 6 | ||||
-rw-r--r-- | server/src/routes/ui/home.rs | 29 |
2 files changed, 21 insertions, 14 deletions
diff --git a/server/src/routes/external_compat.rs b/server/src/routes/external_compat.rs index 7babfa5..eda3537 100644 --- a/server/src/routes/external_compat.rs +++ b/server/src/routes/external_compat.rs @@ -5,6 +5,7 @@ */ use super::ui::{account::session::Session, error::MyResult}; use crate::routes::ui::node::rocket_uri_macro_r_library_node; +use crate::routes::ui::player::{rocket_uri_macro_r_player, PlayerConfig}; use anyhow::anyhow; use jellybase::database::Database; use rocket::{get, response::Redirect, State}; @@ -18,7 +19,10 @@ pub fn r_ext_youtube_watch(_session: Session, db: &State<Database>, v: &str) -> Err(anyhow!("element not found"))? }; let node = db.get_node(id)?.ok_or(anyhow!("node missing"))?; - Ok(Redirect::to(rocket::uri!(r_library_node(&node.slug)))) + Ok(Redirect::to(rocket::uri!(r_player( + &node.slug, + PlayerConfig::default() + )))) } #[get("/channel/<id>")] diff --git a/server/src/routes/ui/home.rs b/server/src/routes/ui/home.rs index ebed647..6c6fdbc 100644 --- a/server/src/routes/ui/home.rs +++ b/server/src/routes/ui/home.rs @@ -3,14 +3,19 @@ which is licensed under the GNU Affero General Public License (version 3); see /COPYING. Copyright (C) 2025 metamuffin <metamuffin.org> */ -use super::{account::session::Session, layout::LayoutPage, node::NodeCard}; +use super::{ + account::session::Session, + layout::LayoutPage, + node::{DatabaseNodeUserDataExt, NodeCard}, +}; use crate::{ database::Database, routes::ui::{error::MyResult, layout::DynLayoutPage}, }; +use anyhow::Context; use chrono::{Datelike, Utc}; use jellybase::CONF; -use jellycommon::{user::WatchedState, Rating}; +use jellycommon::{user::WatchedState, NodeID, Rating}; use rocket::{get, State}; use tokio::fs::read_to_string; @@ -21,14 +26,12 @@ pub fn r_home(sess: Session, db: &State<Database>) -> MyResult<DynLayoutPage> { .flat_map(|i| Some(items[cheap_daily_random(i).checked_rem(items.len())?].clone())) .collect::<Vec<_>>(); - // let toplevel = T_NODE - // .get(db, "library")? - // .context("root node missing")? - // .into_iter() - // .map(|n| db.get_node_with_userdata(&n, &sess)) - // .collect::<anyhow::Result<Vec<_>>>()? - // .into_iter() - // .collect::<Vec<_>>(); + let toplevel = db + .get_node_children(NodeID::from_slug("library")) + .context("root node missing")? + .into_iter() + .map(|n| db.get_node_with_userdata(n, &sess)) + .collect::<anyhow::Result<Vec<_>>>()?; items.sort_by_key(|(n, _)| { n.ratings @@ -68,9 +71,9 @@ pub fn r_home(sess: Session, db: &State<Database>) -> MyResult<DynLayoutPage> { title: "Home".to_string(), content: markup::new! { h2 { "Explore " @CONF.brand } - // ul.children.hlist {@for (id, node, udata) in &toplevel { - // li { @NodeCard { id, node, udata } } - // }} + ul.children.hlist {@for (node, udata) in &toplevel { + li { @NodeCard { node, udata } } + }} @if !continue_watching.is_empty() { h2 { "Continue Watching" } ul.children.hlist {@for (node, udata) in &continue_watching { |