} quote;
static struct Display {
- GtkWidget *entry_textfont;
+/* GtkWidget *entry_textfont;
GtkWidget *button_textfont;
GtkWidget *entry_smallfont;
GtkWidget *entry_normalfont;
- GtkWidget *entry_boldfont;
+ GtkWidget *entry_boldfont; */
GtkWidget *chkbtn_folder_unread;
GtkWidget *entry_ng_abbrev_len;
GtkWidget *combo;
} keybind;
-static GtkWidget *font_sel_win;
-static guint font_sel_conn_id;
+/* static GtkWidget *font_sel_win;
+static guint font_sel_conn_id; */
static GtkWidget *quote_color_win;
static GtkWidget *color_dialog;
{"widget_font", NULL, &prefs_common.widgetfont, P_STRING,
NULL, NULL, NULL},
{"message_font", "-misc-fixed-medium-r-normal--14-*-*-*-*-*-*-*",
- &prefs_common.textfont, P_STRING,
- &display.entry_textfont,
- prefs_set_data_from_entry, prefs_set_entry},
+ &prefs_common.textfont, P_STRING, NULL, NULL, NULL},
{"small_font", "-*-helvetica-medium-r-normal--10-*-*-*-*-*-*-*",
- &prefs_common.smallfont, P_STRING,
- &display.entry_smallfont,
- prefs_set_data_from_entry, prefs_set_entry},
+ &prefs_common.smallfont, P_STRING, NULL, NULL, NULL},
{"bold_font", "-*-helvetica-bold-r-normal--12-*-*-*-*-*-*-*",
- &prefs_common.boldfont, P_STRING,
- &display.entry_boldfont,
- prefs_set_data_from_entry, prefs_set_entry},
+ &prefs_common.boldfont, P_STRING, NULL, NULL, NULL},
{"normal_font", "-*-helvetica-medium-r-normal--12-*-*-*-*-*-*-*",
- &prefs_common.normalfont, P_STRING,
- &display.entry_normalfont,
- prefs_set_data_from_entry, prefs_set_entry},
+ &prefs_common.normalfont, P_STRING, NULL, NULL, NULL},
{"display_folder_unread_num", "TRUE",
static void prefs_enable_message_color_toggled (void);
static void prefs_recycle_colors_toggled (GtkWidget *widget);
-static void prefs_font_select (GtkButton *button, GtkEntry *entry);
+/* static void prefs_font_select (GtkButton *button, GtkEntry *entry);
static void prefs_font_selection_key_pressed (GtkWidget *widget,
GdkEventKey *event,
gpointer data);
static void prefs_font_selection_ok (GtkButton *button, GtkEntry *entry);
-
+*/
static void prefs_keybind_select (void);
static gint prefs_keybind_deleted (GtkWidget *widget,
GdkEventAny *event,
static void prefs_display_create(void)
{
GtkWidget *vbox1;
- GtkWidget *frame_font;
+/* GtkWidget *frame_font;
GtkWidget *table1;
GtkWidget *label_textfont;
GtkWidget *entry_textfont;
- GtkWidget *button_textfont;
+ GtkWidget *button_textfont; */
GtkWidget *chkbtn_transhdr;
GtkWidget *chkbtn_folder_unread;
GtkWidget *hbox1;
GtkWidget *button_datefmt;
GtkWidget *entry_datefmt;
GtkWidget *button_dispitem;
- GtkWidget *tmplabel, *tmpbutton, *tmpentry;
+/* GtkWidget *tmplabel, *tmpbutton, *tmpentry; */
vbox1 = gtk_vbox_new (FALSE, VSPACING);
gtk_widget_show (vbox1);
gtk_container_add (GTK_CONTAINER (dialog.notebook), vbox1);
gtk_container_set_border_width (GTK_CONTAINER (vbox1), VBOX_BORDER);
- PACK_FRAME(vbox1, frame_font, _("Font"));
+/* PACK_FRAME(vbox1, frame_font, _("Font"));
table1 = gtk_table_new (4, 3, FALSE);
gtk_signal_connect (GTK_OBJECT(tmpbutton), "clicked",
GTK_SIGNAL_FUNC(prefs_font_select), tmpentry);
display.entry_boldfont = tmpentry;
-
+*/
vbox2 = gtk_vbox_new (FALSE, 0);
gtk_widget_show (vbox2);
gtk_box_pack_start (GTK_BOX (vbox1), vbox2, FALSE, TRUE, 0);
GTK_SIGNAL_FUNC (prefs_summary_column_open),
NULL);
- display.entry_textfont = entry_textfont;
- display.button_textfont = button_textfont;
+/* display.entry_textfont = entry_textfont;
+ display.button_textfont = button_textfont; */
display.chkbtn_transhdr = chkbtn_transhdr;
display.chkbtn_folder_unread = chkbtn_folder_unread;
is_active = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widget));
prefs_common.recycle_quote_colors = is_active;
}
-
+/*
static void prefs_font_select(GtkButton *button, GtkEntry *entry)
{
gchar *font_name;
gtk_widget_hide(font_sel_win);
}
-
+*/
static void prefs_keybind_select(void)
{
GtkWidget *window;
--- /dev/null
+/*
+ * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
+ * Copyright (C) 2003 Hiroyuki Yamamoto & the Sylpheed-Claws 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
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * 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.
+ */
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include "defs.h"
+
+#include <stdio.h>
+#include <stdlib.h>
+
+#include <glib.h>
+#include <gtk/gtk.h>
+#include <gdk/gdkkeysyms.h>
+
+#include "intl.h"
+#include "utils.h"
+#include "prefs_common.h"
+#include "prefs_gtk.h"
+
+#include "gtk/gtkutils.h"
+#include "gtk/prefswindow.h"
+
+typedef struct _FontsPage
+{
+ PrefsPage page;
+
+ GtkWidget *window; /* do not modify */
+
+ GtkWidget *label_textfont;
+ GtkWidget *entry_textfont;
+ GtkWidget *entry_smallfont;
+ GtkWidget *entry_normalfont;
+ GtkWidget *entry_boldfont;
+ GtkWidget *button_textfont;
+} FontsPage;
+
+static GtkWidget *font_sel_win;
+static guint font_sel_conn_id;
+
+static void prefs_font_select (GtkButton *button, GtkEntry *entry);
+
+static void prefs_font_selection_key_pressed (GtkWidget *widget,
+ GdkEventKey *event,
+ gpointer data);
+static void prefs_font_selection_ok (GtkButton *button, GtkEntry *entry);
+
+static void prefs_font_select(GtkButton *button, GtkEntry *entry)
+{
+ gchar *font_name;
+
+ g_return_if_fail(entry != NULL);
+
+ if (!font_sel_win) {
+ font_sel_win = gtk_font_selection_dialog_new
+ (_("Font selection"));
+ gtk_window_position(GTK_WINDOW(font_sel_win),
+ GTK_WIN_POS_CENTER);
+ gtk_signal_connect(GTK_OBJECT(font_sel_win), "delete_event",
+ GTK_SIGNAL_FUNC(gtk_widget_hide_on_delete),
+ NULL);
+ gtk_signal_connect
+ (GTK_OBJECT(font_sel_win), "key_press_event",
+ GTK_SIGNAL_FUNC(prefs_font_selection_key_pressed),
+ NULL);
+ gtk_signal_connect_object
+ (GTK_OBJECT(GTK_FONT_SELECTION_DIALOG(font_sel_win)->cancel_button),
+ "clicked",
+ GTK_SIGNAL_FUNC(gtk_widget_hide_on_delete),
+ GTK_OBJECT(font_sel_win));
+ }
+
+ if(font_sel_conn_id) {
+ gtk_signal_disconnect(GTK_OBJECT(GTK_FONT_SELECTION_DIALOG(font_sel_win)->ok_button), font_sel_conn_id);
+ }
+ font_sel_conn_id = gtk_signal_connect
+ (GTK_OBJECT(GTK_FONT_SELECTION_DIALOG(font_sel_win)->ok_button),
+ "clicked",
+ GTK_SIGNAL_FUNC(prefs_font_selection_ok),
+ entry);
+ printf("%i\n", font_sel_conn_id);
+
+ font_name = gtk_editable_get_chars(GTK_EDITABLE(entry), 0, -1);
+ gtk_font_selection_dialog_set_font_name(GTK_FONT_SELECTION_DIALOG(font_sel_win), font_name);
+ g_free(font_name);
+ manage_window_set_transient(GTK_WINDOW(font_sel_win));
+ gtk_window_set_modal(GTK_WINDOW(font_sel_win), TRUE);
+ gtk_widget_grab_focus
+ (GTK_FONT_SELECTION_DIALOG(font_sel_win)->ok_button);
+ gtk_widget_show(font_sel_win);
+}
+
+static void prefs_font_selection_key_pressed(GtkWidget *widget,
+ GdkEventKey *event,
+ gpointer data)
+{
+ if (event && event->keyval == GDK_Escape)
+ gtk_widget_hide(font_sel_win);
+}
+
+static void prefs_font_selection_ok(GtkButton *button, GtkEntry *entry)
+{
+ gchar *fontname;
+
+ fontname = gtk_font_selection_dialog_get_font_name
+ (GTK_FONT_SELECTION_DIALOG(font_sel_win));
+
+ if (fontname) {
+ gtk_entry_set_text(entry, fontname);
+
+ g_free(fontname);
+ }
+
+ gtk_widget_hide(font_sel_win);
+}
+
+void prefs_fonts_create_widget(PrefsPage *_page, GtkWindow *window,
+ gpointer data)
+{
+ FontsPage *prefs_fonts = (FontsPage *) _page;
+
+ GtkWidget *table;
+ GtkWidget *frame_font;
+ GtkWidget *table1;
+ GtkWidget *label_textfont;
+ GtkWidget *entry_textfont;
+ GtkWidget *entry_smallfont;
+ GtkWidget *entry_boldfont;
+ GtkWidget *entry_normalfont;
+ GtkWidget *button_textfont;
+ GtkWidget *tmplabel, *tmpbutton;
+ GtkWidget *vbox;
+ GtkWidget *hint_label;
+
+ table = gtk_table_new(8, 3, FALSE);
+ gtk_widget_show(table);
+ gtk_container_set_border_width(GTK_CONTAINER(table), 8);
+ gtk_table_set_row_spacings(GTK_TABLE(table), 4);
+ gtk_table_set_col_spacings(GTK_TABLE(table), 8);
+
+ label_textfont = gtk_label_new (_("Text"));
+ gtk_widget_show (label_textfont);
+ gtk_table_attach (GTK_TABLE (table), label_textfont, 0, 1, 0, 1,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_label_set_justify(GTK_LABEL(tmplabel), GTK_JUSTIFY_RIGHT);
+ gtk_misc_set_alignment(GTK_MISC(label_textfont), 1, 0.5);
+
+ entry_textfont = gtk_entry_new ();
+ gtk_widget_show (entry_textfont);
+ gtk_table_attach (GTK_TABLE (table), entry_textfont, 1, 2, 0, 1,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_entry_set_text(GTK_ENTRY(entry_textfont), prefs_common.textfont);
+
+ button_textfont = gtk_button_new_with_label (" ... ");
+
+ gtk_widget_show (button_textfont);
+ gtk_table_attach (GTK_TABLE (table), button_textfont, 2, 3, 0, 1,
+ 0, 0, 0, 0);
+ gtk_signal_connect (GTK_OBJECT (button_textfont), "clicked",
+ GTK_SIGNAL_FUNC (prefs_font_select), entry_textfont);
+
+ tmplabel = gtk_label_new (_("Small"));
+ gtk_widget_show (tmplabel);
+ gtk_table_attach (GTK_TABLE (table), tmplabel, 0, 1, 1, 2,
+ (GtkAttachOptions) GTK_FILL,
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_label_set_justify(GTK_LABEL(tmplabel), GTK_JUSTIFY_RIGHT);
+ gtk_misc_set_alignment(GTK_MISC(tmplabel), 1, 0.5);
+
+ entry_smallfont = gtk_entry_new ();
+ gtk_widget_show (entry_smallfont);
+ gtk_table_attach (GTK_TABLE (table), entry_smallfont, 1, 2, 1, 2,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_entry_set_text(GTK_ENTRY(entry_smallfont), prefs_common.smallfont);
+
+ tmpbutton = gtk_button_new_with_label (" ... ");
+ gtk_widget_show (tmpbutton);
+ gtk_table_attach (GTK_TABLE (table), tmpbutton, 2, 3, 1, 2,
+ 0, 0, 0, 0);
+ gtk_signal_connect (GTK_OBJECT(tmpbutton), "clicked",
+ GTK_SIGNAL_FUNC(prefs_font_select), entry_smallfont);
+
+ tmplabel = gtk_label_new (_("Normal"));
+ gtk_widget_show (tmplabel);
+ gtk_table_attach (GTK_TABLE (table), tmplabel, 0, 1, 2, 3,
+ (GtkAttachOptions) GTK_FILL,
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_label_set_justify(GTK_LABEL(tmplabel), GTK_JUSTIFY_RIGHT);
+ gtk_misc_set_alignment(GTK_MISC(tmplabel), 1, 0.5);
+
+ entry_normalfont = gtk_entry_new ();
+ gtk_widget_show (entry_normalfont);
+ gtk_table_attach (GTK_TABLE (table), entry_normalfont, 1, 2, 2, 3,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_entry_set_text(GTK_ENTRY(entry_normalfont), prefs_common.normalfont);
+
+ tmpbutton = gtk_button_new_with_label (" ... ");
+ gtk_widget_show (tmpbutton);
+ gtk_table_attach (GTK_TABLE (table), tmpbutton, 2, 3, 2, 3,
+ 0, 0, 0, 0);
+ gtk_signal_connect (GTK_OBJECT(tmpbutton), "clicked",
+ GTK_SIGNAL_FUNC(prefs_font_select), entry_normalfont);
+
+ tmplabel = gtk_label_new (_("Bold"));
+ gtk_widget_show (tmplabel);
+ gtk_table_attach (GTK_TABLE (table), tmplabel, 0, 1, 3, 4,
+ (GtkAttachOptions) GTK_FILL,
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_label_set_justify(GTK_LABEL(tmplabel), GTK_JUSTIFY_RIGHT);
+ gtk_misc_set_alignment(GTK_MISC(tmplabel), 1, 0.5);
+
+ entry_boldfont = gtk_entry_new ();
+ gtk_widget_show (entry_boldfont);
+ gtk_table_attach (GTK_TABLE (table), entry_boldfont, 1, 2, 3, 4,
+ (GtkAttachOptions) (GTK_EXPAND | GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+ gtk_entry_set_text(GTK_ENTRY(entry_boldfont), prefs_common.boldfont);
+
+ tmpbutton = gtk_button_new_with_label (" ... ");
+ gtk_widget_show (tmpbutton);
+ gtk_table_attach (GTK_TABLE (table), tmpbutton, 2, 3, 3, 4,
+ 0, 0, 0, 0);
+ gtk_signal_connect (GTK_OBJECT(tmpbutton), "clicked",
+ GTK_SIGNAL_FUNC(prefs_font_select), entry_boldfont);
+
+ vbox = gtk_vbox_new(FALSE, VSPACING_NARROW);
+ gtk_widget_show(vbox);
+ gtk_table_attach (GTK_TABLE (table), vbox, 0, 4, 4, 5,
+ (GtkAttachOptions) (GTK_FILL),
+ (GtkAttachOptions) (0), 0, 0);
+
+ hint_label = gtk_label_new (_("You will need to restart for the "
+ "changes to take effect"));
+ gtk_widget_show (hint_label);
+ gtk_box_pack_start (GTK_BOX (vbox),
+ hint_label, FALSE, FALSE, 0);
+ gtk_misc_set_alignment(GTK_MISC(hint_label), 0, 0.5);
+
+ prefs_fonts->window = GTK_WIDGET(window);
+ prefs_fonts->entry_textfont = entry_textfont;
+ prefs_fonts->entry_smallfont = entry_smallfont;
+ prefs_fonts->entry_normalfont = entry_normalfont;
+ prefs_fonts->entry_boldfont = entry_boldfont;
+ prefs_fonts->button_textfont = button_textfont;
+
+ prefs_fonts->page.widget = table;
+}
+
+void prefs_fonts_save(PrefsPage *_page)
+{
+ FontsPage *fonts = (FontsPage *) _page;
+
+ prefs_common.textfont = gtk_editable_get_chars
+ (GTK_EDITABLE(fonts->entry_textfont), 0, -1);
+ prefs_common.smallfont = gtk_editable_get_chars
+ (GTK_EDITABLE(fonts->entry_smallfont), 0, -1);
+ prefs_common.boldfont = gtk_editable_get_chars
+ (GTK_EDITABLE(fonts->entry_boldfont), 0, -1);
+ prefs_common.normalfont = gtk_editable_get_chars
+ (GTK_EDITABLE(fonts->entry_normalfont), 0, -1);
+}
+static void prefs_fonts_destroy_widget(PrefsPage *_page)
+{
+ /* FontsPage *fonts = (FontsPage *) _page; */
+
+}
+
+FontsPage *prefs_fonts;
+
+void prefs_fonts_init(void)
+{
+ FontsPage *page;
+
+ page = g_new0(FontsPage, 1);
+ page->page.path = _("Display/Fonts");
+ page->page.create_widget = prefs_fonts_create_widget;
+ page->page.destroy_widget = prefs_fonts_destroy_widget;
+ page->page.save_page = prefs_fonts_save;
+ page->page.weight = 60.0;
+ prefs_gtk_register_page((PrefsPage *) page);
+ prefs_fonts = page;
+}
+
+void prefs_fonts_done(void)
+{
+ prefs_gtk_unregister_page((PrefsPage *) prefs_fonts);
+ g_free(prefs_fonts);
+}