main.rs 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. //! Run with:
  2. //!
  3. //! ```sh
  4. //! dx build --features web --release
  5. //! cargo run --features ssr --release
  6. //! ```
  7. #![allow(non_snake_case, unused)]
  8. use dioxus::prelude::*;
  9. use serde::{Deserialize, Serialize};
  10. fn app() -> Element {
  11. // let state = use_server_future(|| async move { get_server_data().await.unwrap() })?;
  12. // let state = state.value();
  13. let mut count = use_signal(|| 0);
  14. let text = use_signal(|| "...".to_string());
  15. rsx! {
  16. // div { "Server state: {state}" }
  17. h1 { "High-Five counter: {count}" }
  18. button { onclick: move |_| count += 1, "Up high!" }
  19. button { onclick: move |_| count -= 1, "Down low!" }
  20. button {
  21. onclick: move |_| {
  22. to_owned![text];
  23. async move {
  24. if let Ok(data) = get_server_data().await {
  25. println!("Client received: {}", data);
  26. text.set(data.clone());
  27. post_server_data(data).await.unwrap();
  28. }
  29. }
  30. },
  31. "Run a server function!"
  32. }
  33. "Server said: {text}"
  34. }
  35. }
  36. #[server]
  37. async fn post_server_data(data: String) -> Result<(), ServerFnError> {
  38. println!("Server received: {}", data);
  39. Ok(())
  40. }
  41. #[server]
  42. async fn get_server_data() -> Result<String, ServerFnError> {
  43. Ok(reqwest::get("https://httpbin.org/ip").await?.text().await?)
  44. }
  45. fn main() {
  46. #[cfg(feature = "web")]
  47. tracing_wasm::set_as_global_default();
  48. #[cfg(feature = "ssr")]
  49. tracing_subscriber::fmt::init();
  50. launch(app);
  51. }