mirror of
https://github.com/RGBCube/serenity
synced 2025-06-25 09:32:08 +00:00
LibGUI: Show radio buttons for checkable actions in CommandPalette
This patch adds a painting delegate to the icon column of CommandPalette to show a radio button in case an action is checkable and does not explicitly have an icon :^)
This commit is contained in:
parent
b67d4ab52f
commit
fcd97a3e19
1 changed files with 24 additions and 0 deletions
|
@ -1,5 +1,6 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2022, Andreas Kling <kling@serenityos.org>
|
* Copyright (c) 2022, Andreas Kling <kling@serenityos.org>
|
||||||
|
* Copyright (c) 2022, Jakob-Niklas See <git@nwex.de>
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
*/
|
*/
|
||||||
|
@ -11,6 +12,7 @@
|
||||||
#include <LibGUI/CommandPalette.h>
|
#include <LibGUI/CommandPalette.h>
|
||||||
#include <LibGUI/FilteringProxyModel.h>
|
#include <LibGUI/FilteringProxyModel.h>
|
||||||
#include <LibGUI/Model.h>
|
#include <LibGUI/Model.h>
|
||||||
|
#include <LibGUI/Painter.h>
|
||||||
#include <LibGUI/TableView.h>
|
#include <LibGUI/TableView.h>
|
||||||
#include <LibGUI/TextBox.h>
|
#include <LibGUI/TextBox.h>
|
||||||
#include <LibGUI/Widget.h>
|
#include <LibGUI/Widget.h>
|
||||||
|
@ -18,6 +20,25 @@
|
||||||
|
|
||||||
namespace GUI {
|
namespace GUI {
|
||||||
|
|
||||||
|
class IconOrRadioButtonDelegate final : public GUI::TableCellPaintingDelegate {
|
||||||
|
public:
|
||||||
|
virtual ~IconOrRadioButtonDelegate() override { }
|
||||||
|
|
||||||
|
bool should_paint(ModelIndex const& index) override
|
||||||
|
{
|
||||||
|
return index.data().is_bool();
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void paint(GUI::Painter& painter, Gfx::IntRect const& cell_rect, Gfx::Palette const& palette, ModelIndex const& index) override
|
||||||
|
{
|
||||||
|
auto checked = index.data().as_bool();
|
||||||
|
|
||||||
|
Gfx::IntRect radio_rect { 0, 0, 12, 12 };
|
||||||
|
radio_rect.center_within(cell_rect);
|
||||||
|
Gfx::StylePainter::paint_radio_button(painter, radio_rect, palette, checked, false);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
class ActionModel final : public GUI::Model {
|
class ActionModel final : public GUI::Model {
|
||||||
public:
|
public:
|
||||||
enum Column {
|
enum Column {
|
||||||
|
@ -64,6 +85,8 @@ public:
|
||||||
case Column::Icon:
|
case Column::Icon:
|
||||||
if (action.icon())
|
if (action.icon())
|
||||||
return *action.icon();
|
return *action.icon();
|
||||||
|
if (action.is_checkable())
|
||||||
|
return action.is_checked();
|
||||||
return "";
|
return "";
|
||||||
case Column::Text:
|
case Column::Text:
|
||||||
return Gfx::parse_ampersand_string(action.text());
|
return Gfx::parse_ampersand_string(action.text());
|
||||||
|
@ -112,6 +135,7 @@ CommandPalette::CommandPalette(GUI::Window& parent_window, ScreenPosition screen
|
||||||
m_filter_model = MUST(GUI::FilteringProxyModel::create(*m_model));
|
m_filter_model = MUST(GUI::FilteringProxyModel::create(*m_model));
|
||||||
m_filter_model->set_filter_term("");
|
m_filter_model->set_filter_term("");
|
||||||
|
|
||||||
|
m_table_view->set_column_painting_delegate(0, make<IconOrRadioButtonDelegate>());
|
||||||
m_table_view->set_model(*m_filter_model);
|
m_table_view->set_model(*m_filter_model);
|
||||||
|
|
||||||
m_text_box->on_change = [this] {
|
m_text_box->on_change = [this] {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue