plasma-framework/src/plasmaquick
Eike Hein 433b6794fe Add Qt::Dialog to default flags to make QXcbWindow::isTransient() happy.
Panel popup dialogs along with other applications of Plasma::Dialog
(e.g. Kicker's submenus) currently don't correctly set WM_TRANSIENT_FOR
to the id of their parent window on X11. This causes them to interact
badly with auto-hide panels which do not set struts, e.g. Kicker's
submenus open behind the panel.

Internally, Dialog makes calls to QWindow::setFlags when its window
type is "Normal" (the default) and otherwise uses KWindowSystem's
setType. (Kicker's subclass, SubMenu, does an additional
KWindowSystem::setType call for NET::Menu). Neither CompactApplet
nor Kicker change their Dialog's 'type' property to anything else,
so their dialogs are "Normal", thus going the setFlags route with
no setType calls.

Dialog also sets its transient parent to the window the visualParent
item is inside of.

Now here is where things break down: QXcbWindow will update
WM_TRANSIENT_PARENT for in show(), but only when an inline function
called isTransient returns true. isTransient decides this based on
window type, which is determined from the flags set with
QWindow::setFlags. Calls to KWindowSystem::setType would have no
bearing on this; there seems to be no mapping back from external
state. This is why setting Dialog.type to e.g. "DialogWindow" does
nothing.

This patch takes the route of adding Qt::Dialog to the starting
flags - after all Dialog is a dialog. That means isTransient()
will consider the window to be a transient and those
setTransientParent calls Dialog does will not be ignored. In the
case of CompactApplet, no further calls to KWS::setType are done;
Kicker continues to call it with NET::Menu to get desired window
manager behavior.

In light testing everything still seems too work, with the added
benefit of fixing:
BUG:366278

That said, the weird mess of setFlags and setType and state in the
windowing system vs. Qt is horrible and sad.

REVIEW:128571
2016-08-02 19:20:33 +09:00
..
private Make it possible for an applet to offer a test object 2016-03-16 12:32:25 +01:00
appletquickitem.cpp Make use of QQuickItem::setSize 2016-07-04 11:06:44 +01:00
appletquickitem.h Make sure PlasmaQuick export file is properly found 2016-03-17 13:33:19 +01:00
CMakeLists.txt Merge branch 'mart/customShell' 2016-03-08 15:38:31 +01:00
configmodel.cpp ConfigModel: Don't try to resolve empty source path from package 2016-05-04 17:34:02 +02:00
configmodel.h Make sure PlasmaQuick export file is properly found 2016-03-17 13:33:19 +01:00
configview.cpp Make use of QQuickItem::setSize 2016-07-04 11:06:44 +01:00
configview.h Make sure PlasmaQuick export file is properly found 2016-03-17 13:33:19 +01:00
containmentview.cpp ContainmentView: Do not crash on an invalid corona metadata 2015-06-19 00:03:20 +02:00
containmentview.h Header of plasmaquick_export.h is in plasmaquick folder. 2015-11-27 22:52:52 +01:00
dialog.cpp Add Qt::Dialog to default flags to make QXcbWindow::isTransient() happy. 2016-08-02 19:20:33 +09:00
dialog.h Make sure PlasmaQuick export file is properly found 2016-03-17 13:33:19 +01:00
dialogshadows_p.h Fix most of Clazy warnings in plasma-framework 2016-02-29 00:13:41 +01:00
dialogshadows.cpp [DialogShadows] Cache access to QX11Info::display() 2016-05-11 19:58:55 +02:00
KF5PlasmaQuickConfig.cmake.in Fix Plasma_INCLUDE_INSTALL_DIR variable in (another) config module 2014-04-26 13:16:21 +01:00
Mainpage.dox Document WallpaperInterface 2014-12-21 21:03:51 +01:00
packageurlinterceptor.cpp Fix most of Clazy warnings in plasma-framework 2016-02-29 00:13:41 +01:00
packageurlinterceptor.h Make sure PlasmaQuick export file is properly found 2016-03-17 13:33:19 +01:00
shellpluginloader.cpp qstring optimizations 2015-11-27 20:03:48 +00:00
shellpluginloader.h Make sure PlasmaQuick export file is properly found 2016-03-17 13:33:19 +01:00
view.cpp bring config view to fron if already existing 2015-03-11 14:39:00 +01:00
view.h Make sure PlasmaQuick export file is properly found 2016-03-17 13:33:19 +01:00