/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2006 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2012 Hiroyuki Yamamoto 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,
* 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/>.
+ *
*/
#ifdef HAVE_CONFIG_H
# include "config.h"
+#include "claws-features.h"
#endif
#include <glib.h>
#include <glib/gi18n.h>
#include <gdk/gdkkeysyms.h>
-#include <gtk/gtkmain.h>
-#include <gtk/gtkwidget.h>
-#include <gtk/gtkdialog.h>
-#include <gtk/gtkwindow.h>
-#include <gtk/gtksignal.h>
-#include <gtk/gtkvbox.h>
-#include <gtk/gtkhbox.h>
-#include <gtk/gtklabel.h>
-#include <gtk/gtkentry.h>
-#include <gtk/gtkcombo.h>
-#include <gtk/gtkbutton.h>
-#include <gtk/gtkhbbox.h>
-#include <gtk/gtkstock.h>
-#include <gtk/gtkimage.h>
-#include <gtk/gtktogglebutton.h>
-#include <gtk/gtkcheckbutton.h>
+#include <gtk/gtk.h>
#include "inputdialog.h"
#include "manage_window.h"
#include "gtkutils.h"
#include "utils.h"
+#include "combobox.h"
+#include "prefs_common.h"
+
#define INPUT_DIALOG_WIDTH 420
static GtkWidget *msg_label;
static GtkWidget *entry;
static GtkWidget *combo;
-static GtkWidget *remember_chkbtn;
+static GtkWidget *remember_checkbtn;
static GtkWidget *ok_button;
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 *checkbtn_label,
const gchar *default_string,
+ gboolean default_checkbtn_state,
gboolean *remember);
static void input_dialog_set (const gchar *title,
const gchar *message,
gchar *input_dialog(const gchar *title, const gchar *message,
const gchar *default_string)
{
- if (dialog && GTK_WIDGET_VISIBLE(dialog)) return NULL;
+ if (dialog && gtk_widget_get_visible(dialog)) return NULL;
if (!dialog)
input_dialog_create(FALSE);
gtk_widget_hide(combo);
gtk_widget_show(entry);
- gtk_widget_hide(remember_chkbtn);
+ gtk_widget_hide(remember_checkbtn);
gtk_widget_show(icon_q);
gtk_widget_hide(icon_p);
is_pass = FALSE;
gtk_entry_set_visibility(GTK_ENTRY(entry), TRUE);
+#ifdef MAEMO
+ hildon_gtk_entry_set_input_mode(GTK_ENTRY(entry),
+ HILDON_GTK_INPUT_MODE_FULL | HILDON_GTK_INPUT_MODE_AUTOCAP);
+#endif
- return input_dialog_open(title, message, default_string, NULL);
+ return input_dialog_open(title, message, NULL, default_string, FALSE, NULL);
}
gchar *input_dialog_with_invisible(const gchar *title, const gchar *message,
const gchar *default_string)
{
- if (dialog && GTK_WIDGET_VISIBLE(dialog)) return NULL;
+ if (dialog && gtk_widget_get_visible(dialog)) return NULL;
+
+ if (!dialog)
+ input_dialog_create(TRUE);
+
+ type = INPUT_DIALOG_INVISIBLE;
+ gtk_widget_hide(combo);
+ gtk_widget_show(entry);
+ gtk_widget_hide(remember_checkbtn);
+
+ gtk_widget_hide(icon_q);
+ gtk_widget_show(icon_p);
+ is_pass = TRUE;
+ gtk_entry_set_visibility(GTK_ENTRY(entry), FALSE);
+#ifdef MAEMO
+ hildon_gtk_entry_set_input_mode(GTK_ENTRY(entry),
+ HILDON_GTK_INPUT_MODE_FULL | HILDON_GTK_INPUT_MODE_INVISIBLE);
+#endif
+
+ return input_dialog_open(title, message, NULL, default_string, FALSE, NULL);
+}
+
+gchar *input_dialog_with_invisible_checkbtn(const gchar *title, const gchar *message,
+ const gchar *default_string, const gchar *checkbtn_label,
+ gboolean *checkbtn_state)
+{
+ if (dialog && gtk_widget_get_visible(dialog)) return NULL;
if (!dialog)
input_dialog_create(TRUE);
type = INPUT_DIALOG_INVISIBLE;
gtk_widget_hide(combo);
gtk_widget_show(entry);
- gtk_widget_hide(remember_chkbtn);
+
+ if (checkbtn_label && checkbtn_state) {
+ gtk_widget_show(remember_checkbtn);
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(remember_checkbtn), *checkbtn_state);
+ }
+ else {
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(remember_checkbtn), FALSE);
+ gtk_widget_hide(remember_checkbtn);
+ }
gtk_widget_hide(icon_q);
gtk_widget_show(icon_p);
is_pass = TRUE;
gtk_entry_set_visibility(GTK_ENTRY(entry), FALSE);
+#ifdef MAEMO
+ hildon_gtk_entry_set_input_mode(GTK_ENTRY(entry),
+ HILDON_GTK_INPUT_MODE_FULL | HILDON_GTK_INPUT_MODE_INVISIBLE);
+#endif
- return input_dialog_open(title, message, default_string, NULL);
+ return input_dialog_open(title, message, checkbtn_label, default_string, (checkbtn_state? *checkbtn_state:FALSE), checkbtn_state);
}
gchar *input_dialog_combo(const gchar *title, const gchar *message,
- const gchar *default_string, GList *list,
- gboolean case_sensitive)
+ const gchar *default_string, GList *list)
{
return input_dialog_combo_remember(title, message,
- default_string, list, case_sensitive, NULL);
+ default_string, list, FALSE);
}
gchar *input_dialog_combo_remember(const gchar *title, const gchar *message,
const gchar *default_string, GList *list,
- gboolean case_sensitive, gboolean *remember)
+ gboolean *remember)
{
- if (dialog && GTK_WIDGET_VISIBLE(dialog)) return NULL;
+ if (dialog && gtk_widget_get_visible(dialog)) return NULL;
if (!dialog)
input_dialog_create(FALSE);
gtk_widget_hide(entry);
gtk_widget_show(combo);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(remember_chkbtn), FALSE);
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(remember_checkbtn), FALSE);
if (remember)
- gtk_widget_show(remember_chkbtn);
+ gtk_widget_show(remember_checkbtn);
else
- gtk_widget_hide(remember_chkbtn);
+ gtk_widget_hide(remember_checkbtn);
gtk_widget_show(icon_q);
gtk_widget_hide(icon_p);
is_pass = FALSE;
- if (!list) {
- GList empty_list;
+ combobox_unset_popdown_strings(GTK_COMBO_BOX(combo));
+ combobox_set_popdown_strings(GTK_COMBO_BOX(combo), list);
- empty_list.data = (gpointer)"";
- empty_list.next = NULL;
- empty_list.prev = NULL;
- gtk_combo_set_popdown_strings(GTK_COMBO(combo), &empty_list);
- } else
- gtk_combo_set_popdown_strings(GTK_COMBO(combo), list);
+ return input_dialog_open(title, message, NULL, default_string, FALSE, remember);
+}
+
+gchar *input_dialog_with_checkbtn(const gchar *title,
+ const gchar *message,
+ const gchar *default_string,
+ const gchar *checkbtn_label,
+ gboolean *checkbtn_state)
+{
+ if (dialog && gtk_widget_get_visible(dialog)) return NULL;
- gtk_combo_set_case_sensitive(GTK_COMBO(combo), case_sensitive);
+ if (!dialog)
+ input_dialog_create(FALSE);
- return input_dialog_open(title, message, default_string, remember);
+ type = INPUT_DIALOG_NORMAL;
+ gtk_widget_hide(combo);
+ gtk_widget_show(entry);
+
+ if (checkbtn_label && checkbtn_state)
+ gtk_widget_show(remember_checkbtn);
+ else
+ gtk_widget_hide(remember_checkbtn);
+
+ gtk_widget_show(icon_q);
+ gtk_widget_hide(icon_p);
+ is_pass = FALSE;
+ gtk_entry_set_visibility(GTK_ENTRY(entry), TRUE);
+#ifdef MAEMO
+ hildon_gtk_entry_set_input_mode(GTK_ENTRY(entry),
+ HILDON_GTK_INPUT_MODE_FULL | HILDON_GTK_INPUT_MODE_AUTOCAP);
+#endif
+
+ return input_dialog_open(title, message, checkbtn_label, default_string,
+ prefs_common.inherit_folder_props, checkbtn_state);
}
gchar *input_dialog_query_password(const gchar *server, const gchar *user)
gchar *message;
gchar *pass;
- message = g_strdup_printf(_("Input password for %s on %s:"),
+ if (server && user)
+ message = g_strdup_printf(_("Input password for %s on %s:"),
user, server);
+ else if (server)
+ message = g_strdup_printf(_("Input password for %s:"),
+ server);
+ else if (user)
+ message = g_strdup_printf(_("Input password for %s:"),
+ user);
+ else
+ message = g_strdup_printf(_("Input password:"));
pass = input_dialog_with_invisible(_("Input password"), message, NULL);
g_free(message);
return pass;
}
+gchar *input_dialog_query_password_keep(const gchar *server, const gchar *user, gchar **keep)
+{
+ gchar *message;
+ gchar *pass;
+
+ if (server && user)
+ message = g_strdup_printf(_("Input password for %s on %s:"),
+ user, server);
+ else if (server)
+ message = g_strdup_printf(_("Input password for %s:"),
+ server);
+ else if (user)
+ message = g_strdup_printf(_("Input password for %s:"),
+ user);
+ else
+ message = g_strdup_printf(_("Input password:"));
+ if (keep) {
+ if (*keep != NULL) {
+ pass = g_strdup (*keep);
+ }
+ else {
+ gboolean state = prefs_common.session_passwords;
+ pass = input_dialog_with_invisible_checkbtn(_("Input password"),
+ message, NULL,
+ _("Remember password for this session"),
+ &state);
+ if (state) {
+ *keep = g_strdup (pass);
+ debug_print("keeping session password for account\n");
+ }
+ prefs_common.session_passwords = state;
+ }
+ }
+ else {
+ pass = input_dialog_with_invisible(_("Input password"), message, NULL);
+ }
+ g_free(message);
+
+ return pass;
+}
+
static void input_dialog_create(gboolean is_password)
{
static PangoFontDescription *font_desc;
- GtkWidget *w_hbox;
GtkWidget *hbox;
GtkWidget *vbox;
GtkWidget *cancel_button;
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);
g_signal_connect(G_OBJECT(dialog), "delete_event",
G_CALLBACK(delete_event), NULL);
G_CALLBACK(key_pressed), NULL);
MANAGE_WINDOW_SIGNALS_CONNECT(dialog);
- gtk_box_set_spacing (GTK_BOX (GTK_DIALOG (dialog)->vbox), 14);
+ vbox = gtk_dialog_get_content_area (GTK_DIALOG (dialog));
+ gtk_box_set_spacing (GTK_BOX (vbox), 14);
hbox = gtk_hbox_new (FALSE, 12);
gtk_container_set_border_width (GTK_CONTAINER (hbox), 5);
gtk_widget_show (hbox);
- gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog)->vbox), hbox,
+ gtk_box_pack_start (GTK_BOX (vbox), hbox,
FALSE, FALSE, 0);
/* for title label */
- w_hbox = gtk_hbox_new(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);
gint size;
size = pango_font_description_get_size
- (msg_title->style->font_desc);
+ (gtk_widget_get_style(msg_title)->font_desc);
font_desc = pango_font_description_new();
pango_font_description_set_weight
(font_desc, PANGO_WEIGHT_BOLD);
g_signal_connect(G_OBJECT(entry), "activate",
G_CALLBACK(entry_activated), NULL);
- combo = gtk_combo_new();
+ combo = gtk_combo_box_entry_new_text();
gtk_box_pack_start(GTK_BOX(vbox), combo, FALSE, FALSE, 0);
- g_signal_connect(G_OBJECT(GTK_COMBO(combo)->entry), "activate",
+ g_signal_connect(G_OBJECT(gtk_bin_get_child(GTK_BIN((combo)))), "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);
+ remember_checkbtn = gtk_check_button_new_with_label(_("Remember this"));
+ gtk_box_pack_start(GTK_BOX(vbox), remember_checkbtn, FALSE, FALSE, 0);
hbox = gtk_hbox_new(TRUE, 0);
&ok_button, GTK_STOCK_OK,
NULL, NULL);
- gtk_box_pack_end(GTK_BOX(GTK_DIALOG(dialog)->action_area),
+ gtk_box_pack_end(GTK_BOX(gtk_dialog_get_action_area(GTK_DIALOG(dialog))),
confirm_area, FALSE, FALSE, 0);
gtk_container_set_border_width(GTK_CONTAINER(confirm_area), 5);
- gtk_widget_show_all(GTK_DIALOG(dialog)->vbox);
+ gtk_widget_show_all(gtk_dialog_get_content_area(GTK_DIALOG(dialog)));
- gtk_widget_hide(remember_chkbtn);
+ gtk_widget_hide(remember_checkbtn);
if (is_password)
gtk_widget_hide(icon_q);
}
static gchar *input_dialog_open(const gchar *title, const gchar *message,
- const gchar *default_string, gboolean *remember)
+ const gchar *checkbtn_label,
+ const gchar *default_string,
+ gboolean default_checkbtn_state,
+ gboolean *remember)
{
gchar *str;
- if (dialog && GTK_WIDGET_VISIBLE(dialog)) return NULL;
+ if (dialog && gtk_widget_get_visible(dialog)) return NULL;
if (!dialog)
input_dialog_create(FALSE);
+ if (checkbtn_label)
+ gtk_button_set_label(GTK_BUTTON(remember_checkbtn), checkbtn_label);
+ else
+ gtk_button_set_label(GTK_BUTTON(remember_checkbtn), _("Remember this"));
+
input_dialog_set(title, message, default_string);
- gtk_widget_show(dialog);
+ gtk_window_present(GTK_WINDOW(dialog));
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(remember_chkbtn), FALSE);
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(remember_checkbtn),
+ default_checkbtn_state);
if (remember)
- gtk_widget_show(remember_chkbtn);
+ gtk_widget_show(remember_checkbtn);
else
- gtk_widget_hide(remember_chkbtn);
+ gtk_widget_hide(remember_checkbtn);
gtk_window_set_modal(GTK_WINDOW(dialog), TRUE);
manage_window_set_transient(GTK_WINDOW(dialog));
gtk_main_iteration();
manage_window_focus_out(dialog, NULL, NULL);
- gtk_widget_hide(dialog);
if (ack) {
GtkEditable *editable;
if (type == INPUT_DIALOG_COMBO)
- editable = GTK_EDITABLE(GTK_COMBO(combo)->entry);
+ editable = GTK_EDITABLE(gtk_bin_get_child(GTK_BIN((combo))));
else
editable = GTK_EDITABLE(entry);
GTK_EVENTS_FLUSH();
if (remember) {
- *remember = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(remember_chkbtn));
+ *remember = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(remember_checkbtn));
}
- debug_print("return string = %s\n", str ? str : "(none)");
+
+ gtk_widget_destroy(dialog);
+ dialog = NULL;
+
+ if (is_pass)
+ debug_print("return string = %s\n", str ? "********": ("none"));
+ else
+ debug_print("return string = %s\n", str ? str : "(none)");
return str;
}
GtkWidget *entry_;
if (type == INPUT_DIALOG_COMBO)
- entry_ = GTK_COMBO(combo)->entry;
+ entry_ = gtk_bin_get_child(GTK_BIN((combo)));
else
entry_ = entry;
static gboolean key_pressed(GtkWidget *widget, GdkEventKey *event, gpointer data)
{
- if (event && event->keyval == GDK_Escape) {
+ if (event && event->keyval == GDK_KEY_Escape) {
ack = FALSE;
fin = TRUE;
- } else if (event && event->keyval == GDK_Return) {
+ } else if (event && event->keyval == GDK_KEY_Return) {
ack = TRUE;
fin = TRUE;
return TRUE; /* do not let Return pass - it