add language

This commit is contained in:
2025-08-03 10:23:42 +02:00
parent d97a6f6760
commit d0b4247ed1
3 changed files with 139 additions and 121 deletions

View File

@@ -1,6 +1,7 @@
use crate::{page::new, Backend}; use crate::{language::language, page::new, Backend};
use axum::{ use axum::{
extract::{Path, State}, extract::{Path, State},
http::HeaderMap,
response::{IntoResponse, Redirect, Response}, response::{IntoResponse, Redirect, Response},
routing::get, routing::get,
Router, Router,
@@ -10,14 +11,20 @@ use maud::{html, Markup, PreEscaped};
use std::sync::Arc; use std::sync::Arc;
use uuid::Uuid; use uuid::Uuid;
async fn index(State(backend): State<Arc<Backend>>, cookies: CookieJar) -> Response { async fn index(
let (cookies, client) = backend.client(cookies).await; State(backend): State<Arc<Backend>>,
cookies: CookieJar,
headers: HeaderMap,
) -> Response {
let (cookies, req) = backend.client_full(cookies, &headers).await;
let client = req.client;
let sightings = backend.sightings_for_client(&client).await; let sightings = backend.sightings_for_client(&client).await;
let amount_total_cameras = backend.amount_total_cameras().await; let amount_total_cameras = backend.amount_total_cameras().await;
let highscore = backend.highscore().await; let highscore = backend.highscore().await;
let markup = new(html! { let markup = new(
html! {
hgroup { hgroup {
h1 { "Who finds the most cameras?" } h1 { "Who finds the most cameras?" }
} }
@@ -80,7 +87,9 @@ async fn index(State(backend): State<Arc<Backend>>, cookies: CookieJar) -> Respo
} }
} }
} }
}); },
req.lang,
);
(cookies, markup).into_response() (cookies, markup).into_response()
} }
@@ -88,16 +97,17 @@ async fn index(State(backend): State<Arc<Backend>>, cookies: CookieJar) -> Respo
async fn game( async fn game(
State(backend): State<Arc<Backend>>, State(backend): State<Arc<Backend>>,
cookies: CookieJar, cookies: CookieJar,
headers: HeaderMap,
Path(uuid): Path<String>, Path(uuid): Path<String>,
) -> Result<Redirect, Response> { ) -> Result<Redirect, Response> {
let (cookies, client) = backend.client(cookies).await; let (cookies, client) = backend.client(cookies).await;
let Ok(uuid) = Uuid::parse_str(&uuid) else { let Ok(uuid) = Uuid::parse_str(&uuid) else {
return Err(not_found().await.into_response()); return Err(not_found(cookies, headers).await.into_response());
}; };
let Some(camera) = backend.get_camera(&uuid).await else { let Some(camera) = backend.get_camera(&uuid).await else {
return Err(not_found().await.into_response()); return Err(not_found(cookies, headers).await.into_response());
}; };
let succ = backend.client_found_camera(&client, &camera).await; let succ = backend.client_found_camera(&client, &camera).await;
@@ -106,10 +116,14 @@ async fn game(
Ok(Redirect::to("/game")) Ok(Redirect::to("/game"))
} }
async fn not_found() -> Markup { async fn not_found(cookies: CookieJar, headers: HeaderMap) -> Markup {
new(html! { let lang = language(&cookies, &headers);
new(
html! {
h1 { "uups" } h1 { "uups" }
}) },
lang,
)
} }
pub(super) fn routes() -> Router<Arc<Backend>> { pub(super) fn routes() -> Router<Arc<Backend>> {

View File

@@ -8,7 +8,8 @@ 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(html! { new(
html! {
h1 { (t!("digital_shadows")) } h1 { (t!("digital_shadows")) }
hgroup { hgroup {
h2 { h2 {
@@ -72,5 +73,7 @@ pub(super) async fn index(cookies: CookieJar, headers: HeaderMap) -> Markup {
} }
} }
} }
}) },
lang,
)
} }

View File

@@ -1,8 +1,9 @@
use crate::Language;
use maud::{html, Markup, DOCTYPE}; use maud::{html, Markup, DOCTYPE};
// TODO: set dynamic meta lang attribute // TODO: set dynamic meta lang attribute
pub fn new(content: Markup) -> Markup { pub fn new(content: Markup, lang: Language) -> Markup {
html! { html! {
(DOCTYPE) (DOCTYPE)
head { head {