fix(web): followers/following load again
This commit is contained in:
parent
2f19d6800d
commit
2d1ae0f425
1 changed files with 10 additions and 50 deletions
|
@ -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 id = params.get().ok().and_then(|x| x.id).unwrap_or_default();
|
||||||
let resource = LocalResource::new(
|
|
||||||
move || {
|
|
||||||
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>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue