main.rs 1.3 KB

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