-
-
Notifications
You must be signed in to change notification settings - Fork 69
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
4 changed files
with
120 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,87 @@ | ||
# Router | ||
|
||
Freya supports the official [Dioxus Router](https://docs.rs/dioxus-router/latest/dioxus_router/), which means you can declare different pages for your app. The only difference is that you will need to use Freya's custom `Link` component. | ||
|
||
Example: | ||
```rs | ||
fn app() -> Element { | ||
rsx!(Router::<Route> {}) | ||
} | ||
|
||
/// Declare your Routes tree in an enum | ||
/// Every route must have a component with the same name | ||
/// So for example, `Home` needs to have a `fn Home(...` component | ||
/// the `Routable` macro will pick it up automatically | ||
/// so it must be in the scope. | ||
#[derive(Routable, Clone, PartialEq)] | ||
#[rustfmt::skip] | ||
pub enum Route { | ||
#[layout(AppSidebar)] | ||
#[route("/")] | ||
Home, | ||
#[route("/other")] | ||
Other, | ||
#[end_layout] | ||
#[route("/..route")] | ||
PageNotFound { }, // Handle 404 routes. | ||
} | ||
|
||
#[allow(non_snake_case)] | ||
fn AppSidebar() -> Element { | ||
rsx!( | ||
Body { | ||
Link { | ||
// Specify to what destination you want this Link you point when clicking. | ||
to: Route::Home, | ||
label { | ||
"Home" | ||
} | ||
}, | ||
Link { | ||
to: Route::Other, | ||
label { | ||
"Other" | ||
} | ||
}, | ||
rect { | ||
main_align: "center", | ||
cross_align: "center", | ||
width: "100%", | ||
height: "100%", | ||
// This is the place where the routes content will actually be showed. | ||
Outlet::<Route> { } | ||
} | ||
} | ||
) | ||
} | ||
|
||
#[allow(non_snake_case)] | ||
#[component] | ||
fn Home() -> Element { | ||
rsx!( | ||
label { | ||
"Home Page" | ||
} | ||
) | ||
} | ||
|
||
#[allow(non_snake_case)] | ||
#[component] | ||
fn Other() -> Element { | ||
rsx!( | ||
label { | ||
"Other Page" | ||
} | ||
) | ||
} | ||
|
||
#[allow(non_snake_case)] | ||
#[component] | ||
fn PageNotFound() -> Element { | ||
rsx!( | ||
label { | ||
"404" | ||
} | ||
) | ||
} | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
# Native Router | ||
|
||
Even though Freya supports Dioxus Router, it might due to Freya being it's own platform it misses certain integrations that users might expect from routing in an app, like support for back and forward buttons from mouses. | ||
|
||
In order to use the native router you simply need to wrap your `Router` content inside the `NativeRouter` component. | ||
|
||
Example (based on the example from [router](../router.md)): | ||
```rs | ||
#[allow(non_snake_case)] | ||
fn AppSidebar() -> Element { | ||
rsx!( | ||
NativeRouter { | ||
Body { | ||
Link { | ||
to: Route::Home, | ||
label { | ||
"Home" | ||
} | ||
}, | ||
Link { | ||
to: Route::Other, | ||
label { | ||
"Other" | ||
} | ||
}, | ||
... | ||
} | ||
} | ||
) | ||
} | ||
|
||
``` |