all_events.rs 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. //! This example shows how to listen to all events on a div and log them to the console.
  2. //!
  3. //! The primary demonstration here is the properties on the events themselves, hoping to give you some inspiration
  4. //! on adding interactivity to your own application.
  5. use dioxus::prelude::*;
  6. use std::{collections::VecDeque, fmt::Debug, rc::Rc};
  7. const STYLE: Asset = asset!("/examples/assets/events.css");
  8. fn main() {
  9. dioxus::launch(app);
  10. }
  11. fn app() -> Element {
  12. // Using a VecDeque so its cheap to pop old events off the front
  13. let mut events = use_signal(VecDeque::new);
  14. // All events and their data implement Debug, so we can re-cast them as Rc<dyn Debug> instead of their specific type
  15. let mut log_event = move |event: Rc<dyn Debug>| {
  16. // Only store the last 20 events
  17. if events.read().len() >= 20 {
  18. events.write().pop_front();
  19. }
  20. events.write().push_back(event);
  21. };
  22. let random_text = "This is some random repeating text. ".repeat(1000);
  23. rsx! {
  24. document::Link { rel: "stylesheet", href: STYLE }
  25. div { id: "container",
  26. // focusing is necessary to catch keyboard events
  27. div { id: "receiver", tabindex: 0,
  28. onmousemove: move |event| log_event(event.data()),
  29. onclick: move |event| log_event(event.data()),
  30. ondoubleclick: move |event| log_event(event.data()),
  31. onmousedown: move |event| log_event(event.data()),
  32. onmouseup: move |event| log_event(event.data()),
  33. onwheel: move |event| log_event(event.data()),
  34. onkeydown: move |event| log_event(event.data()),
  35. onkeyup: move |event| log_event(event.data()),
  36. onkeypress: move |event| log_event(event.data()),
  37. onfocusin: move |event| log_event(event.data()),
  38. onfocusout: move |event| log_event(event.data()),
  39. "Hover, click, type or scroll to see the info down below"
  40. }
  41. div {
  42. style: "padding: 50px;",
  43. div {
  44. style: "text-align: center; padding: 20px; font-family: sans-serif; overflow: auto; height: 400px;",
  45. onscroll: move |event: Event<ScrollData>| {
  46. log_event(event.data());
  47. },
  48. div { style: "margin: 20px; padding: 15px; border: 1px solid #ccc; border-radius: 5px;",
  49. p { "{random_text}" }
  50. }
  51. }
  52. }
  53. div { id: "log",
  54. for event in events.read().iter() {
  55. div { "{event:?}" }
  56. }
  57. }
  58. }
  59. }
  60. }