/* * Copyright (c) 2023, Luke Wilde * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include namespace Web::IntersectionObserver { JS_DEFINE_ALLOCATOR(IntersectionObserverEntry); WebIDL::ExceptionOr> IntersectionObserverEntry::construct_impl(JS::Realm& realm, Web::IntersectionObserver::IntersectionObserverEntryInit const& options) { auto& vm = realm.vm(); JS::GCPtr root_bounds; if (options.root_bounds.has_value()) root_bounds = Geometry::DOMRectReadOnly::from_rect(vm, options.root_bounds.value()); auto bounding_client_rect = Geometry::DOMRectReadOnly::from_rect(vm, options.bounding_client_rect); auto intersection_rect = Geometry::DOMRectReadOnly::from_rect(vm, options.intersection_rect); return realm.heap().allocate(realm, realm, options.time, root_bounds, bounding_client_rect, intersection_rect, options.is_intersecting, options.intersection_ratio, *options.target); } IntersectionObserverEntry::IntersectionObserverEntry(JS::Realm& realm, HighResolutionTime::DOMHighResTimeStamp time, JS::GCPtr root_bounds, JS::NonnullGCPtr bounding_client_rect, JS::NonnullGCPtr intersection_rect, bool is_intersecting, double intersection_ratio, JS::NonnullGCPtr target) : Bindings::PlatformObject(realm) , m_time(time) , m_root_bounds(root_bounds) , m_bounding_client_rect(bounding_client_rect) , m_intersection_rect(intersection_rect) , m_is_intersecting(is_intersecting) , m_intersection_ratio(intersection_ratio) , m_target(target) { } IntersectionObserverEntry::~IntersectionObserverEntry() = default; void IntersectionObserverEntry::initialize(JS::Realm& realm) { Base::initialize(realm); WEB_SET_PROTOTYPE_FOR_INTERFACE(IntersectionObserverEntry); } void IntersectionObserverEntry::visit_edges(JS::Cell::Visitor& visitor) { Base::visit_edges(visitor); visitor.visit(m_root_bounds); visitor.visit(m_bounding_client_rect); visitor.visit(m_intersection_rect); visitor.visit(m_target); } }