X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=shell%2Fev-sidebar.c;h=f23a45f39cc00d7d33c48161f7d63403503e5f33;hb=848665b157185945d190a7a746d054d7f5d5e6e0;hp=b1454d93e4af06245e645c71efa5d1ee197192a4;hpb=a5542ba7635d06d7b4b8e94ea472f29cbf4d2c4e;p=evince.git diff --git a/shell/ev-sidebar.c b/shell/ev-sidebar.c index b1454d93..f23a45f3 100644 --- a/shell/ev-sidebar.c +++ b/shell/ev-sidebar.c @@ -29,21 +29,10 @@ #include #include "ev-sidebar.h" -#include "ev-document-thumbnails.h" -#include "ev-document-links.h" -#include "ev-sidebar-links.h" -#include "ev-sidebar-thumbnails.h" - -typedef struct -{ - char *id; - char *title; - GtkWidget *main_widget; -} EvSidebarPage; +#include "ev-sidebar-page.h" enum { - PAGE_COLUMN_ID, PAGE_COLUMN_TITLE, PAGE_COLUMN_MENU_ITEM, PAGE_COLUMN_MAIN_WIDGET, @@ -54,7 +43,6 @@ enum struct _EvSidebarPrivate { GtkWidget *notebook; GtkWidget *menu; - GtkWidget *frame; GtkWidget *hbox; GtkWidget *label; @@ -75,6 +63,12 @@ ev_sidebar_destroy (GtkObject *object) gtk_menu_detach (GTK_MENU (ev_sidebar->priv->menu)); ev_sidebar->priv->menu = NULL; } + + if (ev_sidebar->priv->page_model) { + g_object_unref (ev_sidebar->priv->page_model); + ev_sidebar->priv->page_model = NULL; + } + (* GTK_OBJECT_CLASS (ev_sidebar_parent_class)->destroy) (object); } @@ -125,6 +119,15 @@ ev_sidebar_select_button_press_cb (GtkWidget *widget, EvSidebar *ev_sidebar = EV_SIDEBAR (user_data); if (event->button == 1) { + GtkRequisition requisition; + gint width; + + width = widget->allocation.width; + gtk_widget_set_size_request (ev_sidebar->priv->menu, -1, -1); + gtk_widget_size_request (ev_sidebar->priv->menu, &requisition); + gtk_widget_set_size_request (ev_sidebar->priv->menu, + MAX (width, requisition.width), -1); + gtk_widget_grab_focus (widget); gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (widget), TRUE); @@ -218,13 +221,14 @@ ev_sidebar_menu_item_activate_cb (GtkWidget *widget, } else { valid = gtk_tree_model_iter_next (ev_sidebar->priv->page_model, &iter); } + g_object_unref (item); + g_free (title); } } static void ev_sidebar_init (EvSidebar *ev_sidebar) { - GtkWidget *frame; GtkWidget *hbox; GtkWidget *close_button; GtkWidget *select_button; @@ -237,21 +241,15 @@ ev_sidebar_init (EvSidebar *ev_sidebar) /* data model */ ev_sidebar->priv->page_model = (GtkTreeModel *) gtk_list_store_new (PAGE_COLUMN_NUM_COLS, - G_TYPE_STRING, G_TYPE_STRING, GTK_TYPE_WIDGET, GTK_TYPE_WIDGET, G_TYPE_INT); /* top option menu */ - frame = gtk_frame_new (NULL); - ev_sidebar->priv->frame = frame; - gtk_box_pack_start (GTK_BOX (ev_sidebar), frame, FALSE, FALSE, 0); - gtk_widget_show (frame); - hbox = gtk_hbox_new (FALSE, 0); ev_sidebar->priv->hbox = hbox; - gtk_container_add (GTK_CONTAINER (frame), hbox); + gtk_box_pack_start (GTK_BOX (ev_sidebar), hbox, FALSE, FALSE, 0); gtk_widget_show (hbox); select_button = gtk_toggle_button_new (); @@ -310,6 +308,8 @@ ev_sidebar_init (EvSidebar *ev_sidebar) gtk_box_pack_start (GTK_BOX (ev_sidebar), ev_sidebar->priv->notebook, TRUE, TRUE, 0); gtk_widget_show (ev_sidebar->priv->notebook); + + gtk_widget_set_sensitive (GTK_WIDGET (ev_sidebar), FALSE); } /* Public functions */ @@ -326,19 +326,19 @@ ev_sidebar_new (void) void ev_sidebar_add_page (EvSidebar *ev_sidebar, - const gchar *page_id, - const gchar *title, GtkWidget *main_widget) { GtkTreeIter iter; GtkWidget *menu_item; gchar *label_title; + const gchar *title; int index; g_return_if_fail (EV_IS_SIDEBAR (ev_sidebar)); - g_return_if_fail (page_id != NULL); - g_return_if_fail (title != NULL); + g_return_if_fail (EV_IS_SIDEBAR_PAGE (main_widget)); g_return_if_fail (GTK_IS_WIDGET (main_widget)); + + title = ev_sidebar_page_get_label (EV_SIDEBAR_PAGE (main_widget)); index = gtk_notebook_append_page (GTK_NOTEBOOK (ev_sidebar->priv->notebook), main_widget, NULL); @@ -353,7 +353,6 @@ ev_sidebar_add_page (EvSidebar *ev_sidebar, gtk_list_store_insert_with_values (GTK_LIST_STORE (ev_sidebar->priv->page_model), &iter, 0, - PAGE_COLUMN_ID, page_id, PAGE_COLUMN_TITLE, title, PAGE_COLUMN_MENU_ITEM, menu_item, PAGE_COLUMN_MAIN_WIDGET, main_widget, @@ -372,6 +371,7 @@ ev_sidebar_add_page (EvSidebar *ev_sidebar, gtk_label_set_text (GTK_LABEL (ev_sidebar->priv->label), label_title); gtk_notebook_set_current_page (GTK_NOTEBOOK (ev_sidebar->priv->notebook), index); + g_free (label_title); } void @@ -380,19 +380,19 @@ ev_sidebar_set_document (EvSidebar *sidebar, { EvSidebarPrivate *priv; GtkTreeIter iter; - gboolean result; + gboolean valid; + gboolean has_pages; g_return_if_fail (EV_IS_SIDEBAR (sidebar)); g_return_if_fail (EV_IS_DOCUMENT (document)); priv = sidebar->priv; - /* FIXME: We should prolly make sidebars have an interface. For now, we - * do this bad hack (TM) - */ - for (result = gtk_tree_model_get_iter_first (priv->page_model, &iter); - result; - result = gtk_tree_model_iter_next (priv->page_model, &iter)) { + has_pages = FALSE; + + for (valid = gtk_tree_model_get_iter_first (priv->page_model, &iter); + valid; + valid = gtk_tree_model_iter_next (priv->page_model, &iter)) { GtkWidget *widget; GtkWidget *menu_widget; @@ -402,40 +402,20 @@ ev_sidebar_set_document (EvSidebar *sidebar, -1); - if (EV_IS_SIDEBAR_LINKS (widget)) { - if (EV_IS_DOCUMENT_LINKS (document) && - ev_document_links_has_document_links (EV_DOCUMENT_LINKS (document))) { - ev_sidebar_links_set_document (EV_SIDEBAR_LINKS (widget), document); - continue; - } else { - gtk_widget_set_sensitive (menu_widget, FALSE); - } - } - - if (EV_IS_SIDEBAR_THUMBNAILS (widget)) { - if (EV_IS_DOCUMENT_THUMBNAILS (document) && - (ev_document_get_n_pages (document) > 1)) { - ev_sidebar_thumbnails_set_document (EV_SIDEBAR_THUMBNAILS (widget), document); - continue; - } else { + if (ev_sidebar_page_support_document (EV_SIDEBAR_PAGE (widget), document)) { + ev_sidebar_page_set_document (EV_SIDEBAR_PAGE (widget), document); + has_pages = TRUE; + } else { gtk_widget_set_sensitive (menu_widget, FALSE); - } } + g_object_unref (widget); + g_object_unref (menu_widget); + } + + if (!has_pages) { + gtk_widget_hide (GTK_WIDGET (sidebar)); + } else { + gtk_widget_set_sensitive (GTK_WIDGET (sidebar), TRUE); } } -gboolean -ev_sidebar_supports_document (EvSidebar *ev_sidebar, - EvDocument *document) -{ - gboolean need_thumbnails; - gboolean need_index; - - need_thumbnails = EV_IS_DOCUMENT_THUMBNAILS (document) && (ev_document_get_n_pages (document) > 1); - need_index = (EV_IS_DOCUMENT_LINKS (document)); - - return need_thumbnails || need_index; -} - - -