aboutsummaryrefslogtreecommitdiff
path: root/ui/src/scaffold.rs
blob: bcff54ca755fcf18dbff666aa4901542420d0ee7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/*
    This file is part of jellything (https://codeberg.org/metamuffin/jellything)
    which is licensed under the GNU Affero General Public License (version 3); see /COPYING.
    Copyright (C) 2025 metamuffin <metamuffin.org>
*/

use crate::locale::{Language, escape, tr, trs};
use jellycommon::routes::{
    u_account_login, u_account_logout, u_account_register, u_account_settings, u_admin_dashboard,
    u_home, u_items, u_node_slug, u_search, u_stats,
};
use markup::{Render, raw};
use std::sync::LazyLock;

static LOGO_ENABLED: LazyLock<bool> = LazyLock::new(|| CONF.asset_path.join("logo.svg").exists());

markup::define! {
    Scaffold<'a, Main: Render>(title: String, main: Main, class: &'a str, session: Option<Session>, lang: Language) {
        @markup::doctype()
        html {
            head {
                title { @title " - " @CONF.brand }
                meta[name="viewport", content="width=device-width, initial-scale=1.0"];
                link[rel="stylesheet", href="/assets/style.css"];
                script[src="/assets/bundle.js"] {}
            }
            body[class=class] {
                nav {
                    h1 { a[href=if session.is_some() {u_home()} else {"/".to_string()}] { @if *LOGO_ENABLED { img.logo[src="/assets/logo.svg"]; } else { @CONF.brand } } } " "
                    @if let Some(_) = session {
                        a.library[href=u_node_slug("library")] { @trs(lang, "nav.root") } " "
                        a.library[href=u_items()] { @trs(lang, "nav.all") } " "
                        a.library[href=u_search()] { @trs(lang, "nav.search") } " "
                        a.library[href=u_stats()] { @trs(lang, "nav.stats") } " "
                    }
                    @if is_importing() { span.warn { "Library database is updating..." } }
                    div.account {
                        @if let Some(session) = session {
                            span { @raw(tr(*lang, "nav.username").replace("{name}", &format!("<b class=\"username\">{}</b>", escape(&session.user.display_name)))) } " "
                            @if session.user.admin {
                                a.admin.hybrid_button[href=u_admin_dashboard()] { p {@trs(lang, "nav.admin")} } " "
                            }
                            a.settings.hybrid_button[href=u_account_settings()] { p {@trs(lang, "nav.settings")} } " "
                            a.logout.hybrid_button[href=u_account_logout()] { p {@trs(lang, "nav.logout")} }
                        } else {
                            a.register.hybrid_button[href=u_account_register()] { p {@trs(lang, "nav.register")} } " "
                            a.login.hybrid_button[href=u_account_login()] { p {@trs(lang, "nav.login")} }
                        }
                    }
                }
                #main { @main }
                footer {
                    p { @CONF.brand " - " @CONF.slogan " | powered by " a[href="https://codeberg.org/metamuffin/jellything"]{"Jellything"} }
                }
            }
        }
    }

    FlashDisplay(flash: Option<Result<String, String>>) {
        @if let Some(flash) = &flash {
            @match flash {
                Ok(mesg) => { section.message { p.success { @mesg } } }
                Err(err) => { section.message { p.error { @err } } }
            }
        }
    }
}