simple_desktop.rs 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. #![allow(non_snake_case)]
  2. use dioxus::prelude::*;
  3. use dioxus_router::prelude::*;
  4. fn main() {
  5. simple_logger::SimpleLogger::new()
  6. .with_level(log::LevelFilter::Debug)
  7. .with_module_level("dioxus", log::LevelFilter::Trace)
  8. .init()
  9. .unwrap();
  10. dioxus_desktop::launch(App);
  11. }
  12. #[component]
  13. fn App(cx: Scope) -> Element {
  14. render! {
  15. Router::<Route> {}
  16. }
  17. }
  18. #[derive(Routable, Clone)]
  19. #[rustfmt::skip]
  20. enum Route {
  21. #[layout(NavBar)]
  22. #[route("/")]
  23. Home {},
  24. #[nest("/new")]
  25. #[route("/")]
  26. BlogList {},
  27. #[route("/:post")]
  28. BlogPost {
  29. post: String,
  30. },
  31. #[end_nest]
  32. #[route("/oranges")]
  33. Oranges {},
  34. }
  35. #[component]
  36. fn NavBar(cx: Scope) -> Element {
  37. render! {
  38. h1 { "Your app here" }
  39. ul {
  40. li { Link { to: Route::Home {}, "home" } }
  41. li { Link { to: Route::BlogList {}, "blog" } }
  42. li { Link { to: Route::BlogPost { post: "tim".into() }, "tims' blog" } }
  43. li { Link { to: Route::BlogPost { post: "bill".into() }, "bills' blog" } }
  44. li { Link { to: Route::BlogPost { post: "james".into() }, "james amazing' blog" } }
  45. }
  46. Outlet::<Route> {}
  47. }
  48. }
  49. #[component]
  50. fn Home(cx: Scope) -> Element {
  51. log::debug!("rendering home {:?}", cx.scope_id());
  52. render! { h1 { "Home" } }
  53. }
  54. #[component]
  55. fn BlogList(cx: Scope) -> Element {
  56. log::debug!("rendering blog list {:?}", cx.scope_id());
  57. render! { div { "Blog List" } }
  58. }
  59. #[component]
  60. fn BlogPost(cx: Scope, post: String) -> Element {
  61. log::debug!("rendering blog post {}", post);
  62. render! {
  63. div {
  64. h3 { "blog post: {post}" }
  65. Link { to: Route::BlogList {}, "back to blog list" }
  66. }
  67. }
  68. }
  69. #[component]
  70. fn Oranges(cx: Scope) -> Element {
  71. render!("Oranges are not apples!")
  72. }