/*
- * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2003 Hiroyuki Yamamoto and the Sylpheed-Claws Team
+ * Claws Mail -- a GTK+ based, lightweight, and fast e-mail client
+ * Copyright (C) 1999-2007 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
*/
/*
#include "defs.h"
#include <glib.h>
+#include <glib/gi18n.h>
#include <gtk/gtk.h>
-#include "intl.h"
-#include "common/utils.h"
+#include "gtkutils.h"
+#include "utils.h"
#include "prefs.h"
#include "prefs_gtk.h"
#include "prefswindow.h"
+#include "combobox.h"
+#include "addressbook.h"
#include "dillo_prefs.h"
#define PREFS_BLOCK_NAME "Dillo"
-DilloBrowserPrefs_t dillo_prefs;
+DilloBrowserPrefs dillo_prefs;
-typedef struct _DilloBrowserPage DilloBrowserPage_t;
+typedef struct _DilloBrowserPage DilloBrowserPage;
struct _DilloBrowserPage {
PrefsPage page;
GtkWidget *local;
+ GtkWidget *whitelist_ab;
+ GtkWidget *whitelist_ab_folder_combo;
+ GtkWidget *whitelist_ab_select_btn;
GtkWidget *full;
};
static PrefParam param[] = {
{"local_browse", "TRUE", &dillo_prefs.local, P_BOOL, NULL, NULL, NULL},
{"full_window", "TRUE", &dillo_prefs.full, P_BOOL, NULL, NULL, NULL},
+ {"whitelist_ab", "FALSE", &dillo_prefs.whitelist_ab, P_BOOL,
+ NULL, NULL, NULL},
+ {"whitelist_ab_folder", N_("Any"), &dillo_prefs.whitelist_ab_folder, P_STRING,
+ NULL, NULL, NULL},
+
{0,0,0,0,0,0,0}
};
-DilloBrowserPage_t prefs_page;
+static DilloBrowserPage prefs_page;
+
+static void create_dillo_prefs_page (PrefsPage *page,
+ GtkWindow *window,
+ gpointer data);
+static void destroy_dillo_prefs_page (PrefsPage *page);
+static void save_dillo_prefs (PrefsPage *page);
+
+static void dillo_whitelist_ab_select_cb(GtkWidget *widget, gpointer data)
+{
+ DilloBrowserPage *page = (DilloBrowserPage *) data;
+ const gchar *folderpath = NULL;
+ gchar *new_path = NULL;
+
+ folderpath = gtk_entry_get_text(GTK_ENTRY(GTK_BIN(page->whitelist_ab_folder_combo)->child));
+ new_path = addressbook_folder_selection(folderpath);
+ if (new_path) {
+ gtk_entry_set_text(GTK_ENTRY(GTK_BIN(page->whitelist_ab_folder_combo)->child), new_path);
+ g_free(new_path);
+ }
+}
+
+static void local_checkbox_toggled(GtkToggleButton *button,
+ gpointer user_data)
+{
+ gboolean active = gtk_toggle_button_get_active(button);
+ DilloBrowserPage *prefs_page = (DilloBrowserPage *) user_data;
+
+ gtk_widget_set_sensitive(prefs_page->whitelist_ab, active);
+ gtk_widget_set_sensitive(prefs_page->whitelist_ab_folder_combo, active &&
+ gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prefs_page->whitelist_ab)));
+ gtk_widget_set_sensitive(prefs_page->whitelist_ab_select_btn, active &&
+ gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prefs_page->whitelist_ab)));
+}
+
+static void whitelist_checkbox_toggled(GtkToggleButton *button,
+ gpointer user_data)
+{
+ gboolean active = gtk_toggle_button_get_active(button);
+ DilloBrowserPage *prefs_page = (DilloBrowserPage *) user_data;
+
+ active &= gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prefs_page->local));
-static void create_dillo_prefs_page (PrefsPage *, GtkWindow *, gpointer);
-static void destroy_dillo_prefs_page (PrefsPage *);
-static void save_dillo_prefs (PrefsPage *);
+ gtk_widget_set_sensitive(prefs_page->whitelist_ab_folder_combo, active);
+ gtk_widget_set_sensitive(prefs_page->whitelist_ab_select_btn, active);
+}
void dillo_prefs_init(void)
{
+ static gchar *path[3];
+ gchar *rcpath;
+
+ path[0] = _("Plugins");
+ path[1] = _("Dillo Browser");
+ path[2] = NULL;
+
prefs_set_default(param);
- prefs_read_config(param, PREFS_BLOCK_NAME, COMMON_RC);
+ rcpath = g_strconcat(get_rc_dir(), G_DIR_SEPARATOR_S, COMMON_RC, NULL);
+ prefs_read_config(param, PREFS_BLOCK_NAME, rcpath, NULL);
+ g_free(rcpath);
- prefs_page.page.path = "Message View/Dillo Browser";
+ prefs_page.page.path = path;
prefs_page.page.create_widget = create_dillo_prefs_page;
prefs_page.page.destroy_widget = destroy_dillo_prefs_page;
prefs_page.page.save_page = save_dillo_prefs;
-
+ prefs_page.page.weight = 35.0;
prefs_gtk_register_page((PrefsPage *) &prefs_page);
}
GtkWindow *window,
gpointer data)
{
- DilloBrowserPage_t *prefs_page = (DilloBrowserPage_t *) page;
+ DilloBrowserPage *prefs_page = (DilloBrowserPage *) page;
GtkWidget *vbox;
GtkWidget *local_checkbox;
GtkWidget *full_checkbox;
GtkWidget *label;
+ GtkTooltips *local_tooltip;
+ GtkTooltips *full_tooltip;
+ GtkWidget *whitelist_ab_checkbtn;
+ GtkWidget *whitelist_ab_folder_combo;
+ GtkWidget *whitelist_ab_select_btn;
+ GtkWidget *hbox_whitelist, *spacer;
+
vbox = gtk_vbox_new(FALSE, 3);
- gtk_widget_ref(vbox);
- gtk_container_set_border_width(GTK_CONTAINER(vbox), 3);
+ gtk_container_set_border_width(GTK_CONTAINER(vbox), VBOX_BORDER);
gtk_widget_show(vbox);
+ local_tooltip = gtk_tooltips_new();
local_checkbox = gtk_check_button_new_with_label
- ("Don't Follow Links in Mails");
- gtk_widget_ref(local_checkbox);
+ (_("Load remote links in mails"));
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(local_checkbox),
- dillo_prefs.local);
+ !dillo_prefs.local);
gtk_box_pack_start(GTK_BOX(vbox), local_checkbox, FALSE, FALSE, 0);
gtk_widget_show(local_checkbox);
+ gtk_tooltips_set_tip(GTK_TOOLTIPS(local_tooltip), local_checkbox,
+ _("Equivalent to Dillo's '--local' option"), NULL);
- label = gtk_label_new("(You can always allow following links\n"
- "by reloading the page)");
+ label = gtk_label_new(_("You can still load remote links "
+ "by reloading the page"));
gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0);
+ gtk_misc_set_alignment(GTK_MISC(label), 0, 0.5);
+ gtkut_widget_set_small_font_size (label);
gtk_widget_show(label);
- full_checkbox = gtk_check_button_new_with_label("Full Screen Mode");
- gtk_widget_ref(full_checkbox);
+
+ hbox_whitelist = gtk_hbox_new(FALSE, 8);
+ gtk_widget_show(hbox_whitelist);
+ gtk_box_pack_start (GTK_BOX (vbox), hbox_whitelist, FALSE, FALSE, 0);
+
+ spacer = gtk_hbox_new(FALSE, 0);
+ gtk_widget_set_size_request(spacer, 12, -1);
+ gtk_widget_show(spacer);
+ gtk_box_pack_start(GTK_BOX(hbox_whitelist), spacer, FALSE, FALSE, 0);
+
+ whitelist_ab_checkbtn = gtk_check_button_new_with_label(_("Only for senders found in address book/folder"));
+ gtk_widget_show(whitelist_ab_checkbtn);
+ gtk_box_pack_start(GTK_BOX(hbox_whitelist), whitelist_ab_checkbtn, FALSE, FALSE, 0);
+
+ whitelist_ab_folder_combo = combobox_text_new(TRUE, _("Any"), NULL);
+ gtk_widget_set_size_request(whitelist_ab_folder_combo, 100, -1);
+ gtk_box_pack_start (GTK_BOX (hbox_whitelist), whitelist_ab_folder_combo, TRUE, TRUE, 0);
+
+ whitelist_ab_select_btn = gtk_button_new_with_label(_("Select ..."));
+ gtk_widget_show (whitelist_ab_select_btn);
+ gtk_box_pack_start (GTK_BOX (hbox_whitelist), whitelist_ab_select_btn, FALSE, FALSE, 0);
+
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(whitelist_ab_checkbtn), dillo_prefs.whitelist_ab);
+ if (dillo_prefs.whitelist_ab_folder != NULL)
+ gtk_entry_set_text(GTK_ENTRY(GTK_BIN(whitelist_ab_folder_combo)->child),
+ dillo_prefs.whitelist_ab_folder);
+
+ full_tooltip = gtk_tooltips_new();
+ full_checkbox = gtk_check_button_new_with_label
+ (_("Full window mode (hide controls)"));
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(full_checkbox),
dillo_prefs.full);
gtk_box_pack_start(GTK_BOX(vbox), full_checkbox, FALSE, FALSE, 0);
gtk_widget_show(full_checkbox);
+ gtk_tooltips_set_tip(GTK_TOOLTIPS(full_tooltip), full_checkbox,
+ _("Equivalent to Dillo's '--fullwindow' option"),
+ NULL);
+
+ g_signal_connect(G_OBJECT(local_checkbox), "toggled",
+ G_CALLBACK(local_checkbox_toggled),
+ prefs_page);
+
+ g_signal_connect(G_OBJECT(whitelist_ab_checkbtn), "toggled",
+ G_CALLBACK(whitelist_checkbox_toggled),
+ prefs_page);
+
+ g_signal_connect(G_OBJECT (whitelist_ab_select_btn), "clicked",
+ G_CALLBACK(dillo_whitelist_ab_select_cb), prefs_page);
+
+ gtk_widget_set_sensitive(whitelist_ab_checkbtn, !dillo_prefs.local);
+ gtk_widget_set_sensitive(whitelist_ab_folder_combo, !dillo_prefs.local && dillo_prefs.whitelist_ab);
+ gtk_widget_set_sensitive(whitelist_ab_select_btn, !dillo_prefs.local && dillo_prefs.whitelist_ab);
+
prefs_page->local = local_checkbox;
prefs_page->full = full_checkbox;
+ prefs_page->whitelist_ab = whitelist_ab_checkbtn;
+ prefs_page->whitelist_ab_folder_combo = whitelist_ab_folder_combo;
+ prefs_page->whitelist_ab_select_btn = whitelist_ab_select_btn;
prefs_page->page.widget = vbox;
}
static void destroy_dillo_prefs_page(PrefsPage *page)
{
- DilloBrowserPage_t *prefs_page = (DilloBrowserPage_t *) page;
-
- gtk_widget_destroy(GTK_WIDGET(prefs_page->local));
- gtk_widget_destroy(GTK_WIDGET(prefs_page->full));
- gtk_widget_destroy(GTK_WIDGET(prefs_page->page.widget));
+ /* Do nothing! */
}
static void save_dillo_prefs(PrefsPage *page)
{
- DilloBrowserPage_t *prefs_page = (DilloBrowserPage_t *) page;
+ DilloBrowserPage *prefs_page = (DilloBrowserPage *) page;
PrefFile *pref_file;
gchar *rc_file_path = g_strconcat(get_rc_dir(), G_DIR_SEPARATOR_S,
COMMON_RC, NULL);
- dillo_prefs.local = gtk_toggle_button_get_active
+ dillo_prefs.local = !gtk_toggle_button_get_active
(GTK_TOGGLE_BUTTON(prefs_page->local));
dillo_prefs.full = gtk_toggle_button_get_active
(GTK_TOGGLE_BUTTON(prefs_page->full));
+
+ dillo_prefs.whitelist_ab = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(prefs_page->whitelist_ab));
+ g_free(dillo_prefs.whitelist_ab_folder);
+ dillo_prefs.whitelist_ab_folder = gtk_editable_get_chars(
+ GTK_EDITABLE(GTK_BIN(prefs_page->whitelist_ab_folder_combo)->child), 0, -1);
pref_file = prefs_write_open(rc_file_path);
g_free(rc_file_path);
prefs_file_close_revert(pref_file);
return;
}
- fprintf(pref_file->fp, "\n");
- prefs_file_close(pref_file);
+
+ if (fprintf(pref_file->fp, "\n") < 0) {
+ FILE_OP_ERROR(rc_file_path, "fprintf");
+ prefs_file_close_revert(pref_file);
+ } else
+ prefs_file_close(pref_file);
}