Files
ladybird/Libraries/LibWeb/Painting/RadioButtonPaintable.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

28 lines
616 B
C++

/*
* Copyright (c) 2022, Andreas Kling <andreas@ladybird.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibWeb/Forward.h>
#include <LibWeb/Painting/PaintableBox.h>
namespace Web::Painting {
class RadioButtonPaintable final : public PaintableBox {
GC_CELL(RadioButtonPaintable, PaintableBox);
GC_DECLARE_ALLOCATOR(RadioButtonPaintable);
public:
static GC::Ref<RadioButtonPaintable> create(Layout::RadioButton const&);
virtual void paint(DisplayListRecordingContext&, PaintPhase) const override;
private:
RadioButtonPaintable(Layout::RadioButton const&);
};
}