2007-01-14 [colin] 2.7.0cvs27
[claws.git] / src / gtk / inputdialog.c
index 8e955dbf2d4f20400afeecf34e5e2def2f10f172..642035595bc73f963fc57d75c1aded754b6c7019 100644 (file)
@@ -1,6 +1,6 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2003 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2007 Hiroyuki Yamamoto
  *
  * 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
@@ -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
@@ -38,6 +38,8 @@
 #include <gtk/gtkhbbox.h>
 #include <gtk/gtkstock.h>
 #include <gtk/gtkimage.h>
+#include <gtk/gtktogglebutton.h>
+#include <gtk/gtkcheckbutton.h>
 
 #include "inputdialog.h"
 #include "manage_window.h"
@@ -63,12 +65,15 @@ static GtkWidget *msg_title;
 static GtkWidget *msg_label;
 static GtkWidget *entry;
 static GtkWidget *combo;
+static GtkWidget *remember_chkbtn;
 static GtkWidget *ok_button;
-
-static void input_dialog_create        (void);
+static GtkWidget *icon_q, *icon_p;
+static gboolean is_pass = FALSE;
+static void input_dialog_create        (gboolean is_password);
 static gchar *input_dialog_open        (const gchar    *title,
                                 const gchar    *message,
-                                const gchar    *default_string);
+                                const gchar    *default_string,
+                                gboolean       *remember);
 static void input_dialog_set   (const gchar    *title,
                                 const gchar    *message,
                                 const gchar    *default_string);
@@ -93,14 +98,20 @@ gchar *input_dialog(const gchar *title, const gchar *message,
        if (dialog && GTK_WIDGET_VISIBLE(dialog)) return NULL;
 
        if (!dialog)
-               input_dialog_create();
+               input_dialog_create(FALSE);
 
        type = INPUT_DIALOG_NORMAL;
        gtk_widget_hide(combo);
        gtk_widget_show(entry);
+
+       gtk_widget_hide(remember_chkbtn);
+
+       gtk_widget_show(icon_q);
+       gtk_widget_hide(icon_p);
+       is_pass = FALSE;
        gtk_entry_set_visibility(GTK_ENTRY(entry), TRUE);
 
-       return input_dialog_open(title, message, default_string);
+       return input_dialog_open(title, message, default_string, NULL);
 }
 
 gchar *input_dialog_with_invisible(const gchar *title, const gchar *message,
@@ -109,29 +120,52 @@ gchar *input_dialog_with_invisible(const gchar *title, const gchar *message,
        if (dialog && GTK_WIDGET_VISIBLE(dialog)) return NULL;
 
        if (!dialog)
-               input_dialog_create();
+               input_dialog_create(TRUE);
 
        type = INPUT_DIALOG_INVISIBLE;
        gtk_widget_hide(combo);
        gtk_widget_show(entry);
+       gtk_widget_hide(remember_chkbtn);
+
+       gtk_widget_hide(icon_q);
+       gtk_widget_show(icon_p);
+       is_pass = TRUE;
        gtk_entry_set_visibility(GTK_ENTRY(entry), FALSE);
 
-       return input_dialog_open(title, message, default_string);
+       return input_dialog_open(title, message, default_string, NULL);
 }
 
 gchar *input_dialog_combo(const gchar *title, const gchar *message,
                          const gchar *default_string, GList *list,
                          gboolean case_sensitive)
+{
+       return input_dialog_combo_remember(title, message, 
+               default_string, list, case_sensitive, NULL);
+}
+
+gchar *input_dialog_combo_remember(const gchar *title, const gchar *message,
+                         const gchar *default_string, GList *list,
+                         gboolean case_sensitive, gboolean *remember)
 {
        if (dialog && GTK_WIDGET_VISIBLE(dialog)) return NULL;
 
        if (!dialog)
-               input_dialog_create();
+               input_dialog_create(FALSE);
 
        type = INPUT_DIALOG_COMBO;
        gtk_widget_hide(entry);
        gtk_widget_show(combo);
 
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(remember_chkbtn), FALSE);
+       if (remember)
+               gtk_widget_show(remember_chkbtn);
+       else
+               gtk_widget_hide(remember_chkbtn);
+
+       gtk_widget_show(icon_q);
+       gtk_widget_hide(icon_p);
+       is_pass = FALSE;
+
        if (!list) {
                GList empty_list;
 
@@ -144,7 +178,7 @@ gchar *input_dialog_combo(const gchar *title, const gchar *message,
 
        gtk_combo_set_case_sensitive(GTK_COMBO(combo), case_sensitive);
 
-       return input_dialog_open(title, message, default_string);
+       return input_dialog_open(title, message, default_string, remember);
 }
 
 gchar *input_dialog_query_password(const gchar *server, const gchar *user)
@@ -160,20 +194,19 @@ gchar *input_dialog_query_password(const gchar *server, const gchar *user)
        return pass;
 }
 
-static void input_dialog_create(void)
+static void input_dialog_create(gboolean is_password)
 {
        static PangoFontDescription *font_desc;
        GtkWidget *w_hbox;
        GtkWidget *hbox;
        GtkWidget *vbox;
-       GtkWidget *ok_button;
        GtkWidget *cancel_button;
        GtkWidget *confirm_area;
-       GtkWidget *icon;
 
        dialog = gtk_dialog_new();
 
        gtk_window_set_resizable(GTK_WINDOW(dialog), FALSE);
+       gtk_window_set_default_size(GTK_WINDOW(dialog), 375, 100);
        gtk_window_set_title(GTK_WINDOW(dialog), "");
        gtk_dialog_set_has_separator (GTK_DIALOG (dialog), FALSE);
 
@@ -193,10 +226,14 @@ static void input_dialog_create(void)
        /* for title label */
        w_hbox = gtk_hbox_new(FALSE, 0);
        
-       icon = gtk_image_new_from_stock(GTK_STOCK_DIALOG_QUESTION,
-                                       GTK_ICON_SIZE_DIALOG); 
-       gtk_misc_set_alignment (GTK_MISC (icon), 0.5, 0.0);
-       gtk_box_pack_start (GTK_BOX (hbox), icon, FALSE, FALSE, 0);
+       icon_q = gtk_image_new_from_stock(GTK_STOCK_DIALOG_QUESTION,
+                               GTK_ICON_SIZE_DIALOG); 
+       gtk_misc_set_alignment (GTK_MISC (icon_q), 0.5, 0.0);
+       gtk_box_pack_start (GTK_BOX (hbox), icon_q, FALSE, FALSE, 0);
+       icon_p = gtk_image_new_from_stock(GTK_STOCK_DIALOG_AUTHENTICATION,
+                               GTK_ICON_SIZE_DIALOG); 
+       gtk_misc_set_alignment (GTK_MISC (icon_p), 0.5, 0.0);
+       gtk_box_pack_start (GTK_BOX (hbox), icon_p, FALSE, FALSE, 0);
        
        vbox = gtk_vbox_new (FALSE, 12);
        gtk_box_pack_start (GTK_BOX (hbox), vbox, TRUE, TRUE, 0);
@@ -238,11 +275,14 @@ static void input_dialog_create(void)
        g_signal_connect(G_OBJECT(GTK_COMBO(combo)->entry), "activate",
                         G_CALLBACK(combo_activated), NULL);
 
+       remember_chkbtn = gtk_check_button_new_with_label(_("Remember this"));
+       gtk_box_pack_start(GTK_BOX(vbox), remember_chkbtn, FALSE, FALSE, 0);
+
        hbox = gtk_hbox_new(TRUE, 0);
 
        gtkut_stock_button_set_create(&confirm_area,
-                                     &ok_button, GTK_STOCK_OK,
                                      &cancel_button, GTK_STOCK_CANCEL,
+                                     &ok_button, GTK_STOCK_OK,
                                      NULL, NULL);
 
        gtk_box_pack_end(GTK_BOX(GTK_DIALOG(dialog)->action_area),
@@ -251,6 +291,15 @@ static void input_dialog_create(void)
 
        gtk_widget_show_all(GTK_DIALOG(dialog)->vbox);
        
+       gtk_widget_hide(remember_chkbtn);
+
+       if (is_password)
+               gtk_widget_hide(icon_q);
+       else
+               gtk_widget_hide(icon_p);
+
+       is_pass = is_password;
+
        gtk_widget_grab_default(ok_button);
 
        g_signal_connect(G_OBJECT(ok_button), "clicked",
@@ -260,17 +309,24 @@ static void input_dialog_create(void)
 }
 
 static gchar *input_dialog_open(const gchar *title, const gchar *message,
-                               const gchar *default_string)
+                               const gchar *default_string, gboolean *remember)
 {
        gchar *str;
 
        if (dialog && GTK_WIDGET_VISIBLE(dialog)) return NULL;
 
        if (!dialog)
-               input_dialog_create();
+               input_dialog_create(FALSE);
 
        input_dialog_set(title, message, default_string);
        gtk_widget_show(dialog);
+
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(remember_chkbtn), FALSE);
+       if (remember)
+               gtk_widget_show(remember_chkbtn);
+       else
+               gtk_widget_hide(remember_chkbtn);
+
        gtk_window_set_modal(GTK_WINDOW(dialog), TRUE);
        manage_window_set_transient(GTK_WINDOW(dialog));
 
@@ -291,7 +347,7 @@ static gchar *input_dialog_open(const gchar *title, const gchar *message,
                        editable = GTK_EDITABLE(entry);
 
                str = gtk_editable_get_chars(editable, 0, -1);
-               if (str && *str == '\0') {
+               if (str && *str == '\0' && !is_pass) {
                        g_free(str);
                        str = NULL;
                }
@@ -300,7 +356,13 @@ static gchar *input_dialog_open(const gchar *title, const gchar *message,
 
        GTK_EVENTS_FLUSH();
 
-       debug_print("return string = %s\n", str ? str : "(none)");
+       if (remember) {
+               *remember = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(remember_chkbtn));
+       }
+       if (is_pass)
+               debug_print("return string = %s\n", str ? "********": ("none"));
+       else
+               debug_print("return string = %s\n", str ? str : "(none)");
        return str;
 }