ladybird/Libraries/LibWeb/Layout/RadioButton.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

27 lines
677 B
C++

/*
* Copyright (c) 2021, Tim Flynn <trflynn89@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibWeb/Forward.h>
#include <LibWeb/Layout/ReplacedBox.h>
namespace Web::Layout {
class RadioButton final : public ReplacedBox {
GC_CELL(RadioButton, ReplacedBox);
GC_DECLARE_ALLOCATOR(RadioButton);
public:
RadioButton(DOM::Document&, HTML::HTMLInputElement&, GC::Ref<CSS::ComputedProperties>);
virtual ~RadioButton() override;
private:
CSS::SizeWithAspectRatio compute_auto_content_box_size() const override { return { 12, 12, {} }; }
virtual GC::Ptr<Painting::Paintable> create_paintable() const override;
};
}