mirror of
https://github.com/LadybirdBrowser/ladybird
synced 2026-05-05 06:32:30 +02:00
LibWeb: Ignore boxes without layout node in intersection observer steps
Check if box has associated layout node is not mentioned in the spec, but it is required to match behavior of other browsers that do not invoke intersection observer steps for boxes without layout node.
This commit is contained in:
committed by
Alexander Kalenik
parent
ea8a6b43f7
commit
3e1d718b7f
Notes:
github-actions[bot]
2025-04-14 15:10:55 +00:00
Author: https://github.com/kalenikaliaksandr Commit: https://github.com/LadybirdBrowser/ladybird/commit/3e1d718b7ff Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/4343
@@ -4663,8 +4663,8 @@ void Document::run_the_update_intersection_observations_steps(HighResolutionTime
|
||||
auto intersection_root_document = intersection_root.visit([](auto& node) -> GC::Ref<Document> {
|
||||
return node->document();
|
||||
});
|
||||
if (!(observer->root().has<Empty>() && &target->document() == intersection_root_document.ptr())
|
||||
|| !(intersection_root.has<GC::Root<DOM::Element>>() && !target->is_descendant_of(*intersection_root.get<GC::Root<DOM::Element>>()))) {
|
||||
// NOTE: Check if target has a layout node is not in the spec but required to match other browsers.
|
||||
if (target->layout_node() && (!(observer->root().has<Empty>() && &target->document() == intersection_root_document.ptr()) || !(intersection_root.has<GC::Root<DOM::Element>>() && !target->is_descendant_of(*intersection_root.get<GC::Root<DOM::Element>>())))) {
|
||||
// 4. Set targetRect to the DOMRectReadOnly obtained by getting the bounding box for target.
|
||||
target_rect = target->get_bounding_client_rect();
|
||||
|
||||
|
||||
Reference in New Issue
Block a user