summaryrefslogtreecommitdiff
path: root/Userland/Libraries/LibGUI
diff options
context:
space:
mode:
authorTimothy Flynn <trflynn89@pm.me>2022-09-01 09:09:51 -0400
committerLinus Groh <mail@linusgroh.de>2022-09-07 14:34:02 +0100
commit3aaaacdb3ac38d64c879791ffe084486c5e5e3af (patch)
treea0883c1216014dd82a90927a87481e7282dc666d /Userland/Libraries/LibGUI
parent11d29bc2ead1aa60e54774c0e7fa9796acad518c (diff)
downloadserenity-3aaaacdb3ac38d64c879791ffe084486c5e5e3af.zip
LibGUI: Wrap the EmojiInputDialog in a scrollable container
This will prevent the dialog from growing endlessly as emoji are added.
Diffstat (limited to 'Userland/Libraries/LibGUI')
-rw-r--r--Userland/Libraries/LibGUI/EmojiInputDialog.cpp12
-rw-r--r--Userland/Libraries/LibGUI/EmojiInputDialog.gml9
2 files changed, 12 insertions, 9 deletions
diff --git a/Userland/Libraries/LibGUI/EmojiInputDialog.cpp b/Userland/Libraries/LibGUI/EmojiInputDialog.cpp
index 145461fda1..98d6eb797d 100644
--- a/Userland/Libraries/LibGUI/EmojiInputDialog.cpp
+++ b/Userland/Libraries/LibGUI/EmojiInputDialog.cpp
@@ -15,6 +15,7 @@
#include <LibGUI/EmojiInputDialogGML.h>
#include <LibGUI/Event.h>
#include <LibGUI/Frame.h>
+#include <LibGUI/ScrollableContainerWidget.h>
#include <stdlib.h>
namespace GUI {
@@ -47,6 +48,10 @@ EmojiInputDialog::EmojiInputDialog(Window* parent_window)
if (!main_widget.load_from_gml(emoji_input_dialog_gml))
VERIFY_NOT_REACHED();
+ set_frameless(true);
+ resize(400, 300);
+
+ auto& scrollable_container = *main_widget.find_descendant_of_type_named<GUI::ScrollableContainerWidget>("scrollable_container"sv);
auto& emojis_widget = *main_widget.find_descendant_of_type_named<GUI::Widget>("emojis"sv);
auto code_points = supported_emoji_code_points();
@@ -55,13 +60,8 @@ EmojiInputDialog::EmojiInputDialog(Window* parent_window)
size_t rows = ceil_div(code_points.size(), columns);
constexpr int button_size = 20;
- // FIXME: I have no idea why this is needed, you'd think that button width * number of buttons would make them fit, but the last one gets cut off.
- constexpr int magic_offset = 7;
- int dialog_width = button_size * columns + magic_offset;
- int dialog_height = button_size * rows;
- resize(dialog_width, dialog_height);
- set_frameless(true);
+ scrollable_container.horizontal_scrollbar().set_visible(false);
for (size_t row = 0; row < rows && index < code_points.size(); ++row) {
auto& horizontal_container = emojis_widget.add<Widget>();
diff --git a/Userland/Libraries/LibGUI/EmojiInputDialog.gml b/Userland/Libraries/LibGUI/EmojiInputDialog.gml
index 34a70b9068..132e54880b 100644
--- a/Userland/Libraries/LibGUI/EmojiInputDialog.gml
+++ b/Userland/Libraries/LibGUI/EmojiInputDialog.gml
@@ -6,8 +6,11 @@
margins: [4]
}
- @GUI::Widget {
- name: "emojis"
- layout: @GUI::VerticalBoxLayout {}
+ @GUI::ScrollableContainerWidget {
+ name: "scrollable_container"
+ content_widget: @GUI::Widget {
+ name: "emojis"
+ layout: @GUI::VerticalBoxLayout {}
+ }
}
}