12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- use axum::{extract::ws::WebSocketUpgrade, response::Html, routing::get, Router};
- use dioxus::prelude::*;
- fn app(cx: Scope) -> Element {
- let mut num = use_state(cx, || 0);
- cx.render(rsx! {
- div {
- "hello axum! {num}"
- button { onclick: move |_| num += 1, "Increment" }
- }
- })
- }
- #[tokio::main]
- async fn main() {
- pretty_env_logger::init();
- let addr: std::net::SocketAddr = ([127, 0, 0, 1], 3030).into();
- let view = dioxus_liveview::LiveViewPool::new();
- let app = Router::new()
- .route(
- "/",
- get(move || async move {
- Html(format!(
- r#"
- <!DOCTYPE html>
- <html>
- <head> <title>Dioxus LiveView with Warp</title> </head>
- <body> <div id="main"></div> </body>
- {glue}
- </html>
- "#,
- glue = dioxus_liveview::interpreter_glue(&format!("ws://{addr}/ws"))
- ))
- }),
- )
- .route(
- "/ws",
- get(move |ws: WebSocketUpgrade| async move {
- ws.on_upgrade(move |socket| async move {
- _ = view.launch(dioxus_liveview::axum_socket(socket), app).await;
- })
- }),
- );
- println!("Listening on http://{addr}");
- axum::Server::bind(&addr.to_string().parse().unwrap())
- .serve(app.into_make_service())
- .await
- .unwrap();
- }
|