3 releases
0.0.4 | Feb 22, 2024 |
---|---|
0.0.3 | Feb 19, 2024 |
0.0.1 | Oct 24, 2023 |
#1887 in Rust patterns
37KB
922 lines
This provides traits and a derive macro for generating rooting HTML forms from structs and enums.
Example
#[derive(rooting_forms::Form)]
struct Creds {
#[title("Your username")]
username: String,
#[title("Your password")]
password: rooting_forms::Password,
}
...
let ok_button = el("button").text("Ok");
let (creds_form, creds_form_state) = Creds::new_form("", None);
ok_button.ref_on("click", move |_| {
let Ok(creds) = creds_form_state.parse() else {
return;
};
do_login(creds);
});
let modal =
el(
"div",
).extend(vec![el("div").classes(&["form_grid"]).extend(creds_form.elements), ok_button]);
...
Creating a form
Call ::new_form
on your form type. The first argument can be empty (it's used for aria hints for nested fields but not for top level structs). The second argument is Some
if you want to pre-populate the form from existing data, for instance if you're editing something.
new_form
returns a the form rooting::El
elements and a state object.
Call parse()
on the state object any number of times. It will either return the parsed object or an empty error. Any error messages will be automatically put in error elements near the relevant form fields. The error messages are cleared at the next parse()
.
Dependencies
~11MB
~213K SLoC