123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- #![allow(unused)]
- use dioxus::prelude::*;
- use dioxus_router::prelude::*;
- fn prepare(path: impl Into<String>) -> VirtualDom {
- let mut vdom = VirtualDom::new_with_props(App, AppProps { path: path.into() });
- let _ = vdom.rebuild();
- return vdom;
- #[derive(Routable, Clone)]
- #[rustfmt::skip]
- enum Route {
- #[route("/")]
- RootIndex {},
- #[nest("/fixed")]
- #[layout(Fixed)]
- #[route("/")]
- FixedIndex {},
- #[route("/fixed")]
- FixedFixed {},
- #[end_layout]
- #[end_nest]
- #[nest("/:id")]
- #[layout(Parameter)]
- #[route("/")]
- ParameterIndex { id: u8 },
- #[route("/fixed")]
- ParameterFixed { id: u8 },
- }
- #[derive(Debug, Props, PartialEq)]
- struct AppProps {
- path: String,
- }
- #[component]
- fn App(cx: Scope<AppProps>) -> Element {
- render! {
- h1 { "App" }
- Router::<Route> {
- config: {
- let path = cx.props.path.parse().unwrap();
- move || RouterConfig::default().history(MemoryHistory::with_initial_path(path))
- }
- }
- }
- }
- #[component]
- fn RootIndex(cx: Scope) -> Element {
- render! {
- h2 { "Root Index" }
- }
- }
- #[component]
- fn Fixed(cx: Scope) -> Element {
- render! {
- h2 { "Fixed" }
- Outlet::<Route> { }
- }
- }
- #[component]
- fn FixedIndex(cx: Scope) -> Element {
- render! {
- h3 { "Fixed - Index" }
- }
- }
- #[component]
- fn FixedFixed(cx: Scope) -> Element {
- render! {
- h3 { "Fixed - Fixed"}
- }
- }
- #[component]
- fn Parameter(cx: Scope, id: u8) -> Element {
- render! {
- h2 { "Parameter {id}" }
- Outlet::<Route> { }
- }
- }
- #[component]
- fn ParameterIndex(cx: Scope, id: u8) -> Element {
- render! {
- h3 { "Parameter - Index" }
- }
- }
- #[component]
- fn ParameterFixed(cx: Scope, id: u8) -> Element {
- render! {
- h3 { "Parameter - Fixed" }
- }
- }
- }
- #[test]
- fn root_index() {
- let vdom = prepare("/");
- let html = dioxus_ssr::render(&vdom);
- assert_eq!(html, "<h1>App</h1><h2>Root Index</h2>");
- }
- #[test]
- fn fixed() {
- let vdom = prepare("/fixed");
- let html = dioxus_ssr::render(&vdom);
- assert_eq!(html, "<h1>App</h1><h2>Fixed</h2><h3>Fixed - Index</h3>");
- }
- #[test]
- fn fixed_fixed() {
- let vdom = prepare("/fixed/fixed");
- let html = dioxus_ssr::render(&vdom);
- assert_eq!(html, "<h1>App</h1><h2>Fixed</h2><h3>Fixed - Fixed</h3>");
- }
- #[test]
- fn parameter() {
- let vdom = prepare("/18");
- let html = dioxus_ssr::render(&vdom);
- assert_eq!(
- html,
- "<h1>App</h1><h2>Parameter 18</h2><h3>Parameter - Index</h3>"
- );
- }
- #[test]
- fn parameter_fixed() {
- let vdom = prepare("/18/fixed");
- let html = dioxus_ssr::render(&vdom);
- assert_eq!(
- html,
- "<h1>App</h1><h2>Parameter 18</h2><h3>Parameter - Fixed</h3>"
- );
- }
|