dioxus/examples/all_events.rs

68 lines
1.8 KiB
Rust
Raw Normal View History

2024-01-31 01:59:57 +00:00
use dioxus::prelude::*;
2024-01-19 23:48:21 +00:00
use std::{collections::VecDeque, fmt::Debug, rc::Rc};
fn main() {
launch(app);
}
const MAX_EVENTS: usize = 8;
2022-07-03 03:12:26 +00:00
const CONTAINER_STYLE: &str = r#"
2024-01-19 23:48:21 +00:00
display: flex;
flex-direction: column;
align-items: center;
"#;
2022-07-03 03:12:26 +00:00
const RECT_STYLE: &str = r#"
2024-01-19 23:48:21 +00:00
background: deepskyblue;
height: 50vh;
width: 50vw;
color: white;
padding: 20px;
margin: 20px;
text-aligh: center;
"#;
fn app() -> Element {
2024-01-21 07:32:12 +00:00
let mut events = use_signal(|| VecDeque::new() as VecDeque<Rc<dyn Debug>>);
2024-01-19 23:48:21 +00:00
let mut log_event = move |event: Rc<dyn Debug>| {
2022-07-03 03:17:48 +00:00
let mut events = events.write();
if events.len() >= MAX_EVENTS {
events.pop_front();
}
2024-01-19 23:48:21 +00:00
2022-07-03 03:17:48 +00:00
events.push_back(event);
};
2024-01-16 19:18:46 +00:00
rsx! {
div { style: "{CONTAINER_STYLE}",
2024-01-19 23:48:21 +00:00
// focusing is necessary to catch keyboard events
2024-01-31 22:07:00 +00:00
div { style: "{RECT_STYLE}", tabindex: 0,
onmousemove: move |event| log_event(event.data()),
onclick: move |event| log_event(event.data()),
ondoubleclick: move |event| log_event(event.data()),
onmousedown: move |event| log_event(event.data()),
onmouseup: move |event| log_event(event.data()),
2024-01-19 23:48:21 +00:00
2024-01-31 22:07:00 +00:00
onwheel: move |event| log_event(event.data()),
2024-01-19 23:48:21 +00:00
2024-01-31 22:07:00 +00:00
onkeydown: move |event| log_event(event.data()),
onkeyup: move |event| log_event(event.data()),
onkeypress: move |event| log_event(event.data()),
2024-01-19 23:48:21 +00:00
2024-01-31 22:07:00 +00:00
onfocusin: move |event| log_event(event.data()),
onfocusout: move |event| log_event(event.data()),
"Hover, click, type or scroll to see the info down below"
}
div {
for event in events.read().iter() {
div { "{event:?}" }
}
}
}
2024-01-14 05:12:21 +00:00
}
}