diff options
Diffstat (limited to 'src/ephy-window.c')
-rw-r--r-- | src/ephy-window.c | 130 |
1 files changed, 56 insertions, 74 deletions
diff --git a/src/ephy-window.c b/src/ephy-window.c index e6e17c12b..6d98032e6 100644 --- a/src/ephy-window.c +++ b/src/ephy-window.c @@ -36,6 +36,7 @@ #include "toolbar.h" #include "popup-commands.h" #include "ephy-encoding-menu.h" +#include "ephy-tabs-menu.h" #include "ephy-stock-icons.h" #include <string.h> @@ -261,6 +262,7 @@ struct EphyWindowPrivate EggActionGroup *popups_action_group; EphyFavoritesMenu *fav_menu; EphyEncodingMenu *enc_menu; + EphyTabsMenu *tabs_menu; PPViewToolbar *ppview_toolbar; GtkNotebook *notebook; EphyTab *active_tab; @@ -284,9 +286,8 @@ ephy_window_notebook_switch_page_cb (GtkNotebook *notebook, EphyWindow *window); static void -ephy_window_tab_detached_cb (EphyNotebook *notebook, gint page, - gint x, gint y, gpointer data); - +ephy_window_tab_detached_cb (EphyNotebook *notebook, gint page, + gint x, gint y, gpointer data); static GObjectClass *parent_class = NULL; @@ -330,34 +331,6 @@ ephy_window_class_init (EphyWindowClass *klass) widget_class->show = ephy_window_show; } -static gboolean -ephy_window_key_press_event_cb (GtkWidget *widget, - GdkEventKey *event, - EphyWindow *window) -{ - int page; - - if ((event->state & GDK_Shift_L) || (event->state & GDK_Shift_R)) - return FALSE; - - if ((event->state & GDK_Alt_L) || (event->state & GDK_Alt_R)) - { - page = event->keyval - GDK_0 -1; - - if (page == -1) page = 9; - - if (page>=-1 && page<=9) - { - gtk_notebook_set_current_page - (GTK_NOTEBOOK (window->priv->notebook), - page == -1 ? -1 : page); - return TRUE; - } - } - - return FALSE; -} - static void ephy_window_selection_received_cb (GtkWidget *widget, GtkSelectionData *selection_data, @@ -521,16 +494,52 @@ setup_window (EphyWindow *window) GTK_WIDGET (window->priv->toolbar), FALSE, FALSE, 0); - g_signal_connect(window, - "key-press-event", - G_CALLBACK(ephy_window_key_press_event_cb), - window); g_signal_connect (window, "selection-received", G_CALLBACK (ephy_window_selection_received_cb), window); } +static void +update_tabs_menu_sensitivity (EphyWindow *window) +{ + gboolean prev_tab, next_tab, move_left, move_right, detach; + EggActionGroup *action_group; + EggAction *action; + int current; + int last; + + current = gtk_notebook_get_current_page + (GTK_NOTEBOOK (window->priv->notebook)); + last = gtk_notebook_get_n_pages + (GTK_NOTEBOOK (window->priv->notebook)) - 1; + prev_tab = move_left = (current > 0); + next_tab = move_right = (current < last); + detach = gtk_notebook_get_n_pages + (GTK_NOTEBOOK (window->priv->notebook)) > 1; + + action_group = window->priv->action_group; + action = egg_action_group_get_action (action_group, "TabsPrevious"); + g_object_set (action, "sensitive", prev_tab, NULL); + action = egg_action_group_get_action (action_group, "TabsNext"); + g_object_set (action, "sensitive", next_tab, NULL); + action = egg_action_group_get_action (action_group, "TabsMoveLeft"); + g_object_set (action, "sensitive", move_left, NULL); + action = egg_action_group_get_action (action_group, "TabsMoveRight"); + g_object_set (action, "sensitive", move_right, NULL); + action = egg_action_group_get_action (action_group, "TabsDetach"); + g_object_set (action, "sensitive", detach, NULL); + + ephy_tabs_menu_update (window->priv->tabs_menu); +} + +static void +ephy_window_tabs_changed_cb (EphyNotebook *notebook, EphyWindow *window) +{ + update_tabs_menu_sensitivity (window); + ephy_tabs_menu_update (window->priv->tabs_menu); +} + static GtkNotebook * setup_notebook (EphyWindow *window) { @@ -549,6 +558,9 @@ setup_notebook (EphyWindow *window) g_signal_connect (G_OBJECT (notebook), "tab_detached", G_CALLBACK (ephy_window_tab_detached_cb), NULL); + g_signal_connect (G_OBJECT (notebook), "tabs_changed", + G_CALLBACK (ephy_window_tabs_changed_cb), + window); gtk_widget_show (GTK_WIDGET (notebook)); @@ -571,9 +583,6 @@ ephy_window_init (EphyWindow *window) /* Setup the window and connect verbs */ setup_window (window); - window->priv->fav_menu = ephy_favorites_menu_new (window); - window->priv->enc_menu = ephy_encoding_menu_new (window); - /* Setup window contents */ window->priv->notebook = setup_notebook (window); gtk_box_pack_start (GTK_BOX (window->priv->main_vbox), @@ -588,6 +597,11 @@ ephy_window_init (EphyWindow *window) g_object_ref (ephy_shell); + /* Initializ the menus */ + window->priv->tabs_menu = ephy_tabs_menu_new (window); + window->priv->fav_menu = ephy_favorites_menu_new (window); + window->priv->enc_menu = ephy_encoding_menu_new (window); + /* Once window is fully created, add it to the session list*/ session_add_window (session, window); } @@ -645,6 +659,7 @@ ephy_window_finalize (GObject *object) g_object_unref (window->priv->fav_menu); g_object_unref (window->priv->enc_menu); + g_object_unref (window->priv->tabs_menu); if (window->priv->ppview_toolbar) { @@ -1207,37 +1222,6 @@ update_find_control (EphyWindow *window) } static void -update_tabs (EphyWindow *window) -{ - gboolean prev_tab, next_tab, move_left, move_right, detach; - EggActionGroup *action_group; - EggAction *action; - int current; - int last; - - current = gtk_notebook_get_current_page - (GTK_NOTEBOOK (window->priv->notebook)); - last = gtk_notebook_get_n_pages - (GTK_NOTEBOOK (window->priv->notebook)) - 1; - prev_tab = move_left = (current > 0); - next_tab = move_right = (current < last); - detach = gtk_notebook_get_n_pages - (GTK_NOTEBOOK (window->priv->notebook)) > 1; - - action_group = window->priv->action_group; - action = egg_action_group_get_action (action_group, "TabsPrevious"); - g_object_set (action, "sensitive", prev_tab, NULL); - action = egg_action_group_get_action (action_group, "TabsNext"); - g_object_set (action, "sensitive", next_tab, NULL); - action = egg_action_group_get_action (action_group, "TabsMoveLeft"); - g_object_set (action, "sensitive", move_left, NULL); - action = egg_action_group_get_action (action_group, "TabsMoveRight"); - g_object_set (action, "sensitive", move_right, NULL); - action = egg_action_group_get_action (action_group, "TabsDetach"); - g_object_set (action, "sensitive", detach, NULL); -} - -static void update_window_visibility (EphyWindow *window) { GList *l, *tabs; @@ -1292,9 +1276,6 @@ ephy_window_update_control (EphyWindow *window, switch (control) { - case TabsControl: - update_tabs (window); - break; case StatusbarMessageControl: update_status_message (window); break; @@ -1354,7 +1335,6 @@ ephy_window_update_all_controls (EphyWindow *window) update_security (window); update_find_control (window); update_spinner_control (window); - update_tabs (window); } } @@ -1461,6 +1441,7 @@ ephy_window_notebook_switch_page_cb (GtkNotebook *notebook, /* update window controls */ ephy_window_update_all_controls (window); + update_tabs_menu_sensitivity (window); } static void @@ -1525,7 +1506,7 @@ ephy_window_get_toolbar (EphyWindow *window) return window->priv->toolbar; } -void +static void ephy_window_tab_detached_cb (EphyNotebook *notebook, gint page, gint x, gint y, gpointer data) { @@ -1542,3 +1523,4 @@ ephy_window_tab_detached_cb (EphyNotebook *notebook, gint page, ephy_tab_set_window (tab, window); gtk_widget_show (GTK_WIDGET (window)); } + |