mirror of
https://github.com/DioxusLabs/dioxus
synced 2025-01-08 02:38:51 +00:00
31780b3ede
* liveview: Add `interpreter_glue_relative_uri` By utilizing `window.location.host` in the client-side JavaScript, we can easily derive the WebSocket URI from a relative path URI. This approach obviates the need for host address retrieval on the server side, unlike the method of serving glue code in liveview using `interpreter_glue`. * liveview: Merge `.._relative_url` functionality - Merged `.._relative_url` to current API `interpreter_glue`. - Edit axum example to work with new feature. * liveview: Fix clippy warning
66 lines
1.8 KiB
Rust
66 lines
1.8 KiB
Rust
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 index_page_with_glue = |glue: &str| {
|
|
Html(format!(
|
|
r#"
|
|
<!DOCTYPE html>
|
|
<html>
|
|
<head> <title>Dioxus LiveView with axum</title> </head>
|
|
<body> <div id="main"></div> </body>
|
|
{glue}
|
|
</html>
|
|
"#,
|
|
))
|
|
};
|
|
|
|
let app =
|
|
Router::new()
|
|
.route(
|
|
"/",
|
|
get(move || async move {
|
|
index_page_with_glue(&dioxus_liveview::interpreter_glue(&format!(
|
|
"ws://{addr}/ws"
|
|
)))
|
|
}),
|
|
)
|
|
.route(
|
|
"/as-path",
|
|
get(move || async move {
|
|
index_page_with_glue(&dioxus_liveview::interpreter_glue("/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();
|
|
}
|