diff options
Diffstat (limited to 'addressbook/gui/contact-editor')
-rw-r--r-- | addressbook/gui/contact-editor/e-contact-editor-im.c | 24 | ||||
-rw-r--r-- | addressbook/gui/contact-editor/e-contact-editor.c | 226 | ||||
-rw-r--r-- | addressbook/gui/contact-editor/im.glade | 2 |
3 files changed, 154 insertions, 98 deletions
diff --git a/addressbook/gui/contact-editor/e-contact-editor-im.c b/addressbook/gui/contact-editor/e-contact-editor-im.c index a086d959e9..d7e98ce909 100644 --- a/addressbook/gui/contact-editor/e-contact-editor-im.c +++ b/addressbook/gui/contact-editor/e-contact-editor-im.c @@ -124,17 +124,17 @@ e_contact_editor_im_class_init (EContactEditorImClass *klass) g_object_class_install_property (object_class, PROP_LOCATION, g_param_spec_string ("location", - _("Location"), - /*_( */"XXX blurb" /*)*/, - "HOME", - G_PARAM_READWRITE)); + _("Location"), + /*_( */"XXX blurb" /*)*/, + "HOME", + G_PARAM_READWRITE)); g_object_class_install_property (object_class, PROP_USERNAME, g_param_spec_string ("username", - _("Username"), - /*_( */"XXX blurb" /*)*/, - NULL, - G_PARAM_READWRITE)); + _("Username"), + /*_( */"XXX blurb" /*)*/, + NULL, + G_PARAM_READWRITE)); g_object_class_install_property (object_class, PROP_EDITABLE, g_param_spec_boolean ("editable", @@ -327,8 +327,8 @@ e_contact_editor_im_new (EContactField service, const char *location, const char GtkWidget *widget = g_object_new (E_TYPE_CONTACT_EDITOR_IM, NULL); g_object_set (widget, "service", GINT_TO_POINTER(service), - "location", location, - "username", username, + "location", location, + "username", username, NULL); return widget; } @@ -460,8 +460,8 @@ fill_in_info(EContactEditorIm *editor) if (optmenu != NULL) gtk_option_menu_set_history(GTK_OPTION_MENU(optmenu), - (editor->location == NULL ? 2 : - !strcmp(editor->location, "WORK") ? 1 : 0)); + (editor->location == NULL ? 2 : + !strcmp(editor->location, "WORK") ? 1 : 0)); } static char * diff --git a/addressbook/gui/contact-editor/e-contact-editor.c b/addressbook/gui/contact-editor/e-contact-editor.c index 111ce093d3..420c5aa6ee 100644 --- a/addressbook/gui/contact-editor/e-contact-editor.c +++ b/addressbook/gui/contact-editor/e-contact-editor.c @@ -85,6 +85,7 @@ enum { COLUMN_IM_SERVICE, COLUMN_IM_SCREENNAME, COLUMN_IM_LOCATION, + COLUMN_IM_LOCATION_TYPE, COLUMN_IM_SERVICE_FIELD, NUM_IM_COLUMNS }; @@ -318,6 +319,7 @@ add_im_clicked(GtkWidget *widget, EContactEditor *editor) { GtkDialog *dialog; int result; + EVCardAttribute *new_attr; dialog = GTK_DIALOG(e_contact_editor_im_new(E_CONTACT_IM_AIM, "HOME", NULL)); @@ -326,25 +328,31 @@ add_im_clicked(GtkWidget *widget, EContactEditor *editor) gtk_widget_hide(GTK_WIDGET(dialog)); if (result == GTK_RESPONSE_OK) { - GList *old_list, *new_list = NULL, *l; + GList *new_list = NULL; EContactField service; const char *screenname; + const char *location; g_object_get(dialog, - "service", &service, - "username", &screenname, - NULL); + "service", &service, + "location", &location, + "username", &screenname, + NULL); - old_list = e_contact_get(editor->contact, service); + new_list = e_contact_get_attributes (editor->contact, service); - for (l = old_list; l != NULL; l = l->next) - new_list = g_list_append(new_list, g_strdup(l->data)); + new_attr = e_vcard_attribute_new ("", e_contact_vcard_attribute (service)); + if (location) + e_vcard_attribute_add_param_with_value (new_attr, + e_vcard_attribute_param_new (EVC_TYPE), + location); + e_vcard_attribute_add_value (new_attr, screenname); - new_list = g_list_append(new_list, g_strdup(screenname)); + new_list = g_list_append(new_list, new_attr); - e_contact_set(editor->contact, service, new_list); + e_contact_set_attributes (editor->contact, service, new_list); - g_list_foreach(new_list, (GFunc)g_free, NULL); + e_vcard_attribute_free (new_attr); g_list_free(new_list); set_im_fields(editor); @@ -366,6 +374,7 @@ edit_im_clicked(GtkWidget *widget, EContactEditor *editor) const char *old_location, *location; const char *old_screenname, *screenname; int result; + EVCardAttribute *new_attr; treeview = glade_xml_get_widget(editor->gui, "treeview-im"); @@ -376,10 +385,10 @@ edit_im_clicked(GtkWidget *widget, EContactEditor *editor) } gtk_tree_model_get(GTK_TREE_MODEL(editor->im_model), &iter, - COLUMN_IM_SERVICE_FIELD, &old_service, - COLUMN_IM_LOCATION, &old_location, - COLUMN_IM_SCREENNAME, &old_screenname, - -1); + COLUMN_IM_SERVICE_FIELD, &old_service, + COLUMN_IM_LOCATION_TYPE, &old_location, + COLUMN_IM_SCREENNAME, &old_screenname, + -1); dialog = GTK_DIALOG(e_contact_editor_im_new(old_service, old_location, old_screenname)); @@ -389,58 +398,72 @@ edit_im_clicked(GtkWidget *widget, EContactEditor *editor) if (result == GTK_RESPONSE_OK) { GList *old_list, *new_list = NULL, *l; + gboolean found; g_object_get(dialog, - "service", &service, - "location", &location, - "username", &screenname, - NULL); + "service", &service, + "location", &location, + "username", &screenname, + NULL); if (service == old_service && - (location == old_location || - (location != NULL && old_location == NULL) || - (location == NULL && old_location != NULL) || - !strcmp(old_location, location)) && - !strcmp(screenname, old_screenname)) { + (location == old_location || + (location != NULL && old_location == NULL) || + (location == NULL && old_location != NULL) || + !strcmp(old_location, location)) && + !strcmp(screenname, old_screenname)) { gtk_widget_destroy(GTK_WIDGET(dialog)); return; } /* Remove the old. */ - old_list = e_contact_get(editor->contact, old_service); + old_list = e_contact_get_attributes (editor->contact, old_service); + found = FALSE; for (l = old_list; l != NULL; l = l->next) { - const char *temp_screenname = (const char *)l->data; - - if (strcmp(temp_screenname, old_screenname)) - new_list = g_list_append(new_list, g_strdup(temp_screenname)); + EVCardAttribute *attr = l->data; + + if (!found + && !strcmp(e_vcard_attribute_get_value (attr), old_screenname) + && e_vcard_attribute_has_type (attr, old_location)) { + e_vcard_attribute_free (attr); + found = TRUE; + } + else { + new_list = g_list_append(new_list, attr); + } } + g_list_free (old_list); - if (service == old_service) - new_list = g_list_append(new_list, g_strdup(screenname)); + /* create a new attribute based on the new screenname */ + new_attr = e_vcard_attribute_new ("", e_contact_vcard_attribute (service)); + if (location) + e_vcard_attribute_add_param_with_value (new_attr, + e_vcard_attribute_param_new (EVC_TYPE), + location); + e_vcard_attribute_add_value (new_attr, screenname); - e_contact_set(editor->contact, old_service, new_list); + if (service == old_service) { + /* we're just appending it to the same list again */ + new_list = g_list_append(new_list, new_attr); - g_list_foreach(new_list, (GFunc)g_free, NULL); - g_list_free(new_list); - - if (old_service != service) - { + e_contact_set_attributes (editor->contact, old_service, new_list); + } + else { + /* we're appending it to a different list, so + we need to write out the old service's list + and then get the new service's list, then + add the new attribute to that. so + confusing! */ + e_contact_set_attributes (editor->contact, old_service, new_list); + /* We have to add this elsewhere. */ - new_list = NULL; - - old_list = e_contact_get(editor->contact, service); - - for (l = old_list; l != NULL; l = l->next) - new_list = g_list_append(new_list, g_strdup(l->data)); + new_list = e_contact_get_attributes (editor->contact, service); - new_list = g_list_append(new_list, g_strdup(screenname)); + new_list = g_list_append(new_list, new_attr); - e_contact_set(editor->contact, service, new_list); - - g_list_foreach(new_list, (GFunc)g_free, NULL); - g_list_free(new_list); + e_contact_set_attributes (editor->contact, service, new_list); } set_im_fields(editor); @@ -483,8 +506,7 @@ remove_im_clicked(GtkWidget *widget, EContactEditor *editor) e_contact_set(editor->contact, old_service, new_list); - if (new_list != NULL) - { + if (new_list != NULL) { g_list_foreach(new_list, (GFunc)g_free, NULL); g_list_free(new_list); } @@ -553,12 +575,12 @@ im_treeview_drag_data_get_cb(GtkWidget *widget, GdkDragContext *dc, str = g_string_new(NULL); g_string_printf(str, - "MIME-Version: 1.0\r\n" - "Content-Type: application/x-im-contact\r\n" - "X-IM-Protocol: %s\r\n" - "X-IM-Username: %s\r\n", - protocol, - screenname); + "MIME-Version: 1.0\r\n" + "Content-Type: application/x-im-contact\r\n" + "X-IM-Protocol: %s\r\n" + "X-IM-Username: %s\r\n", + protocol, + screenname); if (alias && *alias) g_string_append_printf(str, "X-IM-Alias: %s\r\n", alias); @@ -568,10 +590,10 @@ im_treeview_drag_data_get_cb(GtkWidget *widget, GdkDragContext *dc, mime_str = g_string_free(str, FALSE); gtk_selection_data_set(data, - gdk_atom_intern("application/x-im-contact", FALSE), - 8, - mime_str, - strlen(mime_str) + 1); + gdk_atom_intern("application/x-im-contact", FALSE), + 8, + mime_str, + strlen(mime_str) + 1); g_free(mime_str); gtk_tree_path_free(sourcerow); @@ -580,8 +602,8 @@ im_treeview_drag_data_get_cb(GtkWidget *widget, GdkDragContext *dc, static void im_treeview_drag_data_rcv_cb(GtkWidget *widget, GdkDragContext *dc, - guint x, guint y, GtkSelectionData *sd, - guint info, guint t, EContactEditor *editor) + guint x, guint y, GtkSelectionData *sd, + guint info, guint t, EContactEditor *editor) { if (sd->target == gdk_atom_intern("application/x-im-contact", FALSE) && sd->data) { CamelMimeParser *parser; @@ -700,14 +722,14 @@ setup_im_treeview(EContactEditor *editor) return; editor->im_model = gtk_list_store_new(NUM_IM_COLUMNS, - GDK_TYPE_PIXBUF, G_TYPE_STRING, - G_TYPE_STRING, G_TYPE_STRING, G_TYPE_INT); + GDK_TYPE_PIXBUF, G_TYPE_STRING, + G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_INT); gtk_tree_view_set_model(GTK_TREE_VIEW(treeview), - GTK_TREE_MODEL(editor->im_model)); + GTK_TREE_MODEL(editor->im_model)); g_signal_connect(G_OBJECT(treeview), "button-press-event", - G_CALLBACK(im_button_press_cb), editor); + G_CALLBACK(im_button_press_cb), editor); column = gtk_tree_view_column_new(); gtk_tree_view_column_set_title(column, _("Service")); @@ -716,38 +738,47 @@ setup_im_treeview(EContactEditor *editor) renderer = gtk_cell_renderer_pixbuf_new(); gtk_tree_view_column_pack_start(column, renderer, FALSE); gtk_tree_view_column_add_attribute(column, renderer, - "pixbuf", COLUMN_IM_ICON); + "pixbuf", COLUMN_IM_ICON); renderer = gtk_cell_renderer_text_new(); gtk_tree_view_column_pack_start(column, renderer, TRUE); gtk_tree_view_column_add_attribute(column, renderer, - "text", COLUMN_IM_SERVICE); + "text", COLUMN_IM_SERVICE); column = gtk_tree_view_column_new(); gtk_tree_view_column_set_title(column, _("Account Name")); gtk_tree_view_insert_column(GTK_TREE_VIEW(treeview), column, -1); + + renderer = gtk_cell_renderer_text_new(); + gtk_tree_view_column_pack_start(column, renderer, TRUE); + gtk_tree_view_column_add_attribute(column, renderer, + "text", COLUMN_IM_SCREENNAME); + column = gtk_tree_view_column_new(); + gtk_tree_view_column_set_title(column, _("Location")); + gtk_tree_view_insert_column(GTK_TREE_VIEW(treeview), column, -1); + renderer = gtk_cell_renderer_text_new(); gtk_tree_view_column_pack_start(column, renderer, TRUE); gtk_tree_view_column_add_attribute(column, renderer, - "text", COLUMN_IM_SCREENNAME); + "text", COLUMN_IM_LOCATION); selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(treeview)); g_signal_connect(G_OBJECT(selection), "changed", - G_CALLBACK(im_selected_cb), editor); + G_CALLBACK(im_selected_cb), editor); /* Setup drag-and-drop */ gtk_tree_view_enable_model_drag_source(GTK_TREE_VIEW(treeview), - GDK_BUTTON1_MASK, gte, 1, - GDK_ACTION_COPY); + GDK_BUTTON1_MASK, gte, 1, + GDK_ACTION_COPY); gtk_tree_view_enable_model_drag_dest(GTK_TREE_VIEW(treeview), - gte, 1, - GDK_ACTION_COPY | GDK_ACTION_MOVE); + gte, 1, + GDK_ACTION_COPY | GDK_ACTION_MOVE); g_signal_connect(G_OBJECT(treeview), "drag-data-get", - G_CALLBACK(im_treeview_drag_data_get_cb), editor); + G_CALLBACK(im_treeview_drag_data_get_cb), editor); g_signal_connect(G_OBJECT(treeview), "drag-data-received", - G_CALLBACK(im_treeview_drag_data_rcv_cb), editor); + G_CALLBACK(im_treeview_drag_data_rcv_cb), editor); } static void @@ -2802,8 +2833,10 @@ set_fields(EContactEditor *editor) } static void -add_im_field(EContactEditor *editor, EContactField field, const char *service, - const char *desc) +add_im_field(EContactEditor *editor, + EContactField field, + const char *service, + const char *desc) { GList *list; GList *l; @@ -2813,7 +2846,7 @@ add_im_field(EContactEditor *editor, EContactField field, const char *service, char *icon_path; char *buf; - list = e_contact_get(editor->contact, field); + list = e_contact_get_attributes (editor->contact, field); buf = g_strdup_printf("im-%s.png", service); icon_path = g_concat_dir_and_file(EVOLUTION_IMAGESDIR, buf); @@ -2824,18 +2857,39 @@ add_im_field(EContactEditor *editor, EContactField field, const char *service, if (pixbuf != NULL) scale = gdk_pixbuf_scale_simple(pixbuf, 16, 16, GDK_INTERP_BILINEAR); - for (l = list; l != NULL; l = l->next) - { - const char *account_name = (const char *)l->data; + for (l = list; l != NULL; l = l->next) { + EVCardAttribute *attr = l->data; + char *account_name; + char *location; + char *location_type; + + account_name = e_vcard_attribute_get_value (attr); + if (!account_name) + continue; + + if (e_vcard_attribute_has_type (attr, "HOME")) { + location_type = "HOME"; + location = _("Home"); + } + else if (e_vcard_attribute_has_type (attr, "WORK")) { + location_type = "WORK"; + location = _("Work"); + } + else { + location_type = NULL; + location = _("Other"); + } gtk_list_store_append(editor->im_model, &iter); gtk_list_store_set(editor->im_model, &iter, - COLUMN_IM_ICON, scale, - COLUMN_IM_SERVICE, desc, - COLUMN_IM_SCREENNAME, account_name, - COLUMN_IM_SERVICE_FIELD, field, - -1); + COLUMN_IM_ICON, scale, + COLUMN_IM_SERVICE, desc, + COLUMN_IM_LOCATION, location, + COLUMN_IM_LOCATION_TYPE, location_type, + COLUMN_IM_SCREENNAME, account_name, + COLUMN_IM_SERVICE_FIELD, field, + -1); } if (scale != NULL) diff --git a/addressbook/gui/contact-editor/im.glade b/addressbook/gui/contact-editor/im.glade index 04f1e6915d..9523fabd04 100644 --- a/addressbook/gui/contact-editor/im.glade +++ b/addressbook/gui/contact-editor/im.glade @@ -153,6 +153,7 @@ <child> <widget class="GtkLabel" id="label-location"> + <property name="visible">True</property> <property name="label" translatable="yes">Location:</property> <property name="use_underline">False</property> <property name="use_markup">False</property> @@ -176,6 +177,7 @@ <child> <widget class="GtkOptionMenu" id="optmenu-location"> + <property name="visible">True</property> <property name="can_focus">True</property> <property name="history">-1</property> </widget> |