main.rs 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. //! Run with:
  2. //!
  3. //! ```sh
  4. //! dx build --features web
  5. //! cargo run --features ssr
  6. //! ```
  7. #![allow(non_snake_case, unused)]
  8. use dioxus::prelude::*;
  9. use dioxus_fullstack::{launch, prelude::*};
  10. use serde::{Deserialize, Serialize};
  11. #[derive(Props, PartialEq, Debug, Default, Serialize, Deserialize, Clone)]
  12. struct AppProps {
  13. count: i32,
  14. }
  15. fn app(cx: Scope<AppProps>) -> Element {
  16. let mut count = use_state(cx, || cx.props.count);
  17. let text = use_state(cx, || "...".to_string());
  18. cx.render(rsx! {
  19. h1 { "High-Five counter: {count}" }
  20. button { onclick: move |_| count += 1, "Up high!" }
  21. button { onclick: move |_| count -= 1, "Down low!" }
  22. button {
  23. onclick: move |_| {
  24. to_owned![text];
  25. async move {
  26. if let Ok(data) = get_server_data().await {
  27. println!("Client received: {}", data);
  28. text.set(data.clone());
  29. post_server_data(data).await.unwrap();
  30. }
  31. }
  32. },
  33. "Run a server function!"
  34. }
  35. "Server said: {text}"
  36. })
  37. }
  38. #[server(PostServerData)]
  39. async fn post_server_data(data: String) -> Result<(), ServerFnError> {
  40. let axum::extract::Host(host): axum::extract::Host = extract()?;
  41. println!("Server received: {}", data);
  42. println!("{:?}", host);
  43. Ok(())
  44. }
  45. #[server(GetServerData)]
  46. async fn get_server_data() -> Result<String, ServerFnError> {
  47. Ok("Hello from the server!".to_string())
  48. }
  49. fn main() {
  50. launch!(@([127, 0, 0, 1], 8080), app, {
  51. serve_cfg: ServeConfigBuilder::new(app, AppProps { count: 0 }),
  52. });
  53. }