Add a compile-time i18n system with 270 translation keys across 5 locales (EN, DE, FR, ES, PT). Translations are embedded via include_str! and parsed lazily into flat HashMaps with English fallback for missing keys. - Add src/i18n module with Locale enum, t()/tw() lookup functions, and tests - Add JSON translation files for all 5 locales under assets/i18n/ - Provide locale Signal via Dioxus context in App, persisted to localStorage - Replace all hardcoded UI strings across 33 component/page files - Add compact locale picker (globe icon + ISO alpha-2 code) in sidebar header - Add click-outside backdrop dismissal for locale dropdown Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> Co-authored-by: Sharang Parnerkar <parnerkarsharang@gmail.com> Reviewed-on: #12
45 lines
1.1 KiB
Rust
45 lines
1.1 KiB
Rust
use crate::app::Route;
|
|
use dioxus::prelude::*;
|
|
|
|
/// A single tab item for the sub-navigation bar.
|
|
///
|
|
/// # Fields
|
|
///
|
|
/// * `label` - Display text for the tab
|
|
/// * `route` - Route to navigate to when clicked
|
|
#[derive(Clone, PartialEq)]
|
|
pub struct SubNavItem {
|
|
pub label: String,
|
|
pub route: Route,
|
|
}
|
|
|
|
/// Horizontal tab navigation bar used inside nested shell layouts.
|
|
///
|
|
/// Highlights the active tab based on the current route.
|
|
///
|
|
/// # Arguments
|
|
///
|
|
/// * `items` - List of tab items to render
|
|
#[component]
|
|
pub fn SubNav(items: Vec<SubNavItem>) -> Element {
|
|
let current_route = use_route::<Route>();
|
|
|
|
rsx! {
|
|
nav { class: "sub-nav",
|
|
for item in &items {
|
|
{
|
|
let is_active = item.route == current_route;
|
|
let class = if is_active {
|
|
"sub-nav-item sub-nav-item--active"
|
|
} else {
|
|
"sub-nav-item"
|
|
};
|
|
rsx! {
|
|
Link { class: "{class}", to: item.route.clone(), "{item.label}" }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|