fix(web): followers/following load again

This commit is contained in:
əlemi 2025-01-19 02:59:02 +01:00
parent 2f19d6800d
commit 2d1ae0f425
Signed by: alemi
GPG key ID: A4895B84D311642C

View file

@ -1,61 +1,21 @@
use leptos::prelude::*; use leptos::prelude::*;
use leptos_router::hooks::use_params; use leptos_router::hooks::use_params;
use crate::prelude::*; use crate::{prelude::*, timeline::any::Loadable};
use std::sync::Arc;
use apb::Collection;
#[component] #[component]
pub fn FollowList(outgoing: bool) -> impl IntoView { pub fn FollowList(outgoing: bool) -> impl IntoView {
let follow___ = if outgoing { "following" } else { "followers" }; let follow___ = if outgoing { "following" } else { "followers" };
let params = use_params::<IdParam>(); let params = use_params::<IdParam>();
let auth = use_context::<Auth>().expect("missing auth context");
let resource = LocalResource::new(
move || {
let id = params.get().ok().and_then(|x| x.id).unwrap_or_default(); let id = params.get().ok().and_then(|x| x.id).unwrap_or_default();
async move {
Ok::<_, String>(
Http::fetch::<serde_json::Value>(&format!("{URL_BASE}/actors/{id}/{follow___}/page"), auth)
.await
.map_err(|e| e.to_string())?
.ordered_items()
.all_ids()
)
}
}
);
view! { view! {
<div class="tl ml-3-r mr-3-r pl-1 pt-1 pb-1"> <div class="container">
{move || match resource.get().map(|x| x.take()) { <Loadable
None => view! { <Loader /> }.into_any(), base=format!("{URL_BASE}/actors/{id}/{follow___}/page")
Some(Err(e)) => { convert=U::Actor
tracing::error!("could not load followers: {e}"); element=|obj| view! { <ActorBanner object=obj /><hr/> }
view! { <code class="cw center color">{follow___}" unavailable"</code> }.into_any() >
}, ""
Some(Ok(mut arr)) => { </Loadable>
// TODO cheap fix: server gives us follows from oldest to newest
// but it's way more convenient to have them other way around
// so we reverse them just after loading them
arr.reverse();
view! {
<For
each=move || arr.clone()
key=|id| id.clone()
children=move |id| {
let actor = match cache::OBJECTS.get(&id) {
Some(x) => x,
None => Arc::new(serde_json::Value::String(id)),
};
view! {
<ActorBanner object=actor />
<hr />
}.into_any()
}
/ >
}.into_any()
},
}}
</div> </div>
} }
} }