mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-11-27 06:30:20 +00:00
82 lines
2 KiB
Rust
82 lines
2 KiB
Rust
use dioxus::prelude::*;
|
|
use dioxus_core::ElementId;
|
|
use std::{rc::Rc, sync::Mutex};
|
|
|
|
static CLICKS: Mutex<usize> = Mutex::new(0);
|
|
|
|
#[test]
|
|
fn events_propagate() {
|
|
set_event_converter(Box::new(dioxus::html::SerializedHtmlEventConverter));
|
|
|
|
let mut dom = VirtualDom::new(app);
|
|
dom.rebuild(&mut dioxus_core::NoOpMutations);
|
|
|
|
// Top-level click is registered
|
|
dom.handle_event(
|
|
"click",
|
|
Rc::new(PlatformEventData::new(Box::<SerializedMouseData>::default())),
|
|
ElementId(1),
|
|
true,
|
|
);
|
|
assert_eq!(*CLICKS.lock().unwrap(), 1);
|
|
|
|
// break reference....
|
|
for _ in 0..5 {
|
|
dom.mark_dirty(ScopeId(0));
|
|
_ = dom.render_immediate_to_vec();
|
|
}
|
|
|
|
// Lower click is registered
|
|
dom.handle_event(
|
|
"click",
|
|
Rc::new(PlatformEventData::new(Box::<SerializedMouseData>::default())),
|
|
ElementId(2),
|
|
true,
|
|
);
|
|
assert_eq!(*CLICKS.lock().unwrap(), 3);
|
|
|
|
// break reference....
|
|
for _ in 0..5 {
|
|
dom.mark_dirty(ScopeId(0));
|
|
_ = dom.render_immediate_to_vec();
|
|
}
|
|
|
|
// Stop propagation occurs
|
|
dom.handle_event(
|
|
"click",
|
|
Rc::new(PlatformEventData::new(Box::<SerializedMouseData>::default())),
|
|
ElementId(2),
|
|
true,
|
|
);
|
|
assert_eq!(*CLICKS.lock().unwrap(), 3);
|
|
}
|
|
|
|
fn app() -> Element {
|
|
rsx! {
|
|
div { onclick: move |_| {
|
|
println!("top clicked");
|
|
*CLICKS.lock().unwrap() += 1;
|
|
},
|
|
|
|
{vec![
|
|
rsx! {
|
|
problematic_child {}
|
|
}
|
|
].into_iter()}
|
|
}
|
|
}
|
|
}
|
|
|
|
fn problematic_child() -> Element {
|
|
rsx! {
|
|
button { onclick: move |evt| {
|
|
println!("bottom clicked");
|
|
let mut clicks = CLICKS.lock().unwrap();
|
|
if *clicks == 3 {
|
|
evt.stop_propagation();
|
|
} else {
|
|
*clicks += 1;
|
|
}
|
|
} }
|
|
}
|
|
}
|