mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 16:17:45 +00:00
WindowServer: Move menu related code from WindowManager to MenuManager
Menus are now owned by menu manager instead of being split between the window manager and menu manager. If the window server wants to change a menu, or call menu related functionality, this will need to be done through the menu manager. Further refactoring is likely needed, but this seems like a good start for seperating menu logic from window logic.
This commit is contained in:
parent
adff54879c
commit
7557251fac
8 changed files with 250 additions and 242 deletions
|
@ -1,6 +1,8 @@
|
|||
#pragma once
|
||||
|
||||
#include "WSMenu.h"
|
||||
#include "WSMenuBar.h"
|
||||
#include <AK/HashMap.h>
|
||||
#include <LibCore/CObject.h>
|
||||
#include <WindowServer/WSWindow.h>
|
||||
|
||||
|
@ -29,6 +31,10 @@ public:
|
|||
WSMenu* current_menu() { return m_current_menu.ptr(); }
|
||||
void set_current_menu(WSMenu*, bool is_submenu = false);
|
||||
|
||||
WSMenuBar* current_menubar() { return m_current_menubar.ptr(); }
|
||||
void set_current_menubar(WSMenuBar*);
|
||||
void close_menubar(WSMenuBar&);
|
||||
|
||||
void close_bar();
|
||||
void close_everyone();
|
||||
void close_everyone_not_in_lineage(WSMenu&);
|
||||
|
@ -40,6 +46,20 @@ public:
|
|||
void remove_applet(WSWindow&);
|
||||
void invalidate_applet(const WSWindow&, const Rect&);
|
||||
|
||||
Color menu_selection_color() const { return m_menu_selection_color; }
|
||||
WSMenu* system_menu() { return m_system_menu; }
|
||||
WSMenu* find_internal_menu_by_id(int);
|
||||
int theme_index() const { return m_theme_index; }
|
||||
|
||||
template<typename Callback>
|
||||
void for_each_active_menubar_menu(Callback callback)
|
||||
{
|
||||
if (callback(*system_menu()) == IterationDecision::Break)
|
||||
return;
|
||||
if (m_current_menubar)
|
||||
m_current_menubar->for_each_menu(callback);
|
||||
}
|
||||
|
||||
private:
|
||||
void close_menus(const Vector<WSMenu*>&);
|
||||
|
||||
|
@ -64,4 +84,28 @@ private:
|
|||
|
||||
bool m_needs_window_resize { false };
|
||||
bool m_bar_open { false };
|
||||
|
||||
struct AppMetadata {
|
||||
String executable;
|
||||
String name;
|
||||
String icon_path;
|
||||
String category;
|
||||
};
|
||||
Vector<AppMetadata> m_apps;
|
||||
|
||||
HashMap<String, NonnullRefPtr<WSMenu>> m_app_category_menus;
|
||||
|
||||
struct ThemeMetadata {
|
||||
String name;
|
||||
String path;
|
||||
};
|
||||
|
||||
RefPtr<WSMenu> m_system_menu;
|
||||
Color m_menu_selection_color;
|
||||
|
||||
int m_theme_index { 0 };
|
||||
Vector<ThemeMetadata> m_themes;
|
||||
RefPtr<WSMenu> m_themes_menu;
|
||||
|
||||
WeakPtr<WSMenuBar> m_current_menubar;
|
||||
};
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue