https://bugs.kde.org/show_bug.cgi?id=464193
Vlad Zahorodnii <vlad.zahorod...@kde.org> changed: What |Removed |Added ---------------------------------------------------------------------------- Latest Commit|https://invent.kde.org/plas |https://invent.kde.org/plas |ma/plasma-integration/-/com |ma/plasma-integration/-/com |mit/522824e4302c5dae2cd92c4 |mit/d6d82f2b0c26b8b5e5e7661 |88153ee2fe048e548 |8fda1dfa763592b78 --- Comment #5 from Vlad Zahorodnii <vlad.zahorod...@kde.org> --- Git commit d6d82f2b0c26b8b5e5e76618fda1dfa763592b78 by Vlad Zahorodnii. Committed on 06/10/2023 at 09:19. Pushed by vladz into branch 'Plasma/5.27'. Force WindowCloseButtonHint for toplevel dialogs Prior to 6f6603eb64b945e39820a0658504041b851c6e8c, the close button had been implicitly added by QtXCB. For example, if window flags contain only Qt::Dialog, QtXCB will set MWM_FUNC_ALL motif hints. So QtQuick dialogs used to get the close button even though there's no Qt::WinodwCloseButtonHint flag. QtWidgets dialogs usually always pass Qt::WindowCloseButtonHint flag. After making kwin display minimize and maximize decoration buttons only if corresponding Motif hints are set, KDE applications that use windows with Dialog type lost their min/max buttons because QtWidgets code doesn't set those flags. 6f6603eb64b945e39820a0658504041b851c6e8c tried to fix that by making the platform integration theme force Qt::WindowMinimizeButtonHint and Qt::WindowMaximizeButtonHint flags. But it accidentally broke QtQuick dialogs since dialogs have additional flags besides Qt::Dialog now, so QtXCB has stopped setting MWM_FUNC_ALL hints anymore. In order to address that, this patch changes a few things: - Make the platform theme be more careful about changing window flags. If user has explicitly changed window decoration flags, i.e. Qt::CustomizeWindowHint flag is set, don't touch decoration hints. - Merge Qt::WindowMaximizeButtonHint with Qt::WindowMinimizeButtonHint. If the window cannot be maximized, the window manager will hide the maximize button, so we can pass Qt::WindowMinMaxButtonHint. In some way, it's a breaking change as child dialogs may not have maximize button, but it's a weird case and maybe user code should be in control of that? - Forces Qt::WindowCloseButtonHint in addition to min/max button hints. QtQuick child dialogs, i.e. transientParent() is not null, will get default decoration buttons. (cherry picked from commit 522824e4302c5dae2cd92c488153ee2fe048e548) M +3 -9 src/platformtheme/x11integration.cpp https://invent.kde.org/plasma/plasma-integration/-/commit/d6d82f2b0c26b8b5e5e76618fda1dfa763592b78 -- You are receiving this mail because: You are watching all bug changes.