2007-10-10 [colin] 3.0.2cvs53
[claws.git] / src / addressadd.c
index b130386941a1ba2aa199197641560b9c74b58b56..065b40f94039890130aec82c57d003e5c12fc5a9 100644 (file)
@@ -1,10 +1,10 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 2001-2006 Match Grun and the Sylpheed-Claws team
+ * Copyright (C) 2001-2007 Match Grun and the Claws Mail team
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
+ * the Free Software Foundation; either version 3 of the License, or
  * (at your option) any later version.
  *
  * This program is distributed in the hope that it will be useful,
@@ -13,8 +13,8 @@
  * GNU General Public License for more details.
  *
  * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ * 
  */
 
 /*
@@ -46,6 +46,9 @@
 #include "addrbook.h"
 #include "addrindex.h"
 #include "manage_window.h"
+#include "ldapserver.h"
+#include "ldapupdate.h"
+#include "alertpanel.h"
 
 typedef struct {
        AddressBookFile *book;
@@ -54,6 +57,7 @@ typedef struct {
 
 static struct _AddressAdd_dlg {
        GtkWidget *window;
+       GtkWidget *picture;
        GtkWidget *entry_name;
        GtkWidget *label_address;
        GtkWidget *entry_remarks;
@@ -141,11 +145,21 @@ static gboolean addressadd_tree_button( GtkCTree *ctree, GdkEventButton *event,
        return FALSE;
 }
 
+static void addressadd_size_allocate_cb(GtkWidget *widget,
+                                        GtkAllocation *allocation)
+{
+       g_return_if_fail(allocation != NULL);
+
+       prefs_common.addressaddwin_width = allocation->width;
+       prefs_common.addressaddwin_height = allocation->height;
+}
+
 static void addressadd_create( void ) {
        GtkWidget *window;
-       GtkWidget *vbox;
+       GtkWidget *vbox, *hbox;
        GtkWidget *table;
        GtkWidget *label;
+       GtkWidget *picture;
        GtkWidget *entry_name;
        GtkWidget *label_addr;
        GtkWidget *entry_rems;
@@ -158,9 +172,9 @@ static void addressadd_create( void ) {
        GtkWidget *hsbox;
        GtkWidget *statusbar;
        gint top;
+       static GdkGeometry geometry;
 
-       window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
-       gtk_widget_set_size_request( window, 300, 400 );
+       window = gtkut_window_new(GTK_WINDOW_TOPLEVEL, "addressadd");
        gtk_container_set_border_width( GTK_CONTAINER(window), 0 );
        gtk_window_set_title( GTK_WINDOW(window), _("Add to address book") );
        gtk_window_set_position( GTK_WINDOW(window), GTK_WIN_POS_MOUSE );
@@ -169,13 +183,20 @@ static void addressadd_create( void ) {
                          G_CALLBACK(addressadd_delete_event), NULL );
        g_signal_connect( G_OBJECT(window), "key_press_event",
                          G_CALLBACK(addressadd_key_pressed), NULL );
+       g_signal_connect(G_OBJECT(window), "size_allocate",
+                        G_CALLBACK(addressadd_size_allocate_cb), NULL);
 
+       hbox = gtk_hbox_new(FALSE, 6);
        vbox = gtk_vbox_new(FALSE, 8);
        gtk_container_add(GTK_CONTAINER(window), vbox);
        gtk_container_set_border_width( GTK_CONTAINER(vbox), 8 );
 
+       picture = gtk_image_new();
+       gtk_box_pack_start(GTK_BOX(hbox), picture, FALSE, FALSE, 0);
+
        table = gtk_table_new(3, 2, FALSE);
-       gtk_box_pack_start(GTK_BOX(vbox), table, FALSE, FALSE, 0);
+       gtk_box_pack_start(GTK_BOX(hbox), table, FALSE, FALSE, 0);
+       gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 0);
        gtk_container_set_border_width( GTK_CONTAINER(table), 8 );
        gtk_table_set_row_spacings(GTK_TABLE(table), 8);
        gtk_table_set_col_spacings(GTK_TABLE(table), 8);
@@ -240,8 +261,8 @@ static void addressadd_create( void ) {
        gtk_box_pack_start(GTK_BOX(hsbox), statusbar, TRUE, TRUE, BORDER_WIDTH);
 
        /* Button panel */
-       gtkut_stock_button_set_create(&hbbox, &ok_btn, GTK_STOCK_OK,
-                                     &cancel_btn, GTK_STOCK_CANCEL,
+       gtkut_stock_button_set_create(&hbbox, &cancel_btn, GTK_STOCK_CANCEL,
+                                     &ok_btn, GTK_STOCK_OK,
                                      NULL, NULL);
        gtk_box_pack_end(GTK_BOX(vbox), hbbox, FALSE, FALSE, 0);
        gtk_container_set_border_width( GTK_CONTAINER(hbbox), 0 );
@@ -256,9 +277,20 @@ static void addressadd_create( void ) {
        g_signal_connect(G_OBJECT(tree_folder), "button_press_event",
                         G_CALLBACK(addressadd_tree_button), NULL);
 
+       if (!geometry.min_height) {
+               geometry.min_width = 300;
+               geometry.min_height = 400;
+       }
+
+       gtk_window_set_geometry_hints(GTK_WINDOW(window), NULL, &geometry,
+                                     GDK_HINT_MIN_SIZE);
+       gtk_widget_set_size_request(window, prefs_common.addressaddwin_width,
+                                   prefs_common.addressaddwin_height);
+
        gtk_widget_show_all(vbox);
 
        addressadd_dlg.window        = window;
+       addressadd_dlg.picture       = picture;
        addressadd_dlg.entry_name    = entry_name;
        addressadd_dlg.label_address = label_addr;
        addressadd_dlg.entry_remarks = entry_rems;
@@ -318,7 +350,8 @@ static void addressadd_load_data( AddressIndex *addrIndex ) {
        list = addrindex_get_interface_list( addrIndex );
        while( list ) {
                AddressInterface *interface = list->data;
-               if( interface->type == ADDR_IF_BOOK ) {
+               if( interface->type == ADDR_IF_BOOK || 
+                               interface->type == ADDR_IF_LDAP ) {
                        nodeDS = interface->listSource;
                        while( nodeDS ) {
                                ds = nodeDS->data;
@@ -332,7 +365,7 @@ static void addressadd_load_data( AddressIndex *addrIndex ) {
                                /* Add node for address book */
                                abf = ds->rawDataSource;
                                name = &dsName;
-                               node = gtk_sctree_insert_node( tree, NULL, NULL,
+                               node = gtk_ctree_insert_node( tree, NULL, NULL,
                                                name, FOLDER_SPACING, bookXpm,
                                                bookXpmMask, bookXpm, bookXpmMask,
                                                FALSE, TRUE );
@@ -352,11 +385,13 @@ static void addressadd_load_data( AddressIndex *addrIndex ) {
        }
 }
 
-gboolean addressadd_selection( AddressIndex *addrIndex, const gchar *name, const gchar *address, const gchar *remarks ) {
+gboolean addressadd_selection( AddressIndex *addrIndex, const gchar *name, 
+               const gchar *address, const gchar *remarks, GdkPixbuf *picture ) {
        gboolean retVal = FALSE;
        ItemPerson *person = NULL;
        FolderInfo *fi = NULL;
        addressadd_cancelled = FALSE;
+
        if( ! addressadd_dlg.window ) addressadd_create();
        gtk_widget_grab_focus(addressadd_dlg.ok_btn);
        gtk_widget_show(addressadd_dlg.window);
@@ -377,7 +412,12 @@ gboolean addressadd_selection( AddressIndex *addrIndex, const gchar *name, const
                gtk_label_set_text( GTK_LABEL(addressadd_dlg.label_address ), address );
        if( remarks )
                gtk_entry_set_text( GTK_ENTRY(addressadd_dlg.entry_remarks ), remarks );
-
+       if( picture ) {
+               gtk_image_set_from_pixbuf(GTK_IMAGE(addressadd_dlg.picture), picture);
+               gtk_widget_show(GTK_WIDGET(addressadd_dlg.picture));
+       } else {
+               gtk_widget_hide(GTK_WIDGET(addressadd_dlg.picture));
+       }
        gtk_main();
        gtk_widget_hide( addressadd_dlg.window );
 
@@ -394,6 +434,34 @@ gboolean addressadd_selection( AddressIndex *addrIndex, const gchar *name, const
                                                        returned_name, 
                                                        address, 
                                                        returned_remarks);
+                       person->status = ADD_ENTRY;
+
+                       if (picture) {
+                               GError *error = NULL;
+                               gchar *name = g_strconcat( get_rc_dir(), G_DIR_SEPARATOR_S, ADDRBOOK_DIR, G_DIR_SEPARATOR_S, 
+                                                       ADDRITEM_ID(person), ".png", NULL );
+                               gdk_pixbuf_save(picture, name, "png", &error, NULL);
+                               if (error) {
+                                       g_warning(_("Failed to save image: \n%s"),
+                                                       error->message);
+                                       g_error_free(error);
+                               }
+                               addritem_person_set_picture( person, ADDRITEM_ID(person) ) ;
+                               g_free( name );
+                       }
+#ifdef USE_LDAP
+                       if (fi->book->type == ADBOOKTYPE_LDAP) {
+                               LdapServer *server = (LdapServer *) fi->book;
+                               ldapsvr_set_modified(server, TRUE);
+                               ldapsvr_update_book(server, person);
+                               if (server->retVal != LDAPRC_SUCCESS) {
+                                       alertpanel( _("Add address(es)"),
+                                               _("Can't add the specified address"),
+                                               GTK_STOCK_CLOSE, NULL, NULL );
+                                       return server->retVal;
+                               }
+                       }
+#endif
                        g_free(returned_name);
                        g_free(returned_remarks);
                        if( person ) retVal = TRUE;