mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-12-04 01:49:11 +00:00
73 lines
1.2 KiB
Rust
73 lines
1.2 KiB
Rust
use dioxus::prelude::*;
|
|
use dioxus::router::prelude::*;
|
|
|
|
fn main() {
|
|
launch(|| {
|
|
rsx! {
|
|
Router::<Route> {}
|
|
}
|
|
})
|
|
}
|
|
|
|
#[derive(Routable, Clone)]
|
|
#[rustfmt::skip]
|
|
enum Route {
|
|
#[layout(Footer)]
|
|
#[route("/")]
|
|
Home {},
|
|
|
|
#[route("/games")]
|
|
Games {},
|
|
|
|
#[route("/play")]
|
|
Play {},
|
|
|
|
#[route("/settings")]
|
|
Settings {},
|
|
}
|
|
|
|
#[component]
|
|
fn Footer() -> Element {
|
|
rsx! {
|
|
Outlet::<Route> {}
|
|
p { "----" }
|
|
nav {
|
|
style { {STYLE} }
|
|
Link { to: Route::Home {}, class: "nav-btn", "Home" }
|
|
Link { to: Route::Games {}, class: "nav-btn", "Games" }
|
|
Link { to: Route::Play {}, class: "nav-btn", "Play" }
|
|
Link { to: Route::Settings {}, class: "nav-btn", "Settings" }
|
|
}
|
|
}
|
|
}
|
|
|
|
#[component]
|
|
fn Home() -> Element {
|
|
rsx!("Home")
|
|
}
|
|
|
|
#[component]
|
|
fn Games() -> Element {
|
|
rsx!("Games")
|
|
}
|
|
|
|
#[component]
|
|
fn Play() -> Element {
|
|
rsx!("Play")
|
|
}
|
|
|
|
#[component]
|
|
fn Settings() -> Element {
|
|
rsx!("Settings")
|
|
}
|
|
|
|
const STYLE: &str = r#"
|
|
nav {
|
|
display: flex;
|
|
justify-content: space-around;
|
|
}
|
|
.nav-btn {
|
|
text-decoration: none;
|
|
color: black;
|
|
}
|
|
"#;
|