From fd360ba1715692ce44c49c680ab67bf2a1d2fcc4 Mon Sep 17 00:00:00 2001 From: stelar7 Date: Fri, 2 Jun 2023 21:44:03 +0200 Subject: LibWeb: Implement `details_notification_task_steps` for
--- Userland/Libraries/LibWeb/DOM/Element.h | 4 +-- .../Libraries/LibWeb/HTML/HTMLDetailsElement.cpp | 36 ++++++++++++++++++++++ .../Libraries/LibWeb/HTML/HTMLDetailsElement.h | 6 ++++ 3 files changed, 44 insertions(+), 2 deletions(-) (limited to 'Userland') diff --git a/Userland/Libraries/LibWeb/DOM/Element.h b/Userland/Libraries/LibWeb/DOM/Element.h index 4703ece58c..75b1079249 100644 --- a/Userland/Libraries/LibWeb/DOM/Element.h +++ b/Userland/Libraries/LibWeb/DOM/Element.h @@ -89,11 +89,11 @@ public: bool has_attributes() const; DeprecatedString attribute(DeprecatedFlyString const& name) const { return get_attribute(name); } DeprecatedString get_attribute(DeprecatedFlyString const& name) const; - WebIDL::ExceptionOr set_attribute(DeprecatedFlyString const& name, DeprecatedString const& value); + virtual WebIDL::ExceptionOr set_attribute(DeprecatedFlyString const& name, DeprecatedString const& value); WebIDL::ExceptionOr set_attribute_ns(DeprecatedFlyString const& namespace_, DeprecatedFlyString const& qualified_name, DeprecatedString const& value); WebIDL::ExceptionOr> set_attribute_node(Attr&); WebIDL::ExceptionOr> set_attribute_node_ns(Attr&); - void remove_attribute(DeprecatedFlyString const& name); + virtual void remove_attribute(DeprecatedFlyString const& name); WebIDL::ExceptionOr toggle_attribute(DeprecatedFlyString const& name, Optional force); size_t attribute_list_size() const; NamedNodeMap const* attributes() const { return m_attributes.ptr(); } diff --git a/Userland/Libraries/LibWeb/HTML/HTMLDetailsElement.cpp b/Userland/Libraries/LibWeb/HTML/HTMLDetailsElement.cpp index fceef86285..609f70d833 100644 --- a/Userland/Libraries/LibWeb/HTML/HTMLDetailsElement.cpp +++ b/Userland/Libraries/LibWeb/HTML/HTMLDetailsElement.cpp @@ -5,7 +5,9 @@ */ #include +#include #include +#include namespace Web::HTML { @@ -16,6 +18,40 @@ HTMLDetailsElement::HTMLDetailsElement(DOM::Document& document, DOM::QualifiedNa HTMLDetailsElement::~HTMLDetailsElement() = default; +WebIDL::ExceptionOr HTMLDetailsElement::set_attribute(DeprecatedFlyString const& name, DeprecatedString const& value) +{ + auto result = HTMLElement::set_attribute(name, value); + if (result.is_exception()) + return result.exception(); + + if (name == HTML::AttributeNames::open) + run_details_notification_task_steps(); + + return result; +} + +void HTMLDetailsElement::remove_attribute(DeprecatedFlyString const& name) +{ + HTMLElement::remove_attribute(name); + + if (name == HTML::AttributeNames::open) + run_details_notification_task_steps(); +} + +// https://html.spec.whatwg.org/multipage/interactive-elements.html#the-details-element:details-notification-task-steps +void HTMLDetailsElement::run_details_notification_task_steps() +{ + // Whenever the open attribute is added to or removed from a details element, + // the user agent must queue an element task on the DOM manipulation task source given then details element that runs the following steps, + // which are known as the details notification task steps, for this details element: + queue_an_element_task(HTML::Task::Source::DOMManipulation, [this] { + // 1. FIXME: If another task has been queued to run the details notification task steps for this details element, then return. + + // 2. Fire an event named toggle at the details element. + dispatch_event(Web::DOM::Event::create(realm(), HTML::EventNames::toggle).release_value_but_fixme_should_propagate_errors()); + }); +} + JS::ThrowCompletionOr HTMLDetailsElement::initialize(JS::Realm& realm) { MUST_OR_THROW_OOM(Base::initialize(realm)); diff --git a/Userland/Libraries/LibWeb/HTML/HTMLDetailsElement.h b/Userland/Libraries/LibWeb/HTML/HTMLDetailsElement.h index 9f621f516c..15c0159e9c 100644 --- a/Userland/Libraries/LibWeb/HTML/HTMLDetailsElement.h +++ b/Userland/Libraries/LibWeb/HTML/HTMLDetailsElement.h @@ -20,6 +20,12 @@ public: // https://www.w3.org/TR/html-aria/#el-details virtual Optional default_role() const override { return ARIA::Role::group; }; + // ^Element + WebIDL::ExceptionOr set_attribute(DeprecatedFlyString const& name, DeprecatedString const& value) override; + void remove_attribute(DeprecatedFlyString const& name) override; + + void run_details_notification_task_steps(); + private: HTMLDetailsElement(DOM::Document&, DOM::QualifiedName); -- cgit v1.2.3