All checks were successful
CI / Clippy (push) Successful in 2m17s
CI / Security Audit (push) Successful in 1m38s
CI / Format (pull_request) Successful in 6m28s
CI / Tests (push) Successful in 2m51s
CI / Format (push) Successful in 6m17s
CI / Clippy (pull_request) Successful in 2m15s
CI / Security Audit (pull_request) Successful in 1m42s
CI / Tests (pull_request) Successful in 2m48s
CI / Deploy (push) Has been skipped
CI / Deploy (pull_request) Has been skipped
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: &'static str,
|
|
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}" }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|