1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-28 19:17:44 +00:00

LibGUI+WindowServer: Add menu minimum width support

This commit is contained in:
Bastiaan van der Plaat 2024-01-25 18:57:37 +01:00 committed by Andrew Kaster
parent adc845e0cb
commit 350affe406
8 changed files with 56 additions and 10 deletions

View file

@ -90,9 +90,9 @@ void ConnectionFromClient::notify_about_new_screen_rects()
async_screen_rects_changed(Screen::rects(), Screen::main().index(), wm.window_stack_rows(), wm.window_stack_columns());
}
void ConnectionFromClient::create_menu(i32 menu_id, String const& name)
void ConnectionFromClient::create_menu(i32 menu_id, String const& name, i32 minimum_width)
{
auto menu = Menu::construct(this, menu_id, name);
auto menu = Menu::construct(this, menu_id, name, minimum_width);
m_menus.set(menu_id, move(menu));
}
@ -117,6 +117,27 @@ void ConnectionFromClient::set_menu_name(i32 menu_id, String const& name)
}
}
void ConnectionFromClient::set_menu_minimum_width(i32 menu_id, i32 minimum_width)
{
auto it = m_menus.find(menu_id);
if (it == m_menus.end()) {
did_misbehave("DestroyMenu: Bad menu ID");
return;
}
auto& menu = *it->value;
menu.set_minimum_width(minimum_width);
for (auto& it : m_windows) {
auto& window = *it.value;
window.menubar().for_each_menu([&](Menu& other_menu) {
if (&menu == &other_menu) {
window.invalidate_menubar();
return IterationDecision::Break;
}
return IterationDecision::Continue;
});
}
}
void ConnectionFromClient::destroy_menu(i32 menu_id)
{
auto it = m_menus.find(menu_id);

View file

@ -93,8 +93,9 @@ private:
void set_unresponsive(bool);
void destroy_window(Window&, Vector<i32>& destroyed_window_ids);
virtual void create_menu(i32, String const&) override;
virtual void create_menu(i32, String const&, i32) override;
virtual void set_menu_name(i32, String const&) override;
virtual void set_menu_minimum_width(i32, i32) override;
virtual void destroy_menu(i32) override;
virtual void add_menu(i32, i32) override;
virtual void add_menu_item(i32, i32, i32, ByteString const&, bool, bool, bool, bool, bool, ByteString const&, Gfx::ShareableBitmap const&, bool) override;

View file

@ -38,11 +38,12 @@ u32 find_ampersand_shortcut_character(StringView string)
return 0;
}
Menu::Menu(ConnectionFromClient* client, int menu_id, String name)
Menu::Menu(ConnectionFromClient* client, int menu_id, String name, int minimum_width)
: Core::EventReceiver(client)
, m_client(client)
, m_menu_id(menu_id)
, m_name(move(name))
, m_minimum_width(minimum_width)
{
m_alt_shortcut_character = find_ampersand_shortcut_character(m_name);
}
@ -90,7 +91,7 @@ int Menu::content_width() const
if (widest_shortcut)
widest_item += padding_between_text_and_shortcut() + widest_shortcut;
return max(widest_item, rect_in_window_menubar().width()) + horizontal_padding() + frame_thickness() * 2;
return max(m_minimum_width, max(widest_item, rect_in_window_menubar().width()) + horizontal_padding() + frame_thickness() * 2);
}
int Menu::item_height() const
@ -770,6 +771,11 @@ void Menu::set_name(String name)
m_name = move(name);
}
void Menu::set_minimum_width(int minimum_width)
{
m_minimum_width = minimum_width;
}
bool Menu::is_open() const
{
return MenuManager::the().is_open(*this);

View file

@ -61,6 +61,9 @@ public:
String const& name() const { return m_name; }
void set_name(String);
int minimum_width() const { return m_minimum_width; }
void set_minimum_width(int);
template<typename Callback>
IterationDecision for_each_item(Callback callback)
{
@ -138,7 +141,7 @@ public:
Vector<size_t> const* items_with_alt_shortcut(u32 alt_shortcut) const;
private:
Menu(ConnectionFromClient*, int menu_id, String name);
Menu(ConnectionFromClient*, int menu_id, String name, int minimum_width = 0);
virtual void event(Core::Event&) override;
@ -156,6 +159,7 @@ private:
ConnectionFromClient* m_client { nullptr };
int m_menu_id { 0 };
String m_name;
int m_minimum_width { 0 };
u32 m_alt_shortcut_character { 0 };
Gfx::IntRect m_rect_in_window_menubar;
Gfx::IntPoint m_unadjusted_position;

View file

@ -4,8 +4,9 @@
endpoint WindowServer
{
create_menu(i32 menu_id, [UTF8] String name) =|
create_menu(i32 menu_id, [UTF8] String name, i32 minimum_width) =|
set_menu_name(i32 menu_id, String name) =|
set_menu_minimum_width(i32 menu_id, i32 minimum_width) =|
destroy_menu(i32 menu_id) =|
add_menu(i32 window_id, i32 menu_id) =|