mirror of
https://github.com/RGBCube/serenity
synced 2025-06-01 10:18:13 +00:00
LibGUI: Convert AboutDialog layout to GML
This commit is contained in:
parent
c2082b45ee
commit
65c8dfe923
3 changed files with 99 additions and 44 deletions
|
@ -1,12 +1,14 @@
|
|||
/*
|
||||
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
||||
* Copyright (c) 2022, the SerenityOS developers.
|
||||
* Copyright (c) 2023, Sam Atkins <atkinssj@serenityos.org>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <AK/StringBuilder.h>
|
||||
#include <LibGUI/AboutDialog.h>
|
||||
#include <LibGUI/AboutDialogGML.h>
|
||||
#include <LibGUI/BoxLayout.h>
|
||||
#include <LibGUI/Button.h>
|
||||
#include <LibGUI/ImageWidget.h>
|
||||
|
@ -31,56 +33,24 @@ AboutDialog::AboutDialog(StringView name, StringView version, Gfx::Bitmap const*
|
|||
set_icon(parent_window->icon());
|
||||
|
||||
auto widget = set_main_widget<Widget>().release_value_but_fixme_should_propagate_errors();
|
||||
widget->set_fill_with_background_color(true);
|
||||
widget->set_layout<VerticalBoxLayout>();
|
||||
widget->layout()->set_spacing(0);
|
||||
|
||||
auto& banner_image = widget->add<GUI::ImageWidget>();
|
||||
banner_image.load_from_file("/res/graphics/brand-banner.png"sv);
|
||||
|
||||
auto& content_container = widget->add<Widget>();
|
||||
content_container.set_layout<HorizontalBoxLayout>();
|
||||
|
||||
auto& left_container = content_container.add<Widget>();
|
||||
left_container.set_fixed_width(60);
|
||||
left_container.set_layout<VerticalBoxLayout>();
|
||||
left_container.layout()->set_margins({ 12, 0, 0 });
|
||||
widget->load_from_gml(about_dialog_gml).release_value_but_fixme_should_propagate_errors();
|
||||
|
||||
auto icon_wrapper = find_descendant_of_type_named<Widget>("icon_wrapper");
|
||||
if (icon) {
|
||||
auto& icon_wrapper = left_container.add<Widget>();
|
||||
icon_wrapper.set_fixed_size(32, 48);
|
||||
icon_wrapper.set_layout<VerticalBoxLayout>();
|
||||
|
||||
auto& icon_image = icon_wrapper.add<ImageWidget>();
|
||||
icon_image.set_bitmap(m_icon);
|
||||
icon_wrapper->set_visible(true);
|
||||
auto icon_image = find_descendant_of_type_named<ImageWidget>("icon");
|
||||
icon_image->set_bitmap(m_icon);
|
||||
} else {
|
||||
icon_wrapper->set_visible(false);
|
||||
}
|
||||
|
||||
auto& right_container = content_container.add<Widget>();
|
||||
right_container.set_layout<VerticalBoxLayout>();
|
||||
right_container.layout()->set_margins({ 12, 4, 4, 0 });
|
||||
|
||||
auto make_label = [&](StringView text, bool bold = false) {
|
||||
auto& label = right_container.add<Label>(text);
|
||||
label.set_text_alignment(Gfx::TextAlignment::CenterLeft);
|
||||
label.set_fixed_height(14);
|
||||
if (bold)
|
||||
label.set_font(Gfx::FontDatabase::default_font().bold_variant());
|
||||
};
|
||||
make_label(m_name, true);
|
||||
find_descendant_of_type_named<GUI::Label>("name")->set_text(m_name);
|
||||
// If we are displaying a dialog for an application, insert 'SerenityOS' below the application name
|
||||
if (m_name != "SerenityOS")
|
||||
make_label("SerenityOS"sv);
|
||||
make_label(m_version_string);
|
||||
make_label("Copyright \xC2\xA9 the SerenityOS developers, 2018-2023"sv);
|
||||
find_descendant_of_type_named<GUI::Label>("serenity_os")->set_visible(m_name != "SerenityOS");
|
||||
find_descendant_of_type_named<GUI::Label>("version")->set_text(m_version_string);
|
||||
|
||||
right_container.layout()->add_spacer();
|
||||
|
||||
auto& button_container = right_container.add<Widget>();
|
||||
button_container.set_fixed_height(22);
|
||||
button_container.set_layout<HorizontalBoxLayout>();
|
||||
button_container.layout()->add_spacer();
|
||||
auto& ok_button = button_container.add<DialogButton>("OK");
|
||||
ok_button.on_click = [this](auto) {
|
||||
auto ok_button = find_descendant_of_type_named<DialogButton>("ok_button");
|
||||
ok_button->on_click = [this](auto) {
|
||||
done(ExecResult::OK);
|
||||
};
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue