Compare commits
2 Commits
ee4972b25c
...
2affa210e1
Author | SHA1 | Date | |
---|---|---|---|
2affa210e1 | |||
e77e5632d3 |
11
src/index.rs
11
src/index.rs
@@ -1,4 +1,4 @@
|
|||||||
use crate::{language::language, page::new};
|
use crate::{language::language, page::Page};
|
||||||
use axum::http::HeaderMap;
|
use axum::http::HeaderMap;
|
||||||
use axum_extra::extract::CookieJar;
|
use axum_extra::extract::CookieJar;
|
||||||
use maud::{html, Markup};
|
use maud::{html, Markup};
|
||||||
@@ -8,7 +8,11 @@ pub(super) async fn index(cookies: CookieJar, headers: HeaderMap) -> Markup {
|
|||||||
|
|
||||||
rust_i18n::set_locale(lang.to_locale());
|
rust_i18n::set_locale(lang.to_locale());
|
||||||
|
|
||||||
new(
|
let mut page = Page::new(lang);
|
||||||
|
page.succ("Yeah! That worked!".into());
|
||||||
|
page.err("Damn...".into());
|
||||||
|
|
||||||
|
page.content(
|
||||||
html! {
|
html! {
|
||||||
h1 { (t!("digital_shadows")) }
|
h1 { (t!("digital_shadows")) }
|
||||||
hgroup {
|
hgroup {
|
||||||
@@ -73,7 +77,6 @@ pub(super) async fn index(cookies: CookieJar, headers: HeaderMap) -> Markup {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
}
|
||||||
lang,
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
54
src/page.rs
54
src/page.rs
@@ -3,10 +3,43 @@ use maud::{html, Markup, DOCTYPE};
|
|||||||
|
|
||||||
// TODO: set dynamic meta lang attribute
|
// TODO: set dynamic meta lang attribute
|
||||||
|
|
||||||
|
// TODO: remove function
|
||||||
pub fn new(content: Markup, lang: Language) -> Markup {
|
pub fn new(content: Markup, lang: Language) -> Markup {
|
||||||
|
let page = Page::new(lang);
|
||||||
|
page.content(content)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub(crate) struct Page {
|
||||||
|
lang: Language,
|
||||||
|
succ: Option<String>,
|
||||||
|
err: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Page {
|
||||||
|
pub fn new(lang: Language) -> Self {
|
||||||
|
Self {
|
||||||
|
lang,
|
||||||
|
succ: None,
|
||||||
|
err: None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn succ(&mut self, msg: String) {
|
||||||
|
self.succ = Some(msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn err(&mut self, msg: String) {
|
||||||
|
self.err = Some(msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn has_msg(&self) -> bool {
|
||||||
|
self.succ.is_some() || self.err.is_some()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn content(self, content: Markup) -> Markup {
|
||||||
html! {
|
html! {
|
||||||
(DOCTYPE)
|
(DOCTYPE)
|
||||||
html lang=(lang) {
|
html lang=(self.lang) {
|
||||||
head {
|
head {
|
||||||
meta charset="utf-8";
|
meta charset="utf-8";
|
||||||
meta name="viewport" content="width=device-width, initial-scale=1.0";
|
meta name="viewport" content="width=device-width, initial-scale=1.0";
|
||||||
@@ -40,8 +73,8 @@ pub fn new(content: Markup, lang: Language) -> Markup {
|
|||||||
}
|
}
|
||||||
|
|
||||||
li {
|
li {
|
||||||
button id="lang-toggle" lang=(lang.next_language()) {
|
button id="lang-toggle" lang=(self.lang.next_language()) {
|
||||||
(lang.next_language())
|
(self.lang.next_language())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -49,6 +82,20 @@ pub fn new(content: Markup, lang: Language) -> Markup {
|
|||||||
}
|
}
|
||||||
|
|
||||||
main.container {
|
main.container {
|
||||||
|
@if self.has_msg() {
|
||||||
|
section {
|
||||||
|
@if let Some(succ) = self.succ {
|
||||||
|
p class="succ" {
|
||||||
|
(succ)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@if let Some(err) = self.err{
|
||||||
|
p class="err" {
|
||||||
|
(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
section { (content) }
|
section { (content) }
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -66,3 +113,4 @@ pub fn new(content: Markup, lang: Language) -> Markup {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user