mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-01-23 01:32:14 -05:00
WindowServer: Fix traversing modal stack
When walking the modal window stack upwards, we need to check if the top modal window is still a descendant of the window that the parent is blocked by. Fixes not all windows being brought to the front when trying to active a parent in the middle of the modal window stack.
This commit is contained in:
parent
e50874621a
commit
603c17262c
Notes:
sideshowbarker
2024-07-19 04:45:20 +09:00
Author: https://github.com/tomuta Commit: https://github.com/SerenityOS/serenity/commit/603c17262c7 Pull-request: https://github.com/SerenityOS/serenity/pull/2822
3 changed files with 17 additions and 1 deletions
|
@ -634,4 +634,17 @@ void Window::set_progress(int progress)
|
|||
WindowManager::the().notify_progress_changed(*this);
|
||||
}
|
||||
|
||||
bool Window::is_descendant_of(Window& window) const
|
||||
{
|
||||
for (auto* parent = parent_window(); parent; parent = parent->parent_window()) {
|
||||
if (parent == &window)
|
||||
return true;
|
||||
for (auto& accessory : parent->accessory_windows()) {
|
||||
if (accessory == &window)
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -244,6 +244,8 @@ public:
|
|||
Vector<WeakPtr<Window>>& accessory_windows() { return m_accessory_windows; }
|
||||
const Vector<WeakPtr<Window>>& accessory_windows() const { return m_accessory_windows; }
|
||||
|
||||
bool is_descendant_of(Window&) const;
|
||||
|
||||
void set_accessory(bool accessory) { m_accessory = accessory; }
|
||||
bool is_accessory() const;
|
||||
bool is_accessory_of(Window&) const;
|
||||
|
|
|
@ -193,7 +193,8 @@ public:
|
|||
Vector<Window*> modal_stack;
|
||||
auto* modal_stack_top = blocking_modal_window ? blocking_modal_window : &window;
|
||||
for (auto* parent = modal_stack_top->parent_window(); parent; parent = parent->parent_window()) {
|
||||
if (parent->is_blocked_by_modal_window() != modal_stack_top)
|
||||
auto* blocked_by = parent->is_blocked_by_modal_window();
|
||||
if (!blocked_by || (blocked_by != modal_stack_top && !modal_stack_top->is_descendant_of(*blocked_by)))
|
||||
break;
|
||||
modal_stack.append(parent);
|
||||
if (!parent->is_modal())
|
||||
|
|
Loading…
Reference in a new issue