70af57c6e1
All the template are now compiled at compile-time with the `ructe` crate. I preferred to use it instead of askama because it allows more complex Rust expressions, where askama only supports a small subset of expressions and doesn't allow them everywhere (for instance, `{{ macro!() | filter }}` would result in a parsing error). The diff is quite huge, but there is normally no changes in functionality. Fixes #161 and unblocks #110 and #273
28 lines
815 B
HTML
28 lines
815 B
HTML
@use templates::{base, partials::post_card};
|
|
@use template_utils::*;
|
|
@use plume_models::posts::Post;
|
|
|
|
@(ctx: BaseContext, articles: Vec<Post>, page: i32, n_pages: i32)
|
|
|
|
@:base(ctx, "Your feed", {}, {}, {
|
|
<h1>@i18n!(ctx.1, "Your feed")</h1>
|
|
|
|
@tabs(&[
|
|
("/", i18n!(ctx.1, "Latest articles"), false),
|
|
("/feed", i18n!(ctx.1, "Your feed"), true),
|
|
("/federated", i18n!(ctx.1, "Federated feed"), false),
|
|
("/local", i18n!(ctx.1, "Local feed"), false),
|
|
])
|
|
|
|
@if !articles.is_empty() {
|
|
<div class="cards">
|
|
@for article in articles {
|
|
@:post_card(ctx, article)
|
|
}
|
|
</div>
|
|
} else {
|
|
<p class="center">@i18n!(ctx.1, "Nothing to see here yet. Try to follow more people.")</p>
|
|
}
|
|
@paginate(ctx.1, page, n_pages)
|
|
})
|