1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-26 07:27:45 +00:00

MouseSettings: Convert setting widgets to a failable factory

This commit is contained in:
Karol Kosek 2023-05-09 22:44:43 +02:00 committed by Andreas Kling
parent ab8be9aed5
commit 90819e2d71
6 changed files with 43 additions and 13 deletions

View file

@ -9,9 +9,16 @@
#include <Applications/MouseSettings/HighlightWidgetGML.h>
#include <LibGUI/ConnectionToWindowServer.h>
HighlightWidget::HighlightWidget()
ErrorOr<NonnullRefPtr<HighlightWidget>> HighlightWidget::try_create()
{
load_from_gml(highlight_widget_gml).release_value_but_fixme_should_propagate_errors();
auto widget = TRY(adopt_nonnull_ref_or_enomem(new (nothrow) HighlightWidget()));
TRY(widget->setup());
return widget;
}
ErrorOr<void> HighlightWidget::setup()
{
TRY(load_from_gml(highlight_widget_gml));
m_highlight_preview = find_descendant_of_type_named<GUI::Frame>("preview_frame")->add<MouseSettings::HighlightPreviewWidget>(palette());
@ -41,6 +48,7 @@ HighlightWidget::HighlightWidget()
m_highlight_preview->set_color(highlight_color());
m_highlight_preview->set_radius(highlight_radius());
return {};
}
Gfx::Color HighlightWidget::highlight_color()

View file

@ -13,19 +13,22 @@
#include <LibGUI/Window.h>
class HighlightWidget final : public GUI::SettingsWindow::Tab {
C_OBJECT(HighlightWidget)
C_OBJECT_ABSTRACT(HighlightWidget)
public:
static ErrorOr<NonnullRefPtr<HighlightWidget>> try_create();
virtual ~HighlightWidget() override = default;
virtual void apply_settings() override;
virtual void reset_default_values() override;
private:
HighlightWidget() = default;
ErrorOr<void> setup();
Gfx::Color highlight_color();
int highlight_radius();
HighlightWidget();
RefPtr<MouseSettings::HighlightPreviewWidget> m_highlight_preview;
RefPtr<GUI::ColorInput> m_highlight_color_input;
RefPtr<GUI::Slider> m_highlight_opacity_slider;

View file

@ -19,10 +19,16 @@ constexpr double speed_slider_scale = 100.0;
constexpr int default_scroll_length = 4;
constexpr int double_click_speed_default = 250;
MouseWidget::MouseWidget()
ErrorOr<NonnullRefPtr<MouseWidget>> MouseWidget::try_create()
{
load_from_gml(mouse_widget_gml).release_value_but_fixme_should_propagate_errors();
auto widget = TRY(adopt_nonnull_ref_or_enomem(new (nothrow) MouseWidget()));
TRY(widget->setup());
return widget;
}
ErrorOr<void> MouseWidget::setup()
{
TRY(load_from_gml(mouse_widget_gml));
m_speed_label = *find_descendant_of_type_named<GUI::Label>("speed_label");
m_speed_slider = *find_descendant_of_type_named<GUI::HorizontalSlider>("speed_slider");
m_speed_slider->set_range(WindowServer::mouse_accel_min * speed_slider_scale, WindowServer::mouse_accel_max * speed_slider_scale);
@ -70,6 +76,7 @@ MouseWidget::MouseWidget()
update_double_click_speed_label();
update_switch_buttons_image_label();
m_double_click_arrow_widget->set_double_click_speed(m_double_click_speed_slider->value());
return {};
}
void MouseWidget::apply_settings()

View file

@ -12,15 +12,17 @@
#include <LibGUI/Window.h>
class MouseWidget final : public GUI::SettingsWindow::Tab {
C_OBJECT(MouseWidget)
C_OBJECT_ABSTRACT(MouseWidget)
public:
static ErrorOr<NonnullRefPtr<MouseWidget>> try_create();
virtual ~MouseWidget() override = default;
virtual void apply_settings() override;
virtual void reset_default_values() override;
private:
MouseWidget();
MouseWidget() = default;
ErrorOr<void> setup();
void update_speed_label();
void update_double_click_speed_label();

View file

@ -97,9 +97,16 @@ void ThemeModel::invalidate()
Model::invalidate();
}
ThemeWidget::ThemeWidget()
ErrorOr<NonnullRefPtr<ThemeWidget>> ThemeWidget::try_create()
{
load_from_gml(theme_widget_gml).release_value_but_fixme_should_propagate_errors();
auto widget = TRY(adopt_nonnull_ref_or_enomem(new (nothrow) ThemeWidget()));
TRY(widget->setup());
return widget;
}
ErrorOr<void> ThemeWidget::setup()
{
TRY(load_from_gml(theme_widget_gml));
m_cursors_tableview = find_descendant_of_type_named<GUI::TableView>("cursors_tableview");
m_cursors_tableview->set_highlight_selected_rows(true);
m_cursors_tableview->set_alternating_row_colors(false);
@ -108,7 +115,7 @@ ThemeWidget::ThemeWidget()
m_cursors_tableview->set_highlight_key_column(false);
m_mouse_cursor_model = MouseCursorModel::create();
auto sorting_proxy_model = MUST(GUI::SortingProxyModel::create(*m_mouse_cursor_model));
auto sorting_proxy_model = TRY(GUI::SortingProxyModel::create(*m_mouse_cursor_model));
sorting_proxy_model->set_sort_role(GUI::ModelRole::Display);
m_cursors_tableview->set_model(sorting_proxy_model);
@ -127,6 +134,7 @@ ThemeWidget::ThemeWidget()
m_theme_name_box->set_model(ThemeModel::create());
m_theme_name_box->model()->invalidate();
m_theme_name_box->set_text(theme_name, GUI::AllowCallback::No);
return {};
}
void ThemeWidget::apply_settings()

View file

@ -63,15 +63,17 @@ private:
};
class ThemeWidget final : public GUI::SettingsWindow::Tab {
C_OBJECT(ThemeWidget)
C_OBJECT_ABSTRACT(ThemeWidget)
public:
static ErrorOr<NonnullRefPtr<ThemeWidget>> try_create();
virtual ~ThemeWidget() override = default;
virtual void apply_settings() override;
virtual void reset_default_values() override;
private:
ThemeWidget();
ThemeWidget() = default;
ErrorOr<void> setup();
RefPtr<GUI::TableView> m_cursors_tableview;
RefPtr<GUI::ComboBox> m_theme_name_box;