diff options
Diffstat (limited to 'libempathy-gtk')
-rw-r--r-- | libempathy-gtk/empathy-contact-widget.c | 158 | ||||
-rw-r--r-- | libempathy-gtk/empathy-contact-widget.h | 31 | ||||
-rw-r--r-- | libempathy-gtk/empathy-individual-dialogs.c | 6 |
3 files changed, 52 insertions, 143 deletions
diff --git a/libempathy-gtk/empathy-contact-widget.c b/libempathy-gtk/empathy-contact-widget.c index bf65fc7b8..2b770ca17 100644 --- a/libempathy-gtk/empathy-contact-widget.c +++ b/libempathy-gtk/empathy-contact-widget.c @@ -77,7 +77,6 @@ G_DEFINE_TYPE (EmpathyContactWidget, empathy_contact_widget, GTK_TYPE_BOX) struct _EmpathyContactWidgetPriv { EmpathyContact *contact; - EmpathyContactWidgetFlags flags; guint widget_id_timeout; gulong fav_sig_id; @@ -140,8 +139,7 @@ contact_widget_client_setup (EmpathyContactWidget *self) static void contact_widget_groups_update (EmpathyContactWidget *self) { - if (self->priv->flags & EMPATHY_CONTACT_WIDGET_EDIT_GROUPS && - self->priv->contact != NULL) + if (self->priv->contact != NULL) { FolksPersona *persona = empathy_contact_get_persona (self->priv->contact); @@ -423,25 +421,19 @@ contact_widget_contact_update (EmpathyContactWidget *self) } /* Update account widget */ - if (self->priv->flags & EMPATHY_CONTACT_WIDGET_EDIT_ACCOUNT) + if (account) { - if (account) - { - g_signal_handlers_block_by_func (self->priv->widget_account, - contact_widget_change_contact, - self); - empathy_account_chooser_set_account ( - EMPATHY_ACCOUNT_CHOOSER (self->priv->widget_account), account); - g_signal_handlers_unblock_by_func (self->priv->widget_account, - contact_widget_change_contact, self); - } + g_signal_handlers_block_by_func (self->priv->widget_account, + contact_widget_change_contact, + self); + empathy_account_chooser_set_account ( + EMPATHY_ACCOUNT_CHOOSER (self->priv->widget_account), account); + g_signal_handlers_unblock_by_func (self->priv->widget_account, + contact_widget_change_contact, self); } /* Update id widget */ - if (self->priv->flags & EMPATHY_CONTACT_WIDGET_EDIT_ID) - gtk_entry_set_text (GTK_ENTRY (self->priv->widget_id), id ? id : ""); - else - gtk_label_set_label (GTK_LABEL (self->priv->widget_id), id ? id : ""); + gtk_entry_set_text (GTK_ENTRY (self->priv->widget_id), id ? id : ""); /* Update other widgets */ if (self->priv->contact) @@ -518,38 +510,24 @@ static void contact_widget_change_contact (EmpathyContactWidget *self) { TpConnection *connection; + const gchar *id; connection = empathy_account_chooser_get_connection ( EMPATHY_ACCOUNT_CHOOSER (self->priv->widget_account)); if (!connection) return; - if (self->priv->flags & EMPATHY_CONTACT_WIDGET_EDIT_ID) + id = gtk_entry_get_text (GTK_ENTRY (self->priv->widget_id)); + if (!EMP_STR_EMPTY (id)) { - const gchar *id; - - id = gtk_entry_get_text (GTK_ENTRY (self->priv->widget_id)); - if (!EMP_STR_EMPTY (id)) - { - EmpathyClientFactory *factory; + EmpathyClientFactory *factory; - factory = empathy_client_factory_dup (); + factory = empathy_client_factory_dup (); - empathy_client_factory_dup_contact_by_id_async (factory, connection, - id, contact_widget_got_contact_cb, g_object_ref (self)); + empathy_client_factory_dup_contact_by_id_async (factory, connection, + id, contact_widget_got_contact_cb, g_object_ref (self)); - g_object_unref (factory); - } - } - else - { - EmpathyContact *contact; - - contact = empathy_contact_dup_from_tp_contact ( - tp_connection_get_self_contact (connection)); - - contact_widget_set_contact (self, contact); - g_object_unref (contact); + g_object_unref (factory); } } @@ -599,84 +577,53 @@ contact_widget_contact_setup (EmpathyContactWidget *self) self->priv->label_status, TRUE, TRUE, 0); gtk_widget_show (self->priv->label_status); - /* Setup account label/chooser */ - if (self->priv->flags & EMPATHY_CONTACT_WIDGET_EDIT_ACCOUNT) - { - self->priv->widget_account = empathy_account_chooser_new (); - - g_signal_connect_swapped (self->priv->widget_account, "changed", - G_CALLBACK (contact_widget_change_contact), - self); - } - - if (self->priv->widget_account != NULL) - { - gtk_grid_attach (GTK_GRID (self->priv->grid_contact), - self->priv->widget_account, - 2, 0, 1, 1); - - gtk_widget_show (self->priv->widget_account); - } + /* Setup account chooser */ + self->priv->widget_account = empathy_account_chooser_new (); + g_signal_connect_swapped (self->priv->widget_account, "changed", + G_CALLBACK (contact_widget_change_contact), + self); + gtk_grid_attach (GTK_GRID (self->priv->grid_contact), + self->priv->widget_account, + 2, 0, 1, 1); + gtk_widget_show (self->priv->widget_account); /* Set up avatar display */ - { - self->priv->widget_avatar = empathy_avatar_image_new (); - - g_signal_connect (self->priv->widget_avatar, "popup-menu", - G_CALLBACK (widget_avatar_popup_menu_cb), self); - g_signal_connect (self->priv->widget_avatar, "button-press-event", - G_CALLBACK (widget_avatar_button_press_event_cb), self); - } + self->priv->widget_avatar = empathy_avatar_image_new (); + g_signal_connect (self->priv->widget_avatar, "popup-menu", + G_CALLBACK (widget_avatar_popup_menu_cb), self); + g_signal_connect (self->priv->widget_avatar, "button-press-event", + G_CALLBACK (widget_avatar_button_press_event_cb), self); gtk_box_pack_start (GTK_BOX (self->priv->vbox_avatar), self->priv->widget_avatar, FALSE, FALSE, 6); gtk_widget_show (self->priv->widget_avatar); - /* Setup id label/entry */ - if (self->priv->flags & EMPATHY_CONTACT_WIDGET_EDIT_ID) - { - self->priv->widget_id = gtk_entry_new (); - g_signal_connect (self->priv->widget_id, "focus-out-event", - G_CALLBACK (contact_widget_id_focus_out_cb), - self); - g_signal_connect (self->priv->widget_id, "changed", - G_CALLBACK (contact_widget_id_changed_cb), - self); - } - else - { - self->priv->widget_id = gtk_label_new (NULL); - gtk_label_set_selectable (GTK_LABEL (self->priv->widget_id), TRUE); - gtk_misc_set_alignment (GTK_MISC (self->priv->widget_id), 0, 0.5); - } - + /* Setup id entry */ + self->priv->widget_id = gtk_entry_new (); + g_signal_connect (self->priv->widget_id, "focus-out-event", + G_CALLBACK (contact_widget_id_focus_out_cb), + self); + g_signal_connect (self->priv->widget_id, "changed", + G_CALLBACK (contact_widget_id_changed_cb), + self); gtk_grid_attach (GTK_GRID (self->priv->grid_contact), self->priv->widget_id, 2, 1, 1, 1); gtk_widget_set_hexpand (self->priv->widget_id, TRUE); gtk_widget_show (self->priv->widget_id); - /* Setup alias label/entry */ - if (self->priv->flags & EMPATHY_CONTACT_WIDGET_EDIT_ALIAS) - { - self->priv->widget_alias = gtk_entry_new (); + /* Setup alias entry */ + self->priv->widget_alias = gtk_entry_new (); - g_signal_connect (self->priv->widget_alias, "focus-out-event", - G_CALLBACK (contact_widget_entry_alias_focus_event_cb), - self); + g_signal_connect (self->priv->widget_alias, "focus-out-event", + G_CALLBACK (contact_widget_entry_alias_focus_event_cb), + self); - /* Make return activate the window default (the Close button) */ - gtk_entry_set_activates_default (GTK_ENTRY (self->priv->widget_alias), - TRUE); - } - else - { - self->priv->widget_alias = gtk_label_new (NULL); - gtk_label_set_selectable (GTK_LABEL (self->priv->widget_alias), TRUE); - gtk_misc_set_alignment (GTK_MISC (self->priv->widget_alias), 0, 0.5); - } + /* Make return activate the window default (the Close button) */ + gtk_entry_set_activates_default (GTK_ENTRY (self->priv->widget_alias), + TRUE); gtk_grid_attach (GTK_GRID (self->priv->grid_contact), self->priv->widget_alias, 2, 2, 1, 1); @@ -708,15 +655,13 @@ empathy_contact_widget_finalize (GObject *object) /** * empathy_contact_widget_new: * @contact: an #EmpathyContact - * @flags: #EmpathyContactWidgetFlags for the new contact widget * * Creates a new #EmpathyContactWidget. * * Return value: a new #EmpathyContactWidget */ GtkWidget * -empathy_contact_widget_new (EmpathyContact *contact, - EmpathyContactWidgetFlags flags) +empathy_contact_widget_new (EmpathyContact *contact) { EmpathyContactWidget *self; gchar *filename; @@ -727,8 +672,6 @@ empathy_contact_widget_new (EmpathyContact *contact, self = g_object_new (EMPATHY_TYPE_CONTACT_WIDGET, NULL); - self->priv->flags = flags; - filename = empathy_file_lookup ("empathy-contact-widget.ui", "libempathy-gtk"); gui = empathy_builder_get_file (filename, @@ -758,8 +701,7 @@ empathy_contact_widget_new (EmpathyContact *contact, if (contact != NULL) contact_widget_set_contact (self, contact); - else if (self->priv->flags & EMPATHY_CONTACT_WIDGET_EDIT_ACCOUNT || - self->priv->flags & EMPATHY_CONTACT_WIDGET_EDIT_ID) + else contact_widget_change_contact (self); g_object_unref (gui); diff --git a/libempathy-gtk/empathy-contact-widget.h b/libempathy-gtk/empathy-contact-widget.h index 6979d161d..6f8045d3e 100644 --- a/libempathy-gtk/empathy-contact-widget.h +++ b/libempathy-gtk/empathy-contact-widget.h @@ -70,36 +70,7 @@ GType empathy_contact_widget_get_type (void); EMPATHY_TYPE_CONTACT_WIDGET, \ EmpathyContactWidgetClass)) -/** - * EmpathyContactWidgetFlags: - * @EMPATHY_CONTACT_WIDGET_EDIT_NONE: Don't show any widgets to edit any details - * of the contact. This should be the option for widgets that merely display - * information about a contact. - * @EMPATHY_CONTACT_WIDGET_EDIT_ALIAS: Show a #GtkEntry allowing changes to the - * contact's alias. - * @EMPATHY_CONTACT_WIDGET_EDIT_ACCOUNT: Show an #EmpathyAccountChooser allowing - * changes to the contact's account. - * @EMPATHY_CONTACT_WIDGET_EDIT_ID: Show a #GtkEntry allowing changes to the - * contact's identifier. - * @EMPATHY_CONTACT_WIDGET_EDIT_GROUPS: Show a widget to change the groups the - * contact is in. - * @EMPATHY_CONTACT_WIDGET_FOR_TOOLTIP: Make widgets more designed for a tooltip. - * For example, make widgets not selectable. - * - * Flags used when creating an #EmpathyContactWidget to specify which features - * should be available. - */ -typedef enum -{ - EMPATHY_CONTACT_WIDGET_EDIT_NONE = 0, - EMPATHY_CONTACT_WIDGET_EDIT_ALIAS = 1 << 0, - EMPATHY_CONTACT_WIDGET_EDIT_ACCOUNT = 1 << 2, - EMPATHY_CONTACT_WIDGET_EDIT_ID = 1 << 3, - EMPATHY_CONTACT_WIDGET_EDIT_GROUPS = 1 << 4, -} EmpathyContactWidgetFlags; - -GtkWidget * empathy_contact_widget_new (EmpathyContact *contact, - EmpathyContactWidgetFlags flags); +GtkWidget * empathy_contact_widget_new (EmpathyContact *contact); EmpathyContact *empathy_contact_widget_get_contact (GtkWidget *widget); void empathy_contact_widget_set_contact (GtkWidget *widget, EmpathyContact *contact); diff --git a/libempathy-gtk/empathy-individual-dialogs.c b/libempathy-gtk/empathy-individual-dialogs.c index 0aca78fd3..2c5dc274e 100644 --- a/libempathy-gtk/empathy-individual-dialogs.c +++ b/libempathy-gtk/empathy-individual-dialogs.c @@ -134,11 +134,7 @@ empathy_new_individual_dialog_show_with_individual (GtkWindow *parent, if (individual != NULL) contact = empathy_contact_dup_from_folks_individual (individual); - contact_widget = empathy_contact_widget_new (contact, - EMPATHY_CONTACT_WIDGET_EDIT_ALIAS | - EMPATHY_CONTACT_WIDGET_EDIT_ACCOUNT | - EMPATHY_CONTACT_WIDGET_EDIT_ID | - EMPATHY_CONTACT_WIDGET_EDIT_GROUPS); + contact_widget = empathy_contact_widget_new (contact); gtk_container_set_border_width (GTK_CONTAINER (contact_widget), 8); gtk_box_pack_start ( GTK_BOX (gtk_dialog_get_content_area (GTK_DIALOG (dialog))), |