add: block list stacks
This commit is contained in:
parent
9bb5f38f76
commit
b71ae1f5a4
28 changed files with 700 additions and 219 deletions
|
@ -4,7 +4,12 @@ use axum::{
|
|||
Extension,
|
||||
};
|
||||
use axum_extra::extract::CookieJar;
|
||||
use tetratto_core::model::{permissions::FinePermission, stacks::StackPrivacy, Error, auth::User};
|
||||
use tetratto_core::model::{
|
||||
auth::User,
|
||||
permissions::FinePermission,
|
||||
stacks::{StackMode, StackPrivacy},
|
||||
Error,
|
||||
};
|
||||
use crate::{assets::initial_context, get_lang, get_user_from_token, State};
|
||||
use super::{render_error, PaginatedQuery};
|
||||
|
||||
|
@ -35,7 +40,7 @@ pub async fn list_request(jar: CookieJar, Extension(data): Extension<State>) ->
|
|||
}
|
||||
|
||||
/// `/stacks/{id}`
|
||||
pub async fn posts_request(
|
||||
pub async fn feed_request(
|
||||
jar: CookieJar,
|
||||
Extension(data): Extension<State>,
|
||||
Path(id): Path<usize>,
|
||||
|
@ -65,32 +70,50 @@ pub async fn posts_request(
|
|||
));
|
||||
}
|
||||
|
||||
let ignore_users = crate::ignore_users_gen!(user!, data);
|
||||
let list = match data
|
||||
.0
|
||||
.get_stack_posts(
|
||||
user.id,
|
||||
stack.id,
|
||||
12,
|
||||
req.page,
|
||||
&ignore_users,
|
||||
&Some(user.clone()),
|
||||
)
|
||||
.await
|
||||
{
|
||||
Ok(l) => l,
|
||||
Err(e) => return Err(Html(render_error(e, &jar, &data, &Some(user)).await)),
|
||||
};
|
||||
|
||||
let lang = get_lang!(jar, data.0);
|
||||
let mut context = initial_context(&data.0.0.0, lang, &Some(user)).await;
|
||||
let mut context = initial_context(&data.0.0.0, lang, &Some(user.clone())).await;
|
||||
|
||||
context.insert("page", &req.page);
|
||||
context.insert("stack", &stack);
|
||||
context.insert("list", &list);
|
||||
|
||||
if stack.mode == StackMode::BlockList {
|
||||
let list = match data.0.get_stack_users(stack.id, 12, req.page).await {
|
||||
Ok(l) => l,
|
||||
Err(e) => return Err(Html(render_error(e, &jar, &data, &Some(user)).await)),
|
||||
};
|
||||
|
||||
context.insert("list", &list);
|
||||
context.insert(
|
||||
"is_blocked",
|
||||
&data
|
||||
.0
|
||||
.get_stackblock_by_initiator_stack(user.id, stack.id)
|
||||
.await
|
||||
.is_ok(),
|
||||
);
|
||||
} else {
|
||||
let ignore_users = crate::ignore_users_gen!(user!, data);
|
||||
let list = match data
|
||||
.0
|
||||
.get_stack_posts(
|
||||
user.id,
|
||||
stack.id,
|
||||
12,
|
||||
req.page,
|
||||
&ignore_users,
|
||||
&Some(user.clone()),
|
||||
)
|
||||
.await
|
||||
{
|
||||
Ok(l) => l,
|
||||
Err(e) => return Err(Html(render_error(e, &jar, &data, &Some(user)).await)),
|
||||
};
|
||||
|
||||
context.insert("list", &list);
|
||||
}
|
||||
|
||||
// return
|
||||
Ok(Html(data.1.render("stacks/posts.html", &context).unwrap()))
|
||||
Ok(Html(data.1.render("stacks/feed.html", &context).unwrap()))
|
||||
}
|
||||
|
||||
/// `/stacks/{id}/manage`
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue