X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;ds=inline;f=shell%2Fev-sidebar-links.c;h=e663fc992e5d2d6bca86fb5f0f1ed5ab9d4454bd;hb=464f9eb8489a4b5882d20b8603d5f2fb38e61ddb;hp=a278034ab743565a556fb2a2906874e705ca3150;hpb=03ad9a29cbe1a89dfc5e8b94a74f6f86c4cba076;p=evince.git
diff --git a/shell/ev-sidebar-links.c b/shell/ev-sidebar-links.c
index a278034a..e663fc99 100644
--- a/shell/ev-sidebar-links.c
+++ b/shell/ev-sidebar-links.c
@@ -46,6 +46,11 @@ struct _EvSidebarLinksPrivate {
EvPageCache *page_cache;
};
+enum {
+ PROP_0,
+ PROP_MODEL,
+};
+
static void links_page_num_func (GtkTreeViewColumn *tree_column,
GtkCellRenderer *cell,
@@ -71,6 +76,53 @@ ev_sidebar_links_destroy (GtkObject *object)
ev_sidebar_links_clear_document (ev_sidebar_links);
}
+static void
+ev_sidebar_links_set_property (GObject *object,
+ guint prop_id,
+ const GValue *value,
+ GParamSpec *pspec)
+{
+ EvSidebarLinks *ev_sidebar_links;
+ GtkTreeModel *model;
+
+ ev_sidebar_links = EV_SIDEBAR_LINKS (object);
+
+ switch (prop_id)
+ {
+ case PROP_MODEL:
+ model = ev_sidebar_links->priv->model;
+ ev_sidebar_links->priv->model = GTK_TREE_MODEL (g_value_dup_object (value));
+ if (model)
+ g_object_unref (model);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+ break;
+ }
+}
+
+static void
+ev_sidebar_links_get_property (GObject *object,
+ guint prop_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+ EvSidebarLinks *ev_sidebar_links;
+
+ ev_sidebar_links = EV_SIDEBAR_LINKS (object);
+
+ switch (prop_id)
+ {
+ case PROP_MODEL:
+ g_value_set_object (value, ev_sidebar_links->priv->model);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+ break;
+ }
+}
+
+
static void
ev_sidebar_links_class_init (EvSidebarLinksClass *ev_sidebar_links_class)
{
@@ -80,8 +132,19 @@ ev_sidebar_links_class_init (EvSidebarLinksClass *ev_sidebar_links_class)
g_object_class = G_OBJECT_CLASS (ev_sidebar_links_class);
gtk_object_class = GTK_OBJECT_CLASS (ev_sidebar_links_class);
+ g_object_class->set_property = ev_sidebar_links_set_property;
+ g_object_class->get_property = ev_sidebar_links_get_property;
+
gtk_object_class->destroy = ev_sidebar_links_destroy;
+ g_object_class_install_property (g_object_class,
+ PROP_MODEL,
+ g_param_spec_object ("model",
+ "Model",
+ "Current Model",
+ GTK_TYPE_TREE_MODEL,
+ G_PARAM_READWRITE));
+
g_type_class_add_private (g_object_class, sizeof (EvSidebarLinksPrivate));
}
@@ -126,13 +189,13 @@ create_loading_model (void)
/* Creates a fake model to indicate that we're loading */
retval = (GtkTreeModel *)gtk_list_store_new (EV_DOCUMENT_LINKS_COLUMN_NUM_COLUMNS,
G_TYPE_STRING,
- G_TYPE_BOOLEAN,
G_TYPE_OBJECT);
gtk_list_store_append (GTK_LIST_STORE (retval), &iter);
markup = g_strdup_printf ("%s", _("Loading..."));
gtk_list_store_set (GTK_LIST_STORE (retval), &iter,
EV_DOCUMENT_LINKS_COLUMN_MARKUP, markup,
+ EV_DOCUMENT_LINKS_COLUMN_LINK, NULL,
-1);
g_free (markup);
@@ -224,7 +287,7 @@ links_page_num_func (GtkTreeViewColumn *tree_column,
page_string = g_markup_printf_escaped ("%s", page_label);
g_object_set (cell,
- "markup", page_string,
+ "markup", page_string,
"visible", TRUE,
NULL);
@@ -335,6 +398,8 @@ job_finished_cb (EvJobLinks *job,
priv = sidebar_links->priv;
priv->model = g_object_ref (job->model);
+ g_object_notify (G_OBJECT (sidebar_links), "model");
+
gtk_tree_view_set_model (GTK_TREE_VIEW (priv->tree_view), job->model);
g_object_unref (job);