80a4dae8bd
- Use `Result` as much as possible - Display errors instead of panicking TODO (maybe in another PR? this one is already quite big): - Find a way to merge Ructe/ErrorPage types, so that we can have routes returning `Result<X, ErrorPage>` instead of panicking when we have an `Error` - Display more details about the error, to make it easier to debug (sorry, this isn't going to be fun to review, the diff is huge, but it is always the same changes)
39 lines
1.3 KiB
HTML
39 lines
1.3 KiB
HTML
@use plume_models::medias::{Media, MediaCategory};
|
|
@use plume_models::safe_string::SafeString;
|
|
@use templates::base;
|
|
@use template_utils::*;
|
|
@use routes::*;
|
|
|
|
@(ctx: BaseContext, media: Media)
|
|
|
|
@:base(ctx, "Media details", {}, {}, {
|
|
<h1>@i18n!(ctx.1, "Media details")</h1>
|
|
<section>
|
|
<a href="@uri!(medias::list)">@i18n!(ctx.1, "Go back to the gallery")</a>
|
|
</section>
|
|
|
|
<section>
|
|
<figure class="media">
|
|
@Html(media.html(ctx.0).unwrap_or(SafeString::new("")))
|
|
<figcaption>@media.alt_text</figcaption>
|
|
</figure>
|
|
<div>
|
|
<p>
|
|
@i18n!(ctx.1, "Markdown syntax")
|
|
<small>@i18n!(ctx.1, "Copy it into your articles, to insert this media:")</small>
|
|
</p>
|
|
<code>@media.markdown(ctx.0).unwrap_or(SafeString::new(""))</code>
|
|
</div>
|
|
<div>
|
|
@if media.category() == MediaCategory::Image {
|
|
<form class="inline" method="post" action="@uri!(medias::set_avatar: id = media.id)">
|
|
<input class="button" type="submit" value="@i18n!(ctx.1, "Use as avatar")">
|
|
</form>
|
|
}
|
|
<form class="inline" method="post" action="@uri!(medias::delete: id = media.id)">
|
|
<input class="button" type="submit" value="@i18n!(ctx.1, "Delete")">
|
|
</form>
|
|
</div>
|
|
</section>
|
|
})
|