diff options
author | thankyouverycool <66646555+thankyouverycool@users.noreply.github.com> | 2023-04-16 16:02:29 -0400 |
---|---|---|
committer | Andreas Kling <kling@serenityos.org> | 2023-04-18 10:05:21 +0200 |
commit | 7c314f38554ab95e0380cced9cf352b606391f96 (patch) | |
tree | d4d9a957557420dc6a373dfa2dfe843e61449b0f /Userland/Libraries/LibGUI | |
parent | 02a9e5d3f681bbf3c6157d368e95ad3183b200be (diff) | |
download | serenity-7c314f38554ab95e0380cced9cf352b606391f96.zip |
LibGUI: Let InputBox display an ImageWidget
InputBox can now be given a bitmap to display alongside its
prompt and editor. Prompts are now optional to allow for
compact dialogs.
Diffstat (limited to 'Userland/Libraries/LibGUI')
-rw-r--r-- | Userland/Libraries/LibGUI/InputBox.cpp | 44 | ||||
-rw-r--r-- | Userland/Libraries/LibGUI/InputBox.h | 10 |
2 files changed, 38 insertions, 16 deletions
diff --git a/Userland/Libraries/LibGUI/InputBox.cpp b/Userland/Libraries/LibGUI/InputBox.cpp index 85e5e93353..9bcb68f2bf 100644 --- a/Userland/Libraries/LibGUI/InputBox.cpp +++ b/Userland/Libraries/LibGUI/InputBox.cpp @@ -8,38 +8,40 @@ #include <LibGUI/BoxLayout.h> #include <LibGUI/Button.h> +#include <LibGUI/ImageWidget.h> #include <LibGUI/InputBox.h> #include <LibGUI/Label.h> #include <LibGUI/TextBox.h> namespace GUI { -ErrorOr<NonnullRefPtr<InputBox>> InputBox::create(Window* parent_window, String text_value, StringView prompt, StringView title, InputType input_type) +ErrorOr<NonnullRefPtr<InputBox>> InputBox::create(Window* parent_window, String text_value, StringView prompt, StringView title, InputType input_type, RefPtr<Gfx::Bitmap const> icon) { - auto box = TRY(adopt_nonnull_ref_or_enomem(new (nothrow) InputBox(parent_window, text_value, TRY(String::from_utf8(title)), TRY(String::from_utf8(prompt)), input_type))); + auto box = TRY(adopt_nonnull_ref_or_enomem(new (nothrow) InputBox(parent_window, text_value, TRY(String::from_utf8(title)), TRY(String::from_utf8(prompt)), input_type, move(icon)))); TRY(box->build()); return box; } -InputBox::InputBox(Window* parent_window, String text_value, String title, String prompt, InputType input_type) +InputBox::InputBox(Window* parent_window, String text_value, String title, String prompt, InputType input_type, RefPtr<Gfx::Bitmap const> icon) : Dialog(parent_window) , m_text_value(move(text_value)) , m_prompt(move(prompt)) , m_input_type(input_type) + , m_icon(move(icon)) { set_title(move(title).to_deprecated_string()); set_resizable(false); set_auto_shrink(true); } -Dialog::ExecResult InputBox::show(Window* parent_window, String& text_value, StringView prompt, StringView title, InputType input_type, StringView placeholder) +Dialog::ExecResult InputBox::show(Window* parent_window, String& text_value, StringView prompt, StringView title, InputType input_type, StringView placeholder, RefPtr<Gfx::Bitmap const> icon) { - return MUST(try_show(parent_window, text_value, prompt, title, input_type, placeholder)); + return MUST(try_show(parent_window, text_value, prompt, title, input_type, placeholder, move(icon))); } -ErrorOr<Dialog::ExecResult> InputBox::try_show(Window* parent_window, String& text_value, StringView prompt, StringView title, InputType input_type, StringView placeholder) +ErrorOr<Dialog::ExecResult> InputBox::try_show(Window* parent_window, String& text_value, StringView prompt, StringView title, InputType input_type, StringView placeholder, RefPtr<Gfx::Bitmap const> icon) { - auto box = TRY(InputBox::create(parent_window, text_value, prompt, title, input_type)); + auto box = TRY(InputBox::create(parent_window, text_value, prompt, title, input_type, move(icon))); if (parent_window) box->set_icon(parent_window->icon()); box->set_placeholder(placeholder); @@ -86,15 +88,29 @@ ErrorOr<void> InputBox::build() TRY(main_widget->try_set_layout<VerticalBoxLayout>(4, 6)); main_widget->set_fill_with_background_color(true); - auto input_container = TRY(main_widget->try_add<Widget>()); - input_container->set_layout<HorizontalBoxLayout>(); + auto top_container = TRY(main_widget->try_add<Widget>()); + TRY(top_container->try_set_layout<HorizontalBoxLayout>(0, 8)); - m_prompt_label = TRY(input_container->try_add<Label>()); - m_prompt_label->set_autosize(true); - m_prompt_label->set_text(move(m_prompt).to_deprecated_string()); + if (m_icon) { + auto image_widget = TRY(top_container->try_add<ImageWidget>()); + image_widget->set_bitmap(m_icon); + } + auto input_container = TRY(top_container->try_add<Widget>()); + auto orientation = m_icon ? Gfx::Orientation::Vertical : Gfx::Orientation::Horizontal; + TRY(input_container->try_set_layout<BoxLayout>(orientation)); TRY(input_container->add_spacer()); + if (!m_prompt.is_empty()) { + m_label_container = TRY(input_container->try_add<Widget>()); + TRY(m_label_container->try_set_layout<HorizontalBoxLayout>()); + m_prompt_label = TRY(m_label_container->try_add<Label>()); + m_prompt_label->set_autosize(true); + m_prompt_label->set_text_wrapping(Gfx::TextWrapping::DontWrap); + m_prompt_label->set_text_alignment(Gfx::TextAlignment::CenterLeft); + m_prompt_label->set_text(move(m_prompt).to_deprecated_string()); + } + switch (m_input_type) { case InputType::Text: case InputType::NonemptyText: @@ -105,6 +121,8 @@ ErrorOr<void> InputBox::build() break; } + TRY(input_container->add_spacer()); + auto button_container = TRY(main_widget->try_add<Widget>()); TRY(button_container->try_set_layout<HorizontalBoxLayout>(0, 6)); TRY(button_container->add_spacer()); @@ -119,6 +137,8 @@ ErrorOr<void> InputBox::build() auto resize_editor = [this, button_container] { auto width = button_container->effective_min_size().width().as_int(); m_text_editor->set_min_width(width); + if (!m_icon && m_label_container) + m_label_container->set_fixed_width(m_prompt_label->max_width()); }; resize_editor(); on_font_change = [resize_editor] { resize_editor(); }; diff --git a/Userland/Libraries/LibGUI/InputBox.h b/Userland/Libraries/LibGUI/InputBox.h index a1c5017516..8441a0faef 100644 --- a/Userland/Libraries/LibGUI/InputBox.h +++ b/Userland/Libraries/LibGUI/InputBox.h @@ -23,9 +23,9 @@ class InputBox : public Dialog { public: virtual ~InputBox() override = default; - static ExecResult show(Window* parent_window, String& text_value, StringView prompt, StringView title, InputType input_type = InputType::Text, StringView placeholder = {}); - static ErrorOr<ExecResult> try_show(Window* parent_window, String& text_value, StringView prompt, StringView title, InputType input_type = InputType::Text, StringView placeholder = {}); - static ErrorOr<NonnullRefPtr<InputBox>> create(Window* parent_window, String text_value, StringView prompt, StringView title, InputType input_type); + static ExecResult show(Window* parent_window, String& text_value, StringView prompt, StringView title, InputType input_type = InputType::Text, StringView placeholder = {}, RefPtr<Gfx::Bitmap const> icon = nullptr); + static ErrorOr<ExecResult> try_show(Window* parent_window, String& text_value, StringView prompt, StringView title, InputType input_type = InputType::Text, StringView placeholder = {}, RefPtr<Gfx::Bitmap const> icon = nullptr); + static ErrorOr<NonnullRefPtr<InputBox>> create(Window* parent_window, String text_value, StringView prompt, StringView title, InputType input_type, RefPtr<Gfx::Bitmap const> icon = nullptr); String const& text_value() const { return m_text_value; } void set_text_value(String); @@ -33,7 +33,7 @@ public: void set_placeholder(StringView); private: - InputBox(Window* parent_window, String text_value, String title, String prompt, InputType input_type); + InputBox(Window* parent_window, String text_value, String title, String prompt, InputType input_type, RefPtr<Gfx::Bitmap const> icon); virtual void on_done(ExecResult) override; ErrorOr<void> build(); @@ -46,6 +46,8 @@ private: RefPtr<Button> m_cancel_button; RefPtr<TextEditor> m_text_editor; RefPtr<Label> m_prompt_label; + RefPtr<Widget> m_label_container; + RefPtr<Gfx::Bitmap const> m_icon; }; } |