mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 05:28:11 +00:00
WindowServer: Move some menu related code into MenuManager
Shuffle around some menu related code from window manager into menu manager. This still is not perfect, and results in a little more of the window manager to be publically exposed - but this is another step towards better seperation of concerns between menu and window manager. We also move the mouse_event handling into a new function in menu manager as event handling was beginning to become a bit chunky.
This commit is contained in:
parent
24dfc5051a
commit
91a97f7a42
4 changed files with 74 additions and 64 deletions
|
@ -732,58 +732,11 @@ void WindowManager::process_mouse_event(MouseEvent& event, Window*& hovered_wind
|
|||
}
|
||||
|
||||
// FIXME: Now that the menubar has a dedicated window, is this special-casing really necessary?
|
||||
if (!active_window_is_modal() && menubar_rect().contains(event.position())) {
|
||||
if (!MenuManager::the().open_menu_stack().is_empty() || (!active_window_is_modal() && menubar_rect().contains(event.position()))) {
|
||||
MenuManager::the().dispatch_event(event);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!MenuManager::the().open_menu_stack().is_empty()) {
|
||||
auto* topmost_menu = MenuManager::the().open_menu_stack().last().ptr();
|
||||
ASSERT(topmost_menu);
|
||||
auto* window = topmost_menu->menu_window();
|
||||
ASSERT(window);
|
||||
|
||||
bool event_is_inside_current_menu = window->rect().contains(event.position());
|
||||
if (event_is_inside_current_menu) {
|
||||
hovered_window = window;
|
||||
auto translated_event = event.translated(-window->position());
|
||||
deliver_mouse_event(*window, translated_event);
|
||||
return;
|
||||
}
|
||||
|
||||
if (topmost_menu->hovered_item())
|
||||
topmost_menu->clear_hovered_item();
|
||||
if (event.type() == Event::MouseDown || event.type() == Event::MouseUp) {
|
||||
auto* window_menu_of = topmost_menu->window_menu_of();
|
||||
if (window_menu_of) {
|
||||
bool event_is_inside_taskbar_button = window_menu_of->taskbar_rect().contains(event.position());
|
||||
if (event_is_inside_taskbar_button && !topmost_menu->is_window_menu_open()) {
|
||||
topmost_menu->set_window_menu_open(true);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (event.type() == Event::MouseDown) {
|
||||
MenuManager::the().close_bar();
|
||||
topmost_menu->set_window_menu_open(false);
|
||||
}
|
||||
}
|
||||
|
||||
if (event.type() == Event::MouseMove) {
|
||||
for (auto& menu : MenuManager::the().open_menu_stack()) {
|
||||
if (!menu)
|
||||
continue;
|
||||
if (!menu->menu_window()->rect().contains(event.position()))
|
||||
continue;
|
||||
hovered_window = menu->menu_window();
|
||||
auto translated_event = event.translated(-menu->menu_window()->position());
|
||||
deliver_mouse_event(*menu->menu_window(), translated_event);
|
||||
break;
|
||||
}
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
Window* event_window_with_frame = nullptr;
|
||||
|
||||
if (m_active_input_window) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue