2005-10-16 [wwp] 1.9.15cvs52
[claws.git] / src / editaddress.c
index 3fa3c47f3491d62ab9ed2d9fc43d96f00e9b6c3d..fe2646081bf82a0bdb7672040e308bc329ee909f 100644 (file)
@@ -14,7 +14,7 @@
  *
  * You should have received a copy of the GNU General Public License
  * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  */
 
 #ifdef HAVE_CONFIG_H
@@ -52,7 +52,7 @@ static struct _PersonEdit_dlg {
        GtkWidget *statusbar;
        gint status_cid;
 
-       /* Basic data tab */
+       /* User data tab */
        GtkWidget *entry_name;
        GtkWidget *entry_first;
        GtkWidget *entry_last;
@@ -80,6 +80,7 @@ static struct _PersonEdit_dlg {
        gint rowIndEMail;
        gint rowIndAttrib;
        gboolean editNew;
+       gboolean read_only;
 
 } personeditdlg;
 
@@ -224,9 +225,11 @@ static void edit_person_email_list_selected( GtkCList *clist, gint row, gint col
                        gtk_entry_set_text( GTK_ENTRY(personeditdlg.entry_alias), ADDRITEM_NAME(email) );
                if( email->remarks )
                        gtk_entry_set_text( GTK_ENTRY(personeditdlg.entry_remarks), email->remarks );
-               gtk_widget_set_sensitive(personeditdlg.email_del, TRUE);
-               gtk_widget_set_sensitive(personeditdlg.email_up, row > 0);
-               gtk_widget_set_sensitive(personeditdlg.email_down, gtk_clist_get_row_data(clist, row + 1) != NULL);
+               if (!personeditdlg.read_only) {
+                       gtk_widget_set_sensitive(personeditdlg.email_del, TRUE);
+                       gtk_widget_set_sensitive(personeditdlg.email_up, row > 0);
+                       gtk_widget_set_sensitive(personeditdlg.email_down, gtk_clist_get_row_data(clist, row + 1) != NULL);
+               }
        } else {
                gtk_widget_set_sensitive(personeditdlg.email_del, FALSE);
                gtk_widget_set_sensitive(personeditdlg.email_up, FALSE);
@@ -243,8 +246,10 @@ static void edit_person_email_move( gint dir ) {
        if( email ) {
                gtk_clist_row_move( clist, personeditdlg.rowIndEMail, row );
                personeditdlg.rowIndEMail = row;
-               gtk_widget_set_sensitive(personeditdlg.email_up, row > 0);
-               gtk_widget_set_sensitive(personeditdlg.email_down, gtk_clist_get_row_data(clist, row + 1) != NULL);
+               if (!personeditdlg.read_only) {
+                       gtk_widget_set_sensitive(personeditdlg.email_up, row > 0);
+                       gtk_widget_set_sensitive(personeditdlg.email_down, gtk_clist_get_row_data(clist, row + 1) != NULL);
+               }
        } else {
                gtk_widget_set_sensitive(personeditdlg.email_up, FALSE);
                gtk_widget_set_sensitive(personeditdlg.email_down, FALSE);
@@ -278,9 +283,11 @@ static void edit_person_email_delete( gpointer data ) {
        if( ! email ) {
                personeditdlg.rowIndEMail = -1 + row;
        }
-       gtk_widget_set_sensitive(personeditdlg.email_del, gtk_clist_get_row_data(clist, 0) != NULL);
-       gtk_widget_set_sensitive(personeditdlg.email_up, gtk_clist_get_row_data(clist, personeditdlg.rowIndEMail + 1) != NULL);
-       gtk_widget_set_sensitive(personeditdlg.email_down, gtk_clist_get_row_data(clist, personeditdlg.rowIndEMail - 1) != NULL);
+       if (!personeditdlg.read_only) {
+               gtk_widget_set_sensitive(personeditdlg.email_del, gtk_clist_get_row_data(clist, 0) != NULL);
+               gtk_widget_set_sensitive(personeditdlg.email_up, gtk_clist_get_row_data(clist, personeditdlg.rowIndEMail + 1) != NULL);
+               gtk_widget_set_sensitive(personeditdlg.email_down, gtk_clist_get_row_data(clist, personeditdlg.rowIndEMail - 1) != NULL);
+       }
        edit_person_status_show( NULL );
 }
 
@@ -423,7 +430,7 @@ static void edit_person_load_attrib( ItemPerson *person ) {
 
 static void edit_person_attrib_list_selected( GtkCList *clist, gint row, gint column, GdkEvent *event, gpointer data ) {
        UserAttribute *attrib = gtk_clist_get_row_data( clist, row );
-       if( attrib ) {
+       if( attrib && !personeditdlg.read_only) {
                gtk_entry_set_text( GTK_ENTRY(personeditdlg.entry_atname), attrib->name );
                gtk_entry_set_text( GTK_ENTRY(personeditdlg.entry_atvalue), attrib->value );
                gtk_widget_set_sensitive(personeditdlg.attrib_del, TRUE);
@@ -452,7 +459,8 @@ static void edit_person_attrib_delete( gpointer data ) {
                personeditdlg.rowIndAttrib = -1 + row;
        } 
        
-       gtk_widget_set_sensitive(personeditdlg.attrib_del, gtk_clist_get_row_data(clist, 0) != NULL);
+       if (!personeditdlg.read_only)
+               gtk_widget_set_sensitive(personeditdlg.attrib_del, gtk_clist_get_row_data(clist, 0) != NULL);
        
        edit_person_status_show( NULL );
 }
@@ -523,6 +531,18 @@ static void edit_person_attrib_add( gpointer data ) {
        }
 }
 
+/*!
+ *\brief       Save Gtk object size to prefs dataset
+ */
+static void edit_person_size_allocate_cb(GtkWidget *widget,
+                                        GtkAllocation *allocation)
+{
+       g_return_if_fail(allocation != NULL);
+
+       prefs_common.addressbookeditpersonwin_width = allocation->width;
+       prefs_common.addressbookeditpersonwin_height = allocation->height;
+}
+
 static void addressbook_edit_person_dialog_create( gboolean *cancelled ) {
        GtkWidget *window;
        GtkWidget *vbox;
@@ -533,9 +553,9 @@ static void addressbook_edit_person_dialog_create( gboolean *cancelled ) {
        GtkWidget *cancel_btn;
        GtkWidget *hsbox;
        GtkWidget *statusbar;
+       static GdkGeometry geometry;
 
        window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
-       gtk_widget_set_size_request(window, EDITPERSON_WIDTH, EDITPERSON_HEIGHT );
        /* gtk_container_set_border_width(GTK_CONTAINER(window), 0); */
        gtk_window_set_title(GTK_WINDOW(window), _("Edit Person Data"));
        gtk_window_set_position(GTK_WINDOW(window), GTK_WIN_POS_CENTER);
@@ -543,6 +563,9 @@ static void addressbook_edit_person_dialog_create( gboolean *cancelled ) {
        g_signal_connect(G_OBJECT(window), "delete_event",
                         G_CALLBACK(edit_person_delete_event),
                         cancelled);
+       g_signal_connect(G_OBJECT(window), "size_allocate",
+                        G_CALLBACK(edit_person_size_allocate_cb),
+                       cancelled);
        g_signal_connect(G_OBJECT(window), "key_press_event",
                         G_CALLBACK(edit_person_key_pressed),
                         cancelled);
@@ -585,6 +608,16 @@ static void addressbook_edit_person_dialog_create( gboolean *cancelled ) {
 
        gtk_widget_show_all(vbox);
 
+       if (!geometry.min_height) {
+               geometry.min_width = EDITPERSON_WIDTH;
+               geometry.min_height = EDITPERSON_HEIGHT;
+       }
+
+       gtk_window_set_geometry_hints(GTK_WINDOW(window), NULL, &geometry,
+                                     GDK_HINT_MIN_SIZE);
+       gtk_widget_set_size_request(window, prefs_common.addressbookeditpersonwin_width,
+                                   prefs_common.addressbookeditpersonwin_height);
+
        personeditdlg.window     = window;
        personeditdlg.notebook   = notebook;
        personeditdlg.ok_btn     = ok_btn;
@@ -663,6 +696,11 @@ static gboolean email_adding = FALSE, email_saving = FALSE;
 
 static void edit_person_entry_email_changed (GtkWidget *entry, gpointer data)
 {
+       gboolean non_empty = gtk_clist_get_row_data(GTK_CLIST(personeditdlg.clist_email), 0) != NULL;
+
+       if (personeditdlg.read_only)
+               return;
+
        if (gtk_entry_get_text(GTK_ENTRY(personeditdlg.entry_email)) == NULL
        ||  strlen(gtk_entry_get_text(GTK_ENTRY(personeditdlg.entry_email))) == 0) {
                gtk_widget_set_sensitive(personeditdlg.email_add,FALSE);
@@ -671,24 +709,24 @@ static void edit_person_entry_email_changed (GtkWidget *entry, gpointer data)
                email_saving = FALSE;
        } else if (list_find_email(gtk_entry_get_text(GTK_ENTRY(personeditdlg.entry_email)))) {
                gtk_widget_set_sensitive(personeditdlg.email_add,FALSE);
-               gtk_widget_set_sensitive(personeditdlg.email_mod,TRUE);
+               gtk_widget_set_sensitive(personeditdlg.email_mod,non_empty);
                email_adding = FALSE;
-               email_saving = TRUE;
+               email_saving = non_empty;
        } else {
                gtk_widget_set_sensitive(personeditdlg.email_add,TRUE);
-               gtk_widget_set_sensitive(personeditdlg.email_mod,FALSE);
+               gtk_widget_set_sensitive(personeditdlg.email_mod,non_empty);
                email_adding = TRUE;
-               email_saving = FALSE;
+               email_saving = non_empty;
        }
 }
 
 static gboolean edit_person_entry_email_pressed(GtkWidget *widget, GdkEventKey *event, gpointer data)
 {
        if (event && event->keyval == GDK_Return) {
-               if (email_adding)
+               if (email_saving)
+                       edit_person_email_modify(NULL);         
+               else if (email_adding)
                        edit_person_email_add(NULL);
-               else if (email_saving)
-                       edit_person_email_modify(NULL);
        }
        return FALSE;
 }
@@ -856,6 +894,11 @@ static gboolean attrib_adding = FALSE, attrib_saving = FALSE;
 
 static void edit_person_entry_att_changed (GtkWidget *entry, gpointer data)
 {
+       gboolean non_empty = gtk_clist_get_row_data(GTK_CLIST(personeditdlg.clist_attrib), 0) != NULL;
+
+       if (personeditdlg.read_only)
+               return;
+
        if (gtk_entry_get_text(GTK_ENTRY(personeditdlg.entry_atname)) == NULL
        ||  strlen(gtk_entry_get_text(GTK_ENTRY(personeditdlg.entry_atname))) == 0) {
                gtk_widget_set_sensitive(personeditdlg.attrib_add,FALSE);
@@ -864,24 +907,24 @@ static void edit_person_entry_att_changed (GtkWidget *entry, gpointer data)
                attrib_saving = FALSE;
        } else if (list_find_attribute(gtk_entry_get_text(GTK_ENTRY(personeditdlg.entry_atname)))) {
                gtk_widget_set_sensitive(personeditdlg.attrib_add,FALSE);
-               gtk_widget_set_sensitive(personeditdlg.attrib_mod,TRUE);
+               gtk_widget_set_sensitive(personeditdlg.attrib_mod,non_empty);
                attrib_adding = FALSE;
-               attrib_saving = TRUE;
+               attrib_saving = non_empty;
        } else {
                gtk_widget_set_sensitive(personeditdlg.attrib_add,TRUE);
-               gtk_widget_set_sensitive(personeditdlg.attrib_mod,FALSE);
+               gtk_widget_set_sensitive(personeditdlg.attrib_mod,non_empty);
                attrib_adding = TRUE;
-               attrib_saving = FALSE;
+               attrib_saving = non_empty;
        }
 }
 
 static gboolean edit_person_entry_att_pressed(GtkWidget *widget, GdkEventKey *event, gpointer data)
 {
        if (event && event->keyval == GDK_Return) {
-               if (attrib_adding)
-                       edit_person_attrib_add(NULL);
-               else if (attrib_saving)
+               if (attrib_saving)
                        edit_person_attrib_modify(NULL);
+               else if (attrib_adding)
+                       edit_person_attrib_add(NULL);
        }
        return FALSE;
 }
@@ -1024,9 +1067,9 @@ static void addressbook_edit_person_page_attrib( gint pageNum, gchar *pageLbl )
 
 static void addressbook_edit_person_create( gboolean *cancelled ) {
        addressbook_edit_person_dialog_create( cancelled );
-       addressbook_edit_person_page_basic( PAGE_BASIC, _( "Basic Data" ) );
-       addressbook_edit_person_page_email( PAGE_EMAIL, _( "E-Mail Address" ) );
-       addressbook_edit_person_page_attrib( PAGE_ATTRIBUTES, _( "User Attributes" ) );
+       addressbook_edit_person_page_basic( PAGE_BASIC, _( "User Data" ) );
+       addressbook_edit_person_page_email( PAGE_EMAIL, _( "E-Mail Addresses" ) );
+       addressbook_edit_person_page_attrib( PAGE_ATTRIBUTES, _( "Other Attributes" ) );
        gtk_widget_show_all( personeditdlg.window );
 }
 
@@ -1060,6 +1103,27 @@ static GList *edit_person_build_attrib_list() {
        return listAttrib;
 }
 
+static void update_sensitivity(void)
+{
+       gtk_widget_set_sensitive(personeditdlg.entry_name,    !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.entry_first,   !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.entry_last,    !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.entry_nick,    !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.entry_email,   !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.entry_alias,   !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.entry_remarks, !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.email_up,      !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.email_down,    !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.email_del,     !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.email_mod,     !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.email_add,     !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.entry_atname,  !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.entry_atvalue, !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.attrib_add,    !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.attrib_del,    !personeditdlg.read_only);
+       gtk_widget_set_sensitive(personeditdlg.attrib_mod,    !personeditdlg.read_only);
+}
+
 /*
 * Edit person.
 * Enter: abf    Address book.
@@ -1079,6 +1143,10 @@ ItemPerson *addressbook_edit_person( AddressBookFile *abf, ItemFolder *parent, I
                addressbook_edit_person_create(&cancelled);
        gtk_widget_grab_focus(personeditdlg.ok_btn);
        gtk_widget_grab_focus(personeditdlg.entry_name);
+       
+       personeditdlg.read_only = (abf == NULL);
+       update_sensitivity();
+
        gtk_widget_show(personeditdlg.window);
        manage_window_set_transient(GTK_WINDOW(personeditdlg.window));
 
@@ -1140,7 +1208,7 @@ ItemPerson *addressbook_edit_person( AddressBookFile *abf, ItemFolder *parent, I
        }
 
        cn = gtk_editable_get_chars( GTK_EDITABLE(personeditdlg.entry_name), 0, -1 );
-       if( person ) {
+       if( person && abf ) {
                /* Update email/attribute list for existing person */
                addrbook_update_address_list( abf, person, listEMail );
                addrbook_update_attrib_list( abf, person, listAttrib );
@@ -1151,7 +1219,7 @@ ItemPerson *addressbook_edit_person( AddressBookFile *abf, ItemFolder *parent, I
                        /* Wasting our time */
                        if( listEMail == NULL && listAttrib == NULL ) cancelled = TRUE;
                }
-               if( ! cancelled ) {
+               if( ! cancelled && abf ) {
                        person = addrbook_add_address_list( abf, parent, listEMail );
                        addrbook_add_attrib_list( abf, person, listAttrib );
                }