diff options
author | Christian Persch <chpe@cvs.gnome.org> | 2005-01-02 03:51:39 +0800 |
---|---|---|
committer | Christian Persch <chpe@src.gnome.org> | 2005-01-02 03:51:39 +0800 |
commit | d8ef21e4e64809d0c244c6b68701505807620569 (patch) | |
tree | 3f8f720a344a28571de003f9dff2ad97a1946b3d /src/ephy-notebook.c | |
parent | 2a64029e3b463d91bde19fc14e53c34a81d4a1c9 (diff) | |
download | gsoc2013-epiphany-d8ef21e4e64809d0c244c6b68701505807620569.tar gsoc2013-epiphany-d8ef21e4e64809d0c244c6b68701505807620569.tar.gz gsoc2013-epiphany-d8ef21e4e64809d0c244c6b68701505807620569.tar.bz2 gsoc2013-epiphany-d8ef21e4e64809d0c244c6b68701505807620569.tar.lz gsoc2013-epiphany-d8ef21e4e64809d0c244c6b68701505807620569.tar.xz gsoc2013-epiphany-d8ef21e4e64809d0c244c6b68701505807620569.tar.zst gsoc2013-epiphany-d8ef21e4e64809d0c244c6b68701505807620569.zip |
Grab focus on the active tab before removing a tab. Fixes bug #119461.
2005-01-01 Christian Persch <chpe@cvs.gnome.org>
* src/ephy-notebook.c: (close_button_clicked_cb),
(build_tab_label):
* src/ephy-tab.c: (ephy_tab_grab_focus), (ephy_tab_class_init):
Grab focus on the active tab before removing a tab. Fixes bug #119461.
Diffstat (limited to 'src/ephy-notebook.c')
-rw-r--r-- | src/ephy-notebook.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/ephy-notebook.c b/src/ephy-notebook.c index a3cae94cf..fafce396e 100644 --- a/src/ephy-notebook.c +++ b/src/ephy-notebook.c @@ -805,6 +805,15 @@ close_button_clicked_cb (GtkWidget *widget, GtkWidget *tab) if (inhibited == FALSE) { + GtkNotebook *gnotebook; + GtkWidget *active_tab; + + gnotebook = GTK_NOTEBOOK (notebook); + active_tab = gtk_notebook_get_nth_page + (gnotebook, gtk_notebook_get_current_page (gnotebook)); + /* focus the active tab, bug #119461 */ + gtk_widget_grab_focus (active_tab); + ephy_notebook_remove_tab (notebook, EPHY_TAB (tab)); } } @@ -858,6 +867,9 @@ build_tab_label (EphyNotebook *nb, EphyTab *tab) close_button = gtk_button_new (); gtk_button_set_relief (GTK_BUTTON (close_button), GTK_RELIEF_NONE); + /* don't allow focus on the close button */ + GTK_WIDGET_SET_FLAGS (close_button, GTK_CAN_FOCUS); + GTK_WIDGET_SET_FLAGS (close_button, GTK_CAN_DEFAULT); close_icon_size = gtk_icon_size_from_name (EPHY_ICON_SIZE_TAB_BUTTON); image = gtk_image_new_from_stock (EPHY_STOCK_CLOSE_TAB, close_icon_size); gtk_container_add (GTK_CONTAINER (close_button), image); |