]> git.0d.be Git - empathy.git/blobdiff - libempathy-gtk/empathy-roster-group.c
Updated Spanish Translation
[empathy.git] / libempathy-gtk / empathy-roster-group.c
index bffd6a80d137c67bdb589daa17cc8fbf5f92ac32..753655ab56329e60d5f87eb8eefa91ec487e7653 100644 (file)
@@ -1,14 +1,14 @@
 #include "config.h"
-
 #include "empathy-roster-group.h"
 
 #include <telepathy-glib/telepathy-glib.h>
 
-G_DEFINE_TYPE (EmpathyRosterGroup, empathy_roster_group, GTK_TYPE_EXPANDER)
+G_DEFINE_TYPE (EmpathyRosterGroup, empathy_roster_group, GTK_TYPE_LIST_BOX_ROW)
 
 enum
 {
   PROP_NAME = 1,
+  PROP_ICON,
   N_PROPS
 };
 
@@ -24,6 +24,7 @@ static guint signals[LAST_SIGNAL];
 struct _EmpathyRosterGroupPriv
 {
   gchar *name;
+  gchar *icon_name;
 
   /* Widgets associated with this group. EmpathyRosterGroup is not responsible
    * of packing/displaying these widgets. This hash table is a just a set
@@ -44,6 +45,9 @@ empathy_roster_group_get_property (GObject *object,
       case PROP_NAME:
         g_value_set_string (value, self->priv->name);
         break;
+      case PROP_ICON:
+        g_value_set_string (value, self->priv->icon_name);
+        break;
       default:
         G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
         break;
@@ -64,6 +68,10 @@ empathy_roster_group_set_property (GObject *object,
         g_assert (self->priv->name == NULL); /* construct-only */
         self->priv->name = g_value_dup_string (value);
         break;
+      case PROP_ICON:
+        g_assert (self->priv->icon_name == NULL); /* construct-only */
+        self->priv->icon_name = g_value_dup_string (value);
+        break;
       default:
         G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
         break;
@@ -77,15 +85,38 @@ empathy_roster_group_constructed (GObject *object)
   void (*chain_up) (GObject *) =
       ((GObjectClass *) empathy_roster_group_parent_class)->constructed;
   gchar *tmp;
+  GtkWidget *box, *label;
 
   if (chain_up != NULL)
     chain_up (object);
 
   g_assert (self->priv->name != NULL);
 
+  box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 6);
+
+  /* Icon, if any */
+  if (!tp_str_empty (self->priv->icon_name))
+    {
+      GtkWidget *icon;
+
+      icon = gtk_image_new_from_icon_name (self->priv->icon_name,
+          GTK_ICON_SIZE_MENU);
+
+      if (icon != NULL)
+        gtk_box_pack_start (GTK_BOX (box), icon, FALSE, FALSE, 0);
+    }
+
+  /* Label */
   tmp = g_strdup_printf ("<b>%s</b>", self->priv->name);
-  gtk_expander_set_label (GTK_EXPANDER (self), tmp);
+  label = gtk_label_new (tmp);
   g_free (tmp);
+
+  gtk_label_set_use_markup (GTK_LABEL (label), TRUE);
+  gtk_box_pack_start (GTK_BOX (box), label, TRUE, TRUE, 0);
+
+  gtk_widget_show_all (box);
+
+  gtk_expander_set_label_widget (self->expander, box);
 }
 
 static void
@@ -109,6 +140,7 @@ empathy_roster_group_finalize (GObject *object)
       ((GObjectClass *) empathy_roster_group_parent_class)->finalize;
 
   g_free (self->priv->name);
+  g_free (self->priv->icon_name);
 
   if (chain_up != NULL)
     chain_up (object);
@@ -133,6 +165,12 @@ empathy_roster_group_class_init (
       G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY | G_PARAM_STATIC_STRINGS);
   g_object_class_install_property (oclass, PROP_NAME, spec);
 
+  spec = g_param_spec_string ("icon", "Icon",
+      "Icon name",
+      NULL,
+      G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY | G_PARAM_STATIC_STRINGS);
+  g_object_class_install_property (oclass, PROP_ICON, spec);
+
   g_type_class_add_private (klass, sizeof (EmpathyRosterGroupPriv));
 }
 
@@ -143,15 +181,22 @@ empathy_roster_group_init (EmpathyRosterGroup *self)
       EMPATHY_TYPE_ROSTER_GROUP, EmpathyRosterGroupPriv);
 
   self->priv->widgets = g_hash_table_new (NULL, NULL);
+
+  self->expander = GTK_EXPANDER (gtk_expander_new (NULL));
+  gtk_expander_set_use_markup (self->expander, TRUE);
+  gtk_expander_set_expanded (self->expander, TRUE);
+  gtk_widget_show (GTK_WIDGET (self->expander));
+
+  gtk_container_add (GTK_CONTAINER (self), GTK_WIDGET (self->expander));
 }
 
 GtkWidget *
-empathy_roster_group_new (const gchar *name)
+empathy_roster_group_new (const gchar *name,
+    const gchar *icon)
 {
   return g_object_new (EMPATHY_TYPE_ROSTER_GROUP,
       "name", name,
-      "use-markup", TRUE,
-      "expanded", TRUE,
+      "icon", icon,
       NULL);
 }