ladybird/Libraries/LibWeb/HTML/HTMLObjectElement.h

115 lines
4 KiB
C
Raw Normal View History

/*
* Copyright (c) 2020, Andreas Kling <andreas@ladybird.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibCore/Forward.h>
#include <LibGfx/Forward.h>
#include <LibWeb/HTML/NavigableContainer.h>
#include <LibWeb/Layout/ImageProvider.h>
namespace Web::HTML {
class HTMLObjectElement final
: public NavigableContainer
, public Layout::ImageProvider {
WEB_PLATFORM_OBJECT(HTMLObjectElement, NavigableContainer)
GC_DECLARE_ALLOCATOR(HTMLObjectElement);
enum class Representation {
Unknown,
Image,
ContentNavigable,
Children,
};
public:
virtual ~HTMLObjectElement() override;
virtual void form_associated_element_attribute_changed(FlyString const& name, Optional<String> const& old_value, Optional<String> const& value, Optional<FlyString> const& namespace_) override;
virtual void form_associated_element_was_removed(DOM::Node*) override;
String data() const;
void set_data(String const& data);
String type() const { return get_attribute_value(HTML::AttributeNames::type); }
// ^FormAssociatedElement
virtual bool is_form_associated_element() const override { return true; }
// ^FormAssociatedElement
// https://html.spec.whatwg.org/multipage/forms.html#category-listed
virtual bool is_listed() const override { return true; }
LibWeb: Map document element focus to the viewport Apply the focusing steps' get-the-focusable-area mapping before rejecting a non-focusable target. This preserves documentElement.focus() by mapping the non-focusable document element to the Document viewport. Also map rendered navigable containers with content navigables to their active document, while leaving hidden containers unfocused. Preserve Window focus events for child document viewports reached through iframe focus, while still suppressing the top-level viewport surrogate events. Treat rendered object elements as focusable through their default non-null tabindex, even when they show fallback or image content instead of a child navigable. Keep the spec focus-chain common-tail handling intact for viewport focus. The Document object is only our surrogate for the viewport, so designate viewport focus from the new focus target without dispatching Window focus/focusin events for that top-level surrogate. Pass that viewport surrogate as the fallback target for fragment scrolling and NavigateEvent focus reset, so unfocusable body or fragment targets still clear stale element focus. Cover documentElement.focus() in both the activeElement and focus-chain tests, including a tabindex document element that remains focused as an element. Cover object focus with and without a child navigable, hidden object focus attempts, iframe focus events, hidden iframe focus, and blurring a focused iframe after it becomes hidden. Also cover viewport fallback for intercepted navigation focus reset and fragment scrolling to an unfocusable target.
2026-05-20 15:52:18 +02:00
// ^EventTarget
virtual bool is_focusable() const override
{
return meets_focusable_area_rendering_requirements();
}
virtual void visit_edges(Cell::Visitor&) override;
private:
HTMLObjectElement(DOM::Document&, DOM::QualifiedName);
virtual bool is_html_object_element() const override { return true; }
virtual void initialize(JS::Realm&) override;
virtual bool is_presentational_hint(FlyString const&) const override;
virtual void apply_presentational_hints(Vector<CSS::StyleProperty>&) const override;
virtual GC::Ptr<Layout::Node> create_layout_node(CSS::ComputedProperties const&) override;
virtual void adjust_computed_style(CSS::ComputedProperties&) override;
bool has_ancestor_media_element_or_object_element_not_showing_fallback_content() const;
void queue_element_task_to_run_object_representation_steps();
void run_object_representation_handler_steps(Fetch::Infrastructure::Response const&, MimeSniff::MimeType const&, ReadonlyBytes);
void run_object_representation_completed_steps(Representation);
void run_object_representation_fallback_steps();
void load_image();
void update_layout_and_child_objects(Representation);
void resource_did_load(Fetch::Infrastructure::Response const&, ReadonlyBytes);
void resource_did_fail();
// ^DOM::Element
virtual i32 default_tab_index_value() const override;
// ^Layout::ImageProvider
virtual bool is_image_available() const override;
virtual Optional<CSSPixels> intrinsic_width() const override;
virtual Optional<CSSPixels> intrinsic_height() const override;
virtual Optional<CSSPixelFraction> intrinsic_aspect_ratio() const override;
virtual Optional<Gfx::DecodedImageFrame> current_image_frame_sized(Gfx::IntSize) const override;
virtual void set_visible_in_viewport(bool) override;
virtual GC::Ptr<DOM::Element const> to_html_element() const override { return *this; }
virtual size_t current_frame_index() const override { return 0; }
virtual GC::Ptr<DecodedImageData> decoded_image_data() const override { return image_data(); }
GC::Ptr<DecodedImageData> image_data() const;
Representation m_representation { Representation::Unknown };
GC::Ptr<SharedResourceRequest> m_resource_request;
GC::Ptr<DOM::DocumentObserver> m_document_observer;
Vector<DOM::DocumentLoadEventDelayer> m_document_load_event_delayer_for_object_representation_task;
Vector<DOM::DocumentLoadEventDelayer> m_document_load_event_delayer_for_resource_load;
};
}
namespace Web::DOM {
template<>
inline bool Node::fast_is<HTML::HTMLObjectElement>() const { return is_html_object_element(); }
}