dioxus/packages/router/examples/simple_routes.rs

153 lines
4.2 KiB
Rust
Raw Normal View History

2022-12-09 00:15:04 +00:00
#![allow(non_snake_case)]
use dioxus::prelude::*;
2023-05-24 00:09:24 +00:00
use dioxus_router::prelude::*;
use std::str::FromStr;
2022-12-09 00:15:04 +00:00
fn main() {
2023-05-24 00:09:24 +00:00
#[cfg(not(target_arch = "wasm32"))]
dioxus_desktop::launch(root);
2022-12-09 00:15:04 +00:00
2023-05-24 00:09:24 +00:00
#[cfg(target_arch = "wasm32")]
dioxus_web::launch(root);
}
2022-12-15 19:09:53 +00:00
2023-05-24 00:09:24 +00:00
fn root(cx: Scope) -> Element {
render! {
2023-06-01 18:13:50 +00:00
Router {}
2023-05-24 00:09:24 +00:00
}
}
2022-12-09 00:15:04 +00:00
2023-05-24 00:09:24 +00:00
#[inline_props]
fn UserFrame(cx: Scope, user_id: usize) -> Element {
2022-12-09 00:15:04 +00:00
render! {
2023-05-24 00:09:24 +00:00
pre {
"UserFrame{{\n\tuser_id:{user_id}\n}}"
}
div {
background_color: "rgba(0,0,0,50%)",
"children:"
Outlet {}
2022-12-09 03:11:31 +00:00
}
2022-12-09 00:15:04 +00:00
}
}
2023-05-24 00:09:24 +00:00
#[inline_props]
2023-05-31 17:11:11 +00:00
fn Route1(cx: Scope, user_id: usize, dynamic: usize, query: String, extra: String) -> Element {
2022-12-09 00:15:04 +00:00
render! {
2023-05-24 00:09:24 +00:00
pre {
2023-05-31 17:11:11 +00:00
"Route1{{\n\tuser_id:{user_id},\n\tdynamic:{dynamic},\n\tquery:{query},\n\textra:{extra}\n}}"
2023-05-24 00:09:24 +00:00
}
Link {
2023-05-31 17:11:11 +00:00
target: Route::Route1 { user_id: *user_id, dynamic: *dynamic, query: String::new(), extra: extra.clone() + "." },
2023-05-24 00:09:24 +00:00
"Route1 with extra+\".\""
}
p { "Footer" }
Link {
2023-05-24 00:09:24 +00:00
target: Route::Route3 { dynamic: String::new() },
"Home"
2022-12-09 03:11:31 +00:00
}
}
}
2023-05-24 00:09:24 +00:00
#[inline_props]
fn Route2(cx: Scope, user_id: usize) -> Element {
2022-12-09 03:11:31 +00:00
render! {
2023-05-24 00:09:24 +00:00
pre {
"Route2{{\n\tuser_id:{user_id}\n}}"
}
(0..*user_id).map(|i| rsx!{ p { "{i}" } }),
p { "Footer" }
Link {
2023-05-24 00:09:24 +00:00
target: Route::Route3 { dynamic: String::new() },
"Home"
2022-12-09 03:11:31 +00:00
}
2022-12-09 00:15:04 +00:00
}
}
2023-05-24 00:09:24 +00:00
#[inline_props]
fn Route3(cx: Scope, dynamic: String) -> Element {
2023-06-01 14:45:31 +00:00
let navigator = use_navigator(cx);
let current_route = use_route(cx)?;
let current_route_str = use_ref(cx, String::new);
let parsed = Route::from_str(&current_route_str.read());
2023-05-24 00:09:24 +00:00
let site_map = Route::SITE_MAP
.iter()
.flat_map(|seg| seg.flatten().into_iter())
.collect::<Vec<_>>();
render! {
2023-05-24 00:09:24 +00:00
input {
oninput: move |evt| {
2023-06-01 14:45:31 +00:00
*current_route_str.write() = evt.value.clone();
2023-05-24 00:09:24 +00:00
},
2023-06-01 14:45:31 +00:00
value: "{current_route_str.read()}"
2023-05-24 00:09:24 +00:00
}
"dynamic: {dynamic}"
Link {
2023-05-24 00:09:24 +00:00
target: Route::Route2 { user_id: 8888 },
"hello world link"
}
2023-05-31 22:12:52 +00:00
button {
2023-06-01 14:45:31 +00:00
onclick: move |_| { navigator.push(NavigationTarget::External("https://www.google.com".to_string())); },
2023-05-31 22:12:52 +00:00
"google link"
}
2023-05-24 00:09:24 +00:00
p { "Site Map" }
pre { "{site_map:#?}" }
p { "Dynamic link" }
2023-07-14 18:40:38 +00:00
match parsed {
Ok(route) => {
if route != current_route {
render! {
Link {
target: route.clone(),
"{route}"
}
2023-05-24 00:09:24 +00:00
}
}
2023-07-14 18:40:38 +00:00
else {
None
}
2023-05-24 00:09:24 +00:00
}
2023-07-14 18:40:38 +00:00
Err(err) => {
render! {
pre {
color: "red",
"Invalid route:\n{err}"
}
}
2023-05-24 00:39:18 +00:00
}
}
}
}
2023-05-24 00:09:24 +00:00
#[rustfmt::skip]
2023-06-01 16:03:44 +00:00
#[derive(Clone, Debug, PartialEq, Routable)]
2023-05-24 00:09:24 +00:00
enum Route {
2023-07-14 18:40:38 +00:00
#[nest("/test")]
// Nests with parameters have types taken from child routes
#[nest("/user/:user_id")]
// Everything inside the nest has the added parameter `user_id: usize`
// UserFrame is a layout component that will receive the `user_id: usize` parameter
#[layout(UserFrame)]
#[route("/:dynamic?:query")]
Route1 {
// The type is taken from the first instance of the dynamic parameter
user_id: usize,
dynamic: usize,
query: String,
extra: String,
},
#[route("/hello_world")]
// You can opt out of the layout by using the `!` prefix
#[layout(!UserFrame)]
Route2 { user_id: usize },
#[end_layout]
#[end_nest]
2023-05-24 00:09:24 +00:00
#[end_nest]
2023-05-31 17:11:11 +00:00
#[redirect("/:id/user", |id: usize| Route::Route3 { dynamic: id.to_string()})]
2023-05-31 18:57:33 +00:00
#[route("/:dynamic")]
2023-05-24 00:09:24 +00:00
Route3 { dynamic: String },
}