]> www.fi.muni.cz Git - evince.git/blobdiff - shell/ev-sidebar.c
Updated Danish translation.
[evince.git] / shell / ev-sidebar.c
index 4ff8405293fa5fe49d6138c3fff21b70a59c940d..d21a13add609455e0932c8d81c36ec0fb7c9c494 100644 (file)
 #include <gtk/gtk.h>
 
 #include "ev-sidebar.h"
 #include <gtk/gtk.h>
 
 #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
 {
 
 typedef struct
 {
@@ -76,10 +80,10 @@ ev_sidebar_init (EvSidebar *ev_sidebar)
 {
        GtkWidget *hbox;
        GtkCellRenderer *renderer;
 {
        GtkWidget *hbox;
        GtkCellRenderer *renderer;
-
+       
        ev_sidebar->priv = EV_SIDEBAR_GET_PRIVATE (ev_sidebar);
        ev_sidebar->priv = EV_SIDEBAR_GET_PRIVATE (ev_sidebar);
-
        gtk_box_set_spacing (GTK_BOX (ev_sidebar), 6);
        gtk_box_set_spacing (GTK_BOX (ev_sidebar), 6);
+
        /* data model */
        ev_sidebar->priv->page_model = (GtkTreeModel *)
                gtk_list_store_new (PAGE_COLUMN_NUM_COLS,
        /* data model */
        ev_sidebar->priv->page_model = (GtkTreeModel *)
                gtk_list_store_new (PAGE_COLUMN_NUM_COLS,
@@ -87,6 +91,7 @@ ev_sidebar_init (EvSidebar *ev_sidebar)
                                    G_TYPE_STRING,
                                    GTK_TYPE_WIDGET,
                                    G_TYPE_INT);
                                    G_TYPE_STRING,
                                    GTK_TYPE_WIDGET,
                                    G_TYPE_INT);
+
        /* top option menu */
        hbox = gtk_hbox_new (FALSE, 6);
        gtk_box_pack_start (GTK_BOX (ev_sidebar), hbox,
        /* top option menu */
        hbox = gtk_hbox_new (FALSE, 6);
        gtk_box_pack_start (GTK_BOX (ev_sidebar), hbox,
@@ -98,6 +103,7 @@ ev_sidebar_init (EvSidebar *ev_sidebar)
        gtk_box_pack_start (GTK_BOX (hbox),
                            ev_sidebar->priv->option_menu,
                            FALSE, FALSE, 0);
        gtk_box_pack_start (GTK_BOX (hbox),
                            ev_sidebar->priv->option_menu,
                            FALSE, FALSE, 0);
+       
        renderer = gtk_cell_renderer_text_new ();
        gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (ev_sidebar->priv->option_menu),
                                    renderer, TRUE);
        renderer = gtk_cell_renderer_text_new ();
        gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (ev_sidebar->priv->option_menu),
                                    renderer, TRUE);
@@ -170,6 +176,49 @@ ev_sidebar_add_page (EvSidebar   *ev_sidebar,
                                           PAGE_COLUMN_MAIN_WIDGET, main_widget,
                                           PAGE_COLUMN_NOTEBOOK_INDEX, index,
                                           -1);
                                           PAGE_COLUMN_MAIN_WIDGET, main_widget,
                                           PAGE_COLUMN_NOTEBOOK_INDEX, index,
                                           -1);
+
+       /* Set the first item added as active */
+       if (gtk_combo_box_get_active (GTK_COMBO_BOX (ev_sidebar->priv->option_menu)))
+               gtk_combo_box_set_active (GTK_COMBO_BOX (ev_sidebar->priv->option_menu), 0);
+}
+
+void
+ev_sidebar_set_document (EvSidebar   *sidebar,
+                        EvDocument  *document)
+{
+       EvSidebarPrivate *priv;
+       GtkTreeIter iter;
+       gboolean result;
+
+       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)) {
+               GtkWidget *widget;
+
+               gtk_tree_model_get (priv->page_model, &iter,
+                                   PAGE_COLUMN_MAIN_WIDGET, &widget,
+                                   -1);
+
+               if (EV_IS_SIDEBAR_LINKS (widget)
+                   && 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);
+               else if (EV_IS_SIDEBAR_THUMBNAILS (widget) &&
+                        EV_IS_DOCUMENT_THUMBNAILS (document))
+                       ev_sidebar_thumbnails_set_document (EV_SIDEBAR_THUMBNAILS (widget),
+                                                           document);
+       }
+       
+
 }
 
 void
 }
 
 void