From ccce22bf07adb8834c65d8a60d2f8af8cbaa28f8 Mon Sep 17 00:00:00 2001 From: Srinivasa Ragavan Date: Wed, 30 May 2007 08:17:32 +0000 Subject: Fix for bug #333858 svn path=/trunk/; revision=33605 --- addressbook/ChangeLog | 9 +++++++++ addressbook/gui/contact-editor/e-contact-editor.c | 12 ++++++++++-- addressbook/gui/contact-editor/e-contact-editor.h | 2 ++ 3 files changed, 21 insertions(+), 2 deletions(-) diff --git a/addressbook/ChangeLog b/addressbook/ChangeLog index 040ac32723..f14e70fb70 100644 --- a/addressbook/ChangeLog +++ b/addressbook/ChangeLog @@ -1,3 +1,12 @@ +2007-05-30 Srinivasa Ragavan + + ** Fix for bug #333858 from Milan Crha + + * gui/contact-editor/e-contact-editor.c: (categories_response), + (categories_clicked), (e_contact_editor_init): + * gui/contact-editor/e-contact-editor.h: + * importers/evolution-vcard-importer.c: (vcard_import_contacts), + 2007-05-25 Matthew Barnes * gui/component/addressbook-component.c (ensure_sources): diff --git a/addressbook/gui/contact-editor/e-contact-editor.c b/addressbook/gui/contact-editor/e-contact-editor.c index bc2d34342e..64965e9590 100644 --- a/addressbook/gui/contact-editor/e-contact-editor.c +++ b/addressbook/gui/contact-editor/e-contact-editor.c @@ -2652,7 +2652,8 @@ categories_response (GtkDialog *dialog, int response, EContactEditor *editor) else e_contact_set (editor->contact, E_CONTACT_CATEGORIES, (char *)categories); } - gtk_widget_hide(GTK_WIDGET(dialog)); + gtk_widget_destroy(GTK_WIDGET(dialog)); + editor->categories_dialog = NULL; } static gint @@ -2677,7 +2678,11 @@ categories_clicked (GtkWidget *button, EContactEditor *editor) else if (editor->contact) categories = e_contact_get (editor->contact, E_CONTACT_CATEGORIES); - if (!(dialog = GTK_DIALOG (e_categories_dialog_new (categories)))) { + if (editor->categories_dialog != NULL){ + gtk_window_present (GTK_WINDOW(editor->categories_dialog)); + g_free (categories); + return; + }else if (!(dialog = GTK_DIALOG (e_categories_dialog_new (categories)))) { e_error_run (NULL, "addressbook:edit-categories", NULL); g_free (categories); return; @@ -2692,6 +2697,8 @@ categories_clicked (GtkWidget *button, EContactEditor *editor) gtk_widget_show(GTK_WIDGET(dialog)); g_free (categories); + + editor->categories_dialog = GTK_WIDGET (dialog); } static void @@ -3292,6 +3299,7 @@ e_contact_editor_init (EContactEditor *e_contact_editor) e_contact_editor->image_changed = FALSE; e_contact_editor->in_async_call = FALSE; e_contact_editor->target_editable = TRUE; + e_contact_editor->categories_dialog = NULL; e_contact_editor->load_source_id = 0; e_contact_editor->load_book = NULL; diff --git a/addressbook/gui/contact-editor/e-contact-editor.h b/addressbook/gui/contact-editor/e-contact-editor.h index de1e657622..73472c1d2b 100644 --- a/addressbook/gui/contact-editor/e-contact-editor.h +++ b/addressbook/gui/contact-editor/e-contact-editor.h @@ -101,6 +101,8 @@ struct _EContactEditor /* signal ids for "writable_status" */ int target_editable_id; + + GtkWidget *categories_dialog; }; struct _EContactEditorClass -- cgit v1.2.3