[evolution] Bug 787411 - [Wayland] Alt-shown hidden menubar cannot be interacted with
- From: Milan Crha <mcrha src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution] Bug 787411 - [Wayland] Alt-shown hidden menubar cannot be interacted with
- Date: Mon, 11 Sep 2017 14:51:17 +0000 (UTC)
commit 8b934e36a1b77eb8fb4d9db6282db556855b00ce
Author: Milan Crha <mcrha redhat com>
Date: Mon Sep 11 16:51:39 2017 +0200
Bug 787411 - [Wayland] Alt-shown hidden menubar cannot be interacted with
src/shell/e-shell-window-private.c | 41 +++++++++++++++++++++++++++++++++--
src/shell/e-shell-window-private.h | 1 +
2 files changed, 39 insertions(+), 3 deletions(-)
---
diff --git a/src/shell/e-shell-window-private.c b/src/shell/e-shell-window-private.c
index fae3b7f..305516e 100644
--- a/src/shell/e-shell-window-private.c
+++ b/src/shell/e-shell-window-private.c
@@ -259,7 +259,29 @@ delayed_menubar_show_cb (gpointer user_data)
main_menu = e_shell_window_get_managed_widget (shell_window, "/main-menu");
gtk_widget_show (main_menu);
- gtk_widget_grab_focus (main_menu);
+ }
+
+ return FALSE;
+}
+
+static gboolean
+delayed_menubar_hide_cb (gpointer user_data)
+{
+ EShellWindow *shell_window = user_data;
+
+ g_return_val_if_fail (E_IS_SHELL_WINDOW (shell_window), FALSE);
+
+ shell_window->priv->delayed_menubar_hide_id = 0;
+
+ if (!e_shell_window_get_menubar_visible (shell_window) &&
+ !shell_window->priv->delayed_menubar_show_id) {
+ GtkWidget *main_menu;
+
+ main_menu = e_shell_window_get_managed_widget (shell_window, "/main-menu");
+
+ if (gtk_widget_get_visible (main_menu) &&
+ !gtk_menu_shell_get_selected_item (GTK_MENU_SHELL (main_menu)))
+ gtk_widget_hide (main_menu);
}
return FALSE;
@@ -293,6 +315,11 @@ e_shell_window_event_after_cb (EShellWindow *shell_window,
if ((key_event->keyval == GDK_KEY_Alt_L || key_event->keyval == GDK_KEY_Alt_R) &&
!(key_event->state & (GDK_SHIFT_MASK | GDK_CONTROL_MASK | GDK_SUPER_MASK | GDK_HYPER_MASK
| GDK_META_MASK))) {
+ if (shell_window->priv->delayed_menubar_hide_id) {
+ g_source_remove (shell_window->priv->delayed_menubar_hide_id);
+ shell_window->priv->delayed_menubar_hide_id = 0;
+ }
+
if (shell_window->priv->delayed_menubar_show_id) {
g_source_remove (shell_window->priv->delayed_menubar_show_id);
shell_window->priv->delayed_menubar_show_id = 0;
@@ -310,8 +337,11 @@ e_shell_window_event_after_cb (EShellWindow *shell_window,
shell_window->priv->delayed_menubar_show_id = 0;
}
- if (gtk_widget_get_visible (main_menu))
- gtk_widget_hide (main_menu);
+ if (gtk_widget_get_visible (main_menu) &&
+ !shell_window->priv->delayed_menubar_hide_id) {
+ shell_window->priv->delayed_menubar_hide_id =
+ e_named_timeout_add (500, delayed_menubar_hide_cb, shell_window);
+ }
}
}
@@ -616,6 +646,11 @@ e_shell_window_private_dispose (EShellWindow *shell_window)
priv->delayed_menubar_show_id = 0;
}
+ if (priv->delayed_menubar_hide_id) {
+ g_source_remove (priv->delayed_menubar_hide_id);
+ priv->delayed_menubar_hide_id = 0;
+ }
+
/* Need to disconnect handlers before we unref the shell. */
if (priv->signal_handler_ids != NULL) {
GArray *array = priv->signal_handler_ids;
diff --git a/src/shell/e-shell-window-private.h b/src/shell/e-shell-window-private.h
index 6a7f227..8dbad3a 100644
--- a/src/shell/e-shell-window-private.h
+++ b/src/shell/e-shell-window-private.h
@@ -98,6 +98,7 @@ struct _EShellWindowPrivate {
guint is_main_instance : 1;
gulong delayed_menubar_show_id;
+ gulong delayed_menubar_hide_id;
GSList *postponed_alerts; /* EAlert * */
};
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]