1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-05-31 14:38:11 +00:00

LibWeb: Ignore "pointer-events: none" elements in hit_test

This commit is contained in:
Aliaksandr Kalenik 2022-10-19 13:46:48 +03:00 committed by Linus Groh
parent f39b6ae3c6
commit dfc3a4772b
2 changed files with 6 additions and 6 deletions

View file

@ -280,7 +280,6 @@ bool EventHandler::handle_mousedown(Gfx::IntPoint const& position, unsigned butt
JS::GCPtr<DOM::Node> node;
{
// TODO: Allow selecting element behind if one on top has pointer-events set to none.
RefPtr<Painting::Paintable> paintable;
if (m_mouse_event_tracking_layout_node) {
paintable = m_mouse_event_tracking_layout_node->paintable();
@ -293,8 +292,7 @@ bool EventHandler::handle_mousedown(Gfx::IntPoint const& position, unsigned butt
auto pointer_events = paintable->computed_values().pointer_events();
// FIXME: Handle other values for pointer-events.
if (pointer_events == CSS::PointerEvents::None)
return false;
VERIFY(pointer_events != CSS::PointerEvents::None);
node = paintable->mouse_event_target();
if (!node)
@ -414,8 +412,7 @@ bool EventHandler::handle_mousemove(Gfx::IntPoint const& position, unsigned butt
auto pointer_events = paintable->computed_values().pointer_events();
// FIXME: Handle other values for pointer-events.
if (pointer_events == CSS::PointerEvents::None)
return false;
VERIFY(pointer_events != CSS::PointerEvents::None);
hovered_node_changed = node.ptr() != document.hovered_node();
document.set_hovered_node(node);
@ -497,7 +494,6 @@ bool EventHandler::handle_doubleclick(Gfx::IntPoint const& position, unsigned bu
if (!paint_root())
return false;
// TODO: Allow selecting element behind if one on top has pointer-events set to none.
RefPtr<Painting::Paintable> paintable;
if (m_mouse_event_tracking_layout_node) {
paintable = m_mouse_event_tracking_layout_node->paintable();