|
@@ -3,14 +3,14 @@
|
|
|
|
|
|
use dioxus::events::*;
|
|
|
use dioxus::prelude::*;
|
|
|
-use dioxus::router::{Link, Router, Route, RouterService};
|
|
|
+use dioxus::router::{Link, Route, Router, RouterService};
|
|
|
|
|
|
fn main() {
|
|
|
dioxus::desktop::launch(APP);
|
|
|
}
|
|
|
|
|
|
static APP: Component = |cx| {
|
|
|
- cx.render(rsx!{
|
|
|
+ cx.render(rsx! {
|
|
|
Router {
|
|
|
Route { to: "/", home() }
|
|
|
Route { to: "/login", login() }
|
|
@@ -25,65 +25,45 @@ fn home(cx: Scope) -> Element {
|
|
|
})
|
|
|
}
|
|
|
|
|
|
-
|
|
|
fn login(cx: Scope) -> Element {
|
|
|
- let username = use_state(&cx, String::new);
|
|
|
- let password = use_state(&cx, String::new);
|
|
|
-
|
|
|
let service = cx.consume_context::<RouterService>()?;
|
|
|
|
|
|
- let onsubmit = move |_| {
|
|
|
- cx.push_future({
|
|
|
- let (username, password) = (username.get().clone(), password.get().clone());
|
|
|
- let service = service.clone();
|
|
|
+ let onsubmit = move |evt: FormEvent| {
|
|
|
+ to_owned![service];
|
|
|
+ let username = evt.values["username"].clone();
|
|
|
+ let password = evt.values["password"].clone();
|
|
|
|
|
|
- async move {
|
|
|
- let params = [
|
|
|
- ("username", username.to_string()),
|
|
|
- ("password", password.to_string())
|
|
|
- ];
|
|
|
+ cx.spawn(async move {
|
|
|
+ let resp = reqwest::Client::new()
|
|
|
+ .post("http://localhost/login")
|
|
|
+ .form(&[("username", username), ("password", password)])
|
|
|
+ .send()
|
|
|
+ .await;
|
|
|
|
|
|
- let resp = reqwest::Client::new()
|
|
|
- .post("http://localhost/login")
|
|
|
- .form(¶ms)
|
|
|
- .send()
|
|
|
- .await;
|
|
|
+ match resp {
|
|
|
+ // Parse data from here, such as storing a response token
|
|
|
+ Ok(data) => service.push_route("/"),
|
|
|
|
|
|
- match resp {
|
|
|
- Ok(data) => {
|
|
|
- // Parse data from here, such as storing a response token
|
|
|
- service.push_route("/");
|
|
|
- }
|
|
|
- Err(err) => {} //Handle any errors from the fetch here
|
|
|
- }
|
|
|
+ //Handle any errors from the fetch here
|
|
|
+ Err(err) => {}
|
|
|
}
|
|
|
});
|
|
|
};
|
|
|
|
|
|
- cx.render(rsx!{
|
|
|
+ cx.render(rsx! {
|
|
|
h1 { "Login" }
|
|
|
form {
|
|
|
onsubmit: onsubmit,
|
|
|
- // Prevent the default behavior of <form> to post
|
|
|
- prevent_default: "onsubmit",
|
|
|
- input {
|
|
|
- oninput: move |evt| username.set(evt.value.clone())
|
|
|
- }
|
|
|
- label {
|
|
|
- "Username"
|
|
|
- }
|
|
|
+ prevent_default: "onsubmit", // Prevent the default behavior of <form> to post
|
|
|
+ input { r#type: "text" }
|
|
|
+ label { "Username" }
|
|
|
br {}
|
|
|
- input {
|
|
|
- oninput: move |evt| password.set(evt.value.clone()),
|
|
|
- r#type: "password"
|
|
|
- }
|
|
|
+ input { r#type: "password" }
|
|
|
label {
|
|
|
"Password"
|
|
|
}
|
|
|
br {}
|
|
|
- button {
|
|
|
- "Login"
|
|
|
- }
|
|
|
+ button { "Login" }
|
|
|
}
|
|
|
})
|
|
|
-}
|
|
|
+}
|