Plume/templates/base.rs.html

107 lines
5.5 KiB
HTML
Raw Permalink Normal View History

@use plume_models::CONFIG;
@use plume_models::instance::Instance;
@use std::path::Path;
2020-01-21 07:02:03 +01:00
@use crate::template_utils::*;
@use crate::routes::*;
@(ctx: BaseContext, title: String, head: Content, header: Content, content: Content)
2018-09-09 22:41:55 +02:00
2018-05-09 19:53:12 +02:00
<!DOCTYPE html>
<html class="@ctx.2.clone().and_then(|u| u.preferred_theme).unwrap_or_else(|| CONFIG.default_theme.clone())">
2018-05-09 19:53:12 +02:00
<head>
<meta charset="utf-8" />
<title>@title ⋅ @i18n!(ctx.1, "Plume")</title>
2018-09-03 15:59:02 +02:00
<meta name="viewport" content="width=device-width, initial-scale=1" />
<link rel="stylesheet" href="@uri!(plume_static_files: file = Path::new("css").join(ctx.2.clone().and_then(|u| u.preferred_theme).unwrap_or_else(|| CONFIG.default_theme.clone())).join("theme.css"), build_id = CACHE_NAME)" />
<link rel="manifest" href="@uri!(instance::web_manifest)" />
<link rel="icon" type="image/png" href="@uri!(plume_static_files: file = CONFIG.logo.favicon.as_str(), build_id = CACHE_NAME)">
<meta content='#282c37' name='theme-color'/>
@:head()
2018-05-09 19:53:12 +02:00
</head>
<body>
2018-05-10 22:31:52 +02:00
<header>
2018-09-01 16:11:42 +02:00
<nav id="menu">
2021-02-12 10:54:42 +01:00
<a href="#" aria-label="@i18n!(ctx.1, "Menu")" title="@i18n!(ctx.1, "Menu")" role="button" aria-haspopup="true" aria-controls="content" aria-epanded="false"><i class="icon icon-menu"></i></a>
2018-05-10 22:31:52 +02:00
</nav>
2021-02-12 10:54:42 +01:00
<div id="content" role="menu" aria-labelled-by="menu">
2018-09-01 16:11:42 +02:00
<nav>
<a href="@uri!(instance::index)" class="title">
<img src="@uri!(plume_static_files: file = CONFIG.logo.main.as_str(), build_id = CACHE_NAME)">
<p>@i18n!(ctx.1, "Plume")</p>
2018-10-09 16:37:40 +02:00
</a>
2018-09-01 16:11:42 +02:00
<hr/>
@:header()
2018-09-01 16:11:42 +02:00
</nav>
<nav>
@if ctx.2.is_some() {
2019-01-28 13:12:56 +01:00
<a href="@uri!(search::search: _)">
<i class="icon icon-search"></i>
<span class="mobile-label">@i18n!(ctx.1, "Search")</span>
</a>
<a href="@uri!(user::dashboard)">
<i class="icon icon-home" aria-label="@i18n!(ctx.1, "Dashboard")"></i>
<span class="mobile-label">@i18n!(ctx.1, "Dashboard")</span>
2018-09-03 15:59:02 +02:00
</a>
<a href="@uri!(notifications::notifications: page = _)">
<i class="icon icon-bell" aria-label="@i18n!(ctx.1, "Notifications")"></i>
<span class="mobile-label">@i18n!(ctx.1, "Notifications")</span>
2018-09-03 15:59:02 +02:00
</a>
<a href="@uri!(session::delete)">
<i class="icon icon-log-out" aria-label="@i18n!(ctx.1, "Log Out")"></i>
<span class="mobile-label">@i18n!(ctx.1, "Log Out")</span>
2018-09-03 15:59:02 +02:00
</a>
<a href="@uri!(user::me)" title="@i18n!(ctx.1, "My account")">
2022-02-08 08:47:48 +01:00
@avatar(ctx.0, &ctx.2.clone().unwrap(), Size::Small, false, ctx.1)
<span class="mobile-label">@i18n!(ctx.1, "My account")</span>
2018-09-03 15:59:02 +02:00
</a>
} else {
2019-01-28 13:12:56 +01:00
<a href="@uri!(search::search: _)">
<i class="icon icon-search"></i>
<span class="mobile-label">@i18n!(ctx.1, "Search")</span>
</a>
<a href="@uri!(session::new: m = _)">
<i class="icon icon-log-in"></i>
<span class="mobile-label">@i18n!(ctx.1, "Log In")</span>
</a>
<a href="@uri!(user::new)">
<i class="icon icon-user-plus"></i>
<span class="mobile-label">@i18n!(ctx.1, "Register")</span>
</a>
}
2018-09-01 16:11:42 +02:00
</nav>
</div>
2018-05-10 22:31:52 +02:00
</header>
<div class="messages">
@if let Some(ref message) = ctx.3 {
<p class="flash-message @message.0">@message.1</p>
}
</div>
2018-05-10 22:31:52 +02:00
<main>
@:content()
2018-05-10 22:31:52 +02:00
</main>
2018-07-27 14:08:39 +02:00
<footer>
<hr/>
<div>
<h3>@Instance::get_local().map(|i| i.name).unwrap_or_default()</h3>
<a href="@uri!(instance::about)">@i18n!(ctx.1, "About this instance")</a>
<a href="@uri!(instance::privacy)">@i18n!(ctx.1, "Privacy policy")</a>
@if ctx.2.clone().map(|u| u.is_admin()).unwrap_or(false) {
<a href="@uri!(instance::admin)">@i18n!(ctx.1, "Administration")</a>
2024-08-16 08:02:28 +02:00
} else if ctx.2.clone().map(|u| u.is_moderator()).unwrap_or(false) {
<a href="@uri!(instance::admin_mod)">@i18n!(ctx.1, "Moderation")</a>
}
</div>
<div>
<h3>@concat!("Plume ", env!("CARGO_PKG_VERSION"))</h3>
<a href="https://docs.joinplu.me">@i18n!(ctx.1, "Documentation")</a>
<a href="https://github.com/Plume-org/Plume">@i18n!(ctx.1, "Source code")</a>
2020-12-26 13:48:39 +01:00
<a href="https://matrix.to/#/#plume-blog:matrix.org">@i18n!(ctx.1, "Matrix room")</a>
</div>
2018-07-27 14:08:39 +02:00
</footer>
2021-02-10 15:50:41 +01:00
<script type="module">
import init from '@uri!(plume_static_files: file = "plume_front.js", build_id = CACHE_NAME)';
(async () => await init())();
</script>
2018-05-09 19:53:12 +02:00
</body>
</html>