diff options
author | Maxim Monastirsky <momonasmon@gmail.com> | 2016-12-28 01:02:33 +0200 |
---|---|---|
committer | Maxim Monastirsky <momonasmon@gmail.com> | 2017-01-04 22:10:48 +0000 |
commit | 23a13694a5a70098b5ecd58b99d99618111f3ea5 (patch) | |
tree | c91ff4e858181412755a9d458fc3cce209610ca6 /vcl | |
parent | f883b687a1733756aff57acb8775351099515ee7 (diff) |
tdf#104944 gtk3: Ignore mouse up event if the wrong frame
Change-Id: I3d0aad6d2b434866df9110d3b8493fec2d2c94fe
Reviewed-on: https://gerrit.libreoffice.org/32465
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Maxim Monastirsky <momonasmon@gmail.com>
Diffstat (limited to 'vcl')
-rw-r--r-- | vcl/unx/gtk3/gtk3gtkframe.cxx | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/vcl/unx/gtk3/gtk3gtkframe.cxx b/vcl/unx/gtk3/gtk3gtkframe.cxx index 8c91660bd5df..3f49b65b52cc 100644 --- a/vcl/unx/gtk3/gtk3gtkframe.cxx +++ b/vcl/unx/gtk3/gtk3gtkframe.cxx @@ -2611,11 +2611,12 @@ gboolean GtkSalFrame::signalButton( GtkWidget*, GdkEventButton* pEvent, gpointer vcl::DeletionListener aDel( pThis ); - if (pEvent->type == GDK_BUTTON_PRESS && pThis->isFloatGrabWindow()) + if (pThis->isFloatGrabWindow() && pEvent->window != widget_get_window(pThis->getMouseEventWidget())) { - bool bClosePopups = (pEvent->window != widget_get_window(pThis->getMouseEventWidget())); - if (bClosePopups) + if (pEvent->type == GDK_BUTTON_PRESS) pThis->closePopup(); + else if (pEvent->type == GDK_BUTTON_RELEASE) + return true; } if (!aDel.isDeleted()) |