ladybird/Libraries/LibWeb/HTML/HTMLLabelElement.h
Zaggy1024 44ed698d4f LibWeb: Separate the active element and the element being activated
We were conflating elements being the active element and elements being
activated. The :active pseudo class is supposed to be based on whether
an element will have its activation behavior run upon a button being
released.

Store whether an element is being activated as a flag that is set/reset
by EventHandler.

Doing this allows label elements to visually activate their control
without doing a weird paintable hack, so the Labelable classes have
been yeeted.
2026-03-17 04:01:29 -05:00

38 lines
897 B
C++

/*
* Copyright (c) 2020, the SerenityOS developers.
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibWeb/HTML/HTMLElement.h>
namespace Web::HTML {
class HTMLLabelElement final : public HTMLElement {
WEB_PLATFORM_OBJECT(HTMLLabelElement, HTMLElement);
GC_DECLARE_ALLOCATOR(HTMLLabelElement);
public:
virtual ~HTMLLabelElement() override;
Optional<String> for_() const { return attribute(HTML::AttributeNames::for_); }
GC::Ptr<HTMLElement> control() const;
GC::Ptr<HTMLFormElement> form() const;
virtual void set_being_activated(bool) override;
private:
HTMLLabelElement(DOM::Document&, DOM::QualifiedName);
virtual void initialize(JS::Realm&) override;
virtual bool has_activation_behavior() const override;
virtual void activation_behavior(DOM::Event const&) override;
bool m_click_in_progress { false };
};
}