aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-window.c
diff options
context:
space:
mode:
authorXan Lopez <xan@igalia.com>2012-10-07 22:37:57 +0800
committerXan Lopez <xan@igalia.com>2012-10-07 22:37:57 +0800
commit899960fd491389cb3b4bdcbd52837c55061453e2 (patch)
treeadfa3bef0f60e6b16c89f31e93cc8d1843084881 /src/ephy-window.c
parent771f05be192dac3d9f393219191192345165589e (diff)
downloadgsoc2013-epiphany-899960fd491389cb3b4bdcbd52837c55061453e2.tar
gsoc2013-epiphany-899960fd491389cb3b4bdcbd52837c55061453e2.tar.gz
gsoc2013-epiphany-899960fd491389cb3b4bdcbd52837c55061453e2.tar.bz2
gsoc2013-epiphany-899960fd491389cb3b4bdcbd52837c55061453e2.tar.lz
gsoc2013-epiphany-899960fd491389cb3b4bdcbd52837c55061453e2.tar.xz
gsoc2013-epiphany-899960fd491389cb3b4bdcbd52837c55061453e2.tar.zst
gsoc2013-epiphany-899960fd491389cb3b4bdcbd52837c55061453e2.zip
Merge the app menu into the gear menu when we are not in the Shell
Gets rid of the ugly menubar with a single menu. https://bugzilla.gnome.org/show_bug.cgi?id=673054
Diffstat (limited to 'src/ephy-window.c')
-rw-r--r--src/ephy-window.c63
1 files changed, 63 insertions, 0 deletions
diff --git a/src/ephy-window.c b/src/ephy-window.c
index d2afac0dd..ab8b405ec 100644
--- a/src/ephy-window.c
+++ b/src/ephy-window.c
@@ -98,6 +98,8 @@ static const GtkActionEntry ephy_menu_entries [] = {
/* File actions. */
+ { "FileNewWindow", NULL, N_("_New Window"), "<control>N", NULL,
+ G_CALLBACK (window_cmd_file_new_window) },
{ "FileOpen", NULL, N_("_Open…"), "<control>O", NULL,
G_CALLBACK (window_cmd_file_open) },
{ "FileSaveAs", NULL, N_("Save _As…"), "<shift><control>S", NULL,
@@ -110,6 +112,8 @@ static const GtkActionEntry ephy_menu_entries [] = {
G_CALLBACK (window_cmd_file_send_to) },
{ "FileCloseTab", NULL, N_("_Close"), "<control>W", NULL,
G_CALLBACK (window_cmd_file_close_window) },
+ { "FileQuit", NULL, N_("_Quit"), "<control>Q", NULL,
+ G_CALLBACK (window_cmd_file_quit) },
/* Edit actions. */
@@ -133,6 +137,14 @@ static const GtkActionEntry ephy_menu_entries [] = {
G_CALLBACK (window_cmd_edit_find_next) },
{ "EditFindPrev", NULL, N_("Find Pre_vious"), "<shift><control>G", NULL,
G_CALLBACK (window_cmd_edit_find_prev) },
+ { "EditBookmarks", NULL, N_("Edit _Bookmarks…"), "<control>B", NULL,
+ G_CALLBACK (window_cmd_edit_bookmarks) },
+ { "EditHistory", NULL, N_("Edit _History…"), "<control>H", NULL,
+ G_CALLBACK (window_cmd_edit_history) },
+ { "EditPreferences", NULL, N_("Preferences"), "<control>e", NULL,
+ G_CALLBACK (window_cmd_edit_preferences) },
+ { "EditPersonalData", NULL, N_("Personal Data"), "<control>m", NULL,
+ G_CALLBACK (window_cmd_edit_personal_data) },
/* View actions. */
@@ -174,6 +186,11 @@ static const GtkActionEntry ephy_menu_entries [] = {
G_CALLBACK (window_cmd_tabs_move_right) },
{ "TabsDetach", NULL, N_("_Detach Tab"), NULL, NULL,
G_CALLBACK (window_cmd_tabs_detach) },
+
+ /* Help. */
+
+ { "HelpAbout", NULL, N_("_About"), NULL, NULL,
+ G_CALLBACK (window_cmd_help_about) }
};
static const GtkToggleActionEntry ephy_menu_toggle_entries [] =
@@ -354,6 +371,7 @@ struct _EphyWindowPrivate
EphyLocationController *location_controller;
gulong set_focus_handler;
+ gulong app_menu_visibility_handler;
guint closing : 1;
guint has_size : 1;
@@ -3355,6 +3373,10 @@ ephy_window_finalize (GObject *object)
g_signal_handler_disconnect (window,
priv->set_focus_handler);
+ if (priv->app_menu_visibility_handler != 0)
+ g_signal_handler_disconnect (gtk_settings_get_for_screen (gtk_widget_get_screen (GTK_WIDGET (window))),
+ priv->app_menu_visibility_handler);
+
G_OBJECT_CLASS (ephy_window_parent_class)->finalize (object);
LOG ("EphyWindow finalised %p", object);
@@ -3531,6 +3553,38 @@ _gtk_css_provider_load_from_resource (GtkCssProvider* provider,
return res;
}
+static const gchar* app_actions[] = {
+ "FileNewWindow",
+ "EditPreferences",
+ "EditPersonalData",
+ "EditBookmarks",
+ "EditHistory",
+ "FileQuit",
+ "HelpAbout"
+};
+
+static void
+ephy_window_toggle_visibility_for_app_menu (EphyWindow *window)
+{
+ const gchar *action_name;
+ gboolean shows_app_menu;
+ GtkSettings *settings;
+ GtkAction *action;
+ gint idx;
+
+ settings = gtk_settings_get_for_screen (gtk_widget_get_screen (GTK_WIDGET (window)));
+ g_object_get (settings,
+ "gtk-shell-shows-app-menu", &shows_app_menu,
+ NULL);
+
+ for (idx = 0; idx < G_N_ELEMENTS (app_actions); idx++) {
+ action_name = app_actions[idx];
+ action = gtk_action_group_get_action (window->priv->action_group, action_name);
+
+ gtk_action_set_visible (action, !shows_app_menu);
+ }
+}
+
static GObject *
ephy_window_constructor (GType type,
guint n_construct_properties,
@@ -3712,6 +3766,15 @@ ephy_window_constructor (GType type,
}
}
+ /* We never want the menubar shown, we merge the app menu into
+ * our super menu manually when running outside the Shell. */
+ gtk_application_window_set_show_menubar (GTK_APPLICATION_WINDOW (window), FALSE);
+
+ ephy_window_toggle_visibility_for_app_menu (window);
+ priv->app_menu_visibility_handler = g_signal_connect_swapped (gtk_settings_get_for_screen (gtk_widget_get_screen (GTK_WIDGET (window))),
+ "notify::gtk-shell-shows-app-menu",
+ G_CALLBACK (ephy_window_toggle_visibility_for_app_menu), window);
+
/* ensure the UI is updated */
gtk_ui_manager_ensure_update (priv->manager);