2007-08-08 [wwp] 2.10.0cvs103
[claws.git] / src / prefs_folder_item.c
index 2cedcbd99ac194bbaf3360d03a647a3a31bf867e..2ab89dab6a455fbe84a79b5ff65d3ec3911bdf65 100644 (file)
@@ -1,10 +1,10 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2006 Hiroyuki Yamamoto and the Sylpheed-Claws team
+ * Copyright (C) 1999-2007 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,
@@ -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/>.
+ * 
  */
 
 /* alfons - all folder item specific settings should migrate into 
@@ -46,6 +46,8 @@
 #include "folder_item_prefs.h"
 #include "gtk/colorsel.h"
 #include "string_match.h"
+#include "quote_fmt.h"
+#include "combobox.h"
 
 #if USE_ASPELL
 #include "gtkaspell.h"
@@ -59,6 +61,8 @@
 
 typedef struct _FolderItemGeneralPage FolderItemGeneralPage;
 typedef struct _FolderItemComposePage FolderItemComposePage;
+typedef struct _FolderItemTemplatesPage FolderItemTemplatesPage;
+static gboolean can_save = TRUE;
 
 struct _FolderItemGeneralPage
 {
@@ -67,6 +71,7 @@ struct _FolderItemGeneralPage
        FolderItem *item;
 
        GtkWidget *table;
+       GtkWidget *no_save_warning;
        GtkWidget *folder_type;
        GtkWidget *checkbtn_simplify_subject;
        GtkWidget *entry_simplify_subject;
@@ -78,7 +83,11 @@ struct _FolderItemGeneralPage
        GtkWidget *checkbtn_enable_processing;
        GtkWidget *checkbtn_newmailcheck;
        GtkWidget *checkbtn_offlinesync;
-
+       GtkWidget *label_offlinesync;
+       GtkWidget *entry_offlinesync;
+       GtkWidget *label_end_offlinesync;
+       GtkWidget *checkbtn_remove_old_offlinesync;
+       
        /* apply to sub folders */
        GtkWidget *simplify_subject_rec_checkbtn;
        GtkWidget *folder_chmod_rec_checkbtn;
@@ -98,6 +107,7 @@ struct _FolderItemComposePage
 
        GtkWidget *window;
        GtkWidget *table;
+       GtkWidget *no_save_warning;
        GtkWidget *checkbtn_request_return_receipt;
        GtkWidget *checkbtn_save_copy_to_folder;
        GtkWidget *checkbtn_default_to;
@@ -108,9 +118,10 @@ struct _FolderItemComposePage
        GtkWidget *optmenu_default_account;
 #if USE_ASPELL
        GtkWidget *checkbtn_enable_default_dictionary;
+       GtkWidget *checkbtn_enable_default_alt_dictionary;
        GtkWidget *optmenu_default_dictionary;
+       GtkWidget *optmenu_default_alt_dictionary;
 #endif
-       GtkWidget *checkbtn_do_not_sign_or_encrypt;
 
        /* apply to sub folders */
        GtkWidget *request_return_receipt_rec_checkbtn;
@@ -120,19 +131,44 @@ struct _FolderItemComposePage
        GtkWidget *default_account_rec_checkbtn;
 #if USE_ASPELL
        GtkWidget *default_dictionary_rec_checkbtn;
+       GtkWidget *default_alt_dictionary_rec_checkbtn;
 #endif
-       GtkWidget *do_not_sign_or_encrypt_rec_checkbtn;
+};
 
+struct _FolderItemTemplatesPage
+{
+       PrefsPage page;
+
+       FolderItem *item;
+
+       GtkWidget *window;
+       GtkWidget *table;
+       GtkWidget *checkbtn_compose_with_format;
+       GtkWidget *compose_subject_format;
+       GtkWidget *compose_body_format;
+       GtkWidget *checkbtn_reply_with_format;
+       GtkWidget *reply_quotemark;
+       GtkWidget *reply_body_format;
+       GtkWidget *checkbtn_forward_with_format;
+       GtkWidget *forward_quotemark;
+       GtkWidget *forward_body_format;
+
+       /* apply to sub folders */
+       GtkWidget *new_msg_format_rec_checkbtn;
+       GtkWidget *reply_format_rec_checkbtn;
+       GtkWidget *forward_format_rec_checkbtn;
 };
 
 
 static void general_save_folder_prefs(FolderItem *folder, FolderItemGeneralPage *page);
 static void compose_save_folder_prefs(FolderItem *folder, FolderItemComposePage *page);
+static void templates_save_folder_prefs(FolderItem *folder, FolderItemTemplatesPage *page);
 
 static gboolean general_save_recurse_func(GNode *node, gpointer data);
 static gboolean compose_save_recurse_func(GNode *node, gpointer data);
+static gboolean templates_save_recurse_func(GNode *node, gpointer data);
 
-gint prefs_folder_item_chmod_mode              (gchar *folder_chmod);
+static gint prefs_folder_item_chmod_mode               (gchar *folder_chmod);
 
 static void folder_color_set_dialog(GtkWidget *widget, gpointer data);
 static void folder_regexp_test_cb(GtkWidget *widget, gpointer data);
@@ -141,7 +177,7 @@ static void folder_regexp_set_subject_example_cb(GtkWidget *widget, gpointer dat
 #define SAFE_STRING(str) \
        (str) ? (str) : ""
 
-void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
+static void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
                                                   GtkWindow * window,
                                                   gpointer data)
 {
@@ -149,17 +185,17 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
        FolderItem *item = (FolderItem *) data;
        guint rowcount;
 
-
        GtkWidget *table;
-       GtkWidget *hbox;
+       GtkWidget *hbox, *hbox2, *hbox_spc;
        GtkWidget *label;
        
-       GtkWidget *folder_type_menu;
+       GtkListStore *folder_type_menu;
        GtkWidget *folder_type;
-       GtkWidget *dummy_chkbtn;
-       GtkWidget *menuitem;
+       GtkTreeIter iter;
+       GtkWidget *dummy_checkbtn;
        SpecialFolderItemType type;
        
+       GtkWidget *no_save_warning = NULL;
        GtkWidget *checkbtn_simplify_subject;
        GtkWidget *entry_simplify_subject;
        GtkWidget *hbox_regexp;
@@ -175,6 +211,10 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
        GtkWidget *checkbtn_enable_processing;
        GtkWidget *checkbtn_newmailcheck;
        GtkWidget *checkbtn_offlinesync;
+       GtkWidget *label_offlinesync;
+       GtkWidget *entry_offlinesync;
+       GtkWidget *label_end_offlinesync;
+       GtkWidget *checkbtn_remove_old_offlinesync;
 
        GtkWidget *simplify_subject_rec_checkbtn;
        GtkWidget *folder_chmod_rec_checkbtn;
@@ -184,14 +224,29 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
        GtkWidget *offlinesync_rec_checkbtn;
        GtkTooltips *tooltips;
 
+       tooltips = gtk_tooltips_new();
        page->item         = item;
 
        /* Table */
-       table = gtk_table_new(6, 2, FALSE);
+       table = gtk_table_new(9, 4, FALSE);
+       gtk_container_set_border_width (GTK_CONTAINER (table), VBOX_BORDER);
        gtk_table_set_row_spacings(GTK_TABLE(table), 4);
        gtk_table_set_col_spacings(GTK_TABLE(table), 4);
        rowcount = 0;
 
+       if (!can_save) {
+               no_save_warning = gtk_label_new(
+                       _("<i>These preferences will not be saved as this folder "
+                       "is a top-level one. However you can use them to set them "
+                       "to the whole mailbox tree using \"Apply to subfolders\".</i>"));
+               gtk_label_set_use_markup(GTK_LABEL(no_save_warning), TRUE);
+               gtk_label_set_line_wrap(GTK_LABEL(no_save_warning), TRUE);
+               gtk_misc_set_alignment(GTK_MISC(no_save_warning), 0.0, 0.5);
+               gtk_table_attach(GTK_TABLE(table), no_save_warning, 0, 4,
+                        rowcount, rowcount + 1, GTK_FILL, 0, 0, 0);
+               rowcount++;
+       }
+       
        /* Apply to subfolders */
        label = gtk_label_new(_("Apply to\nsubfolders"));
        gtk_misc_set_alignment(GTK_MISC(label), 0.5, 0.5);
@@ -200,7 +255,7 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
        rowcount++;
 
        /* folder_type */
-       folder_type = gtk_option_menu_new ();
+       folder_type = gtkut_sc_combobox_create(NULL, FALSE);
        gtk_widget_show (folder_type);
 
        type = F_NORMAL;
@@ -215,21 +270,21 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
        else if (folder_has_parent_of_type(item, F_TRASH))
                type = F_TRASH;
 
-       folder_type_menu = gtk_menu_new ();
+       folder_type_menu = GTK_LIST_STORE(gtk_combo_box_get_model(
+                               GTK_COMBO_BOX(folder_type)));
 
-       MENUITEM_ADD (folder_type_menu, menuitem, _("Normal"),  F_NORMAL);
-       MENUITEM_ADD (folder_type_menu, menuitem, _("Inbox"),  F_INBOX);
-       MENUITEM_ADD (folder_type_menu, menuitem, _("Outbox"),  F_OUTBOX);
-       MENUITEM_ADD (folder_type_menu, menuitem, _("Drafts"),  F_DRAFT);
-       MENUITEM_ADD (folder_type_menu, menuitem, _("Queue"),  F_QUEUE);
-       MENUITEM_ADD (folder_type_menu, menuitem, _("Trash"),  F_TRASH);
-       gtk_option_menu_set_menu (GTK_OPTION_MENU (folder_type), folder_type_menu);
+       COMBOBOX_ADD (folder_type_menu, _("Normal"),  F_NORMAL);
+       COMBOBOX_ADD (folder_type_menu, _("Inbox"),  F_INBOX);
+       COMBOBOX_ADD (folder_type_menu, _("Outbox"),  F_OUTBOX);
+       COMBOBOX_ADD (folder_type_menu, _("Drafts"),  F_DRAFT);
+       COMBOBOX_ADD (folder_type_menu, _("Queue"),  F_QUEUE);
+       COMBOBOX_ADD (folder_type_menu, _("Trash"),  F_TRASH);
 
-       gtk_option_menu_set_history(GTK_OPTION_MENU(folder_type), type);
+       combobox_select_by_data(GTK_COMBO_BOX(folder_type), type);
 
-       dummy_chkbtn = gtk_check_button_new();
-       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(dummy_chkbtn), type != F_INBOX);
-       gtk_widget_set_sensitive(dummy_chkbtn, FALSE);
+       dummy_checkbtn = gtk_check_button_new();
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(dummy_checkbtn), type != F_INBOX);
+       gtk_widget_set_sensitive(dummy_checkbtn, FALSE);
 
        if (type == item->stype && type == F_NORMAL)
                gtk_widget_set_sensitive(folder_type, TRUE);
@@ -242,7 +297,7 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
                         rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, GTK_FILL, 0, 0);
        gtk_table_attach(GTK_TABLE(table), folder_type, 1, 2, 
                         rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, GTK_FILL, 0, 0);
-       gtk_table_attach(GTK_TABLE(table), dummy_chkbtn, 3, 4, 
+       gtk_table_attach(GTK_TABLE(table), dummy_checkbtn, 3, 4, 
                         rowcount, rowcount + 1, GTK_SHRINK, GTK_SHRINK, 0, 0);
 
        rowcount++;
@@ -344,7 +399,6 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
        folder_color_btn = gtk_button_new_with_label("");
        gtk_widget_set_size_request(folder_color_btn, 36, 26);
        gtk_box_pack_start (GTK_BOX(hbox), folder_color_btn, FALSE, FALSE, 0);
-       tooltips = gtk_tooltips_new();
        gtk_tooltips_set_tip(tooltips, folder_color_btn,
                             _("Pick color for folder"), NULL);
 
@@ -363,7 +417,7 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
        rowcount++;
 
        /* Enable processing at startup */
-       checkbtn_enable_processing = gtk_check_button_new_with_label(_("Process at startup"));
+       checkbtn_enable_processing = gtk_check_button_new_with_label(_("Process at start-up"));
        gtk_table_attach(GTK_TABLE(table), checkbtn_enable_processing, 0, 2, 
                         rowcount, rowcount + 1, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
 
@@ -378,6 +432,10 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
 
        /* Check folder for new mail */
        checkbtn_newmailcheck = gtk_check_button_new_with_label(_("Scan for new mail"));
+       gtk_tooltips_set_tip(tooltips, checkbtn_newmailcheck,
+                            _("Turn this option on if mail is delivered directly "
+                              "to this folder by server side filtering on IMAP or "
+                              "by an external application"), NULL);
        gtk_table_attach(GTK_TABLE(table), checkbtn_newmailcheck, 0, 2,
                         rowcount, rowcount+1, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
        
@@ -398,23 +456,78 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
        gtk_table_attach(GTK_TABLE(table), offlinesync_rec_checkbtn, 3, 4, 
                         rowcount, rowcount + 1, GTK_SHRINK, GTK_SHRINK, 0, 0);
 
+       rowcount++;
+
+       hbox = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (hbox);
+       gtk_table_attach(GTK_TABLE(table), hbox, 0, 4,
+                        rowcount, rowcount+1, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
+       rowcount++;
+
+       hbox_spc = gtk_hbox_new (FALSE, 0);
+       gtk_widget_show (hbox_spc);
+       gtk_box_pack_start (GTK_BOX (hbox), hbox_spc, FALSE, FALSE, 0);
+       gtk_widget_set_size_request (hbox_spc, 12, -1);
+
+       label_offlinesync = gtk_label_new(_("Fetch message bodies from the last"));
+       gtk_widget_show (label_offlinesync);
+       gtk_box_pack_start (GTK_BOX (hbox), label_offlinesync, FALSE, FALSE, 0);
+
+       entry_offlinesync = gtk_entry_new();
+       gtk_widget_set_size_request (entry_offlinesync, 64, -1);
+       gtk_widget_show (entry_offlinesync);
+       gtk_tooltips_set_tip(tooltips, entry_offlinesync, _("0: all bodies"), NULL);
+       gtk_box_pack_start (GTK_BOX (hbox), entry_offlinesync, FALSE, FALSE, 0);
+
+       label_end_offlinesync = gtk_label_new(_("days"));
+       gtk_widget_show (label_end_offlinesync);
+       gtk_box_pack_start (GTK_BOX (hbox), label_end_offlinesync, FALSE, FALSE, 0);
+
+       checkbtn_remove_old_offlinesync = gtk_check_button_new_with_label(
+                                               _("Remove older messages bodies"));
+
+       hbox2 = gtk_hbox_new (FALSE, 8);
+       gtk_widget_show (hbox2);
+       gtk_table_attach(GTK_TABLE(table), hbox2, 0, 4,
+                        rowcount, rowcount+1, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
+       rowcount++;
+
+       hbox_spc = gtk_hbox_new (FALSE, 0);
+       gtk_widget_show (hbox_spc);
+       gtk_box_pack_start (GTK_BOX (hbox2), hbox_spc, FALSE, FALSE, 0);
+       gtk_widget_set_size_request (hbox_spc, 12, -1);
+       gtk_box_pack_start (GTK_BOX (hbox2), checkbtn_remove_old_offlinesync, FALSE, FALSE, 0);
+
+       SET_TOGGLE_SENSITIVITY (checkbtn_offlinesync, hbox);
+       SET_TOGGLE_SENSITIVITY (checkbtn_offlinesync, hbox2);
+       
+       gtk_widget_show_all(table);
+
        if (item->folder && (item->folder->klass->type != F_IMAP && 
            item->folder->klass->type != F_NEWS)) {
-                item->prefs->offlinesync = TRUE;
+               item->prefs->offlinesync = TRUE;
+               item->prefs->offlinesync_days = 0;
+               item->prefs->remove_old_bodies = FALSE;
+
                gtk_widget_set_sensitive(GTK_WIDGET(checkbtn_offlinesync),
                                                                 FALSE);
                gtk_widget_set_sensitive(GTK_WIDGET(offlinesync_rec_checkbtn),
                                                                 FALSE);
+               gtk_widget_hide(GTK_WIDGET(checkbtn_offlinesync));
+               gtk_widget_hide(GTK_WIDGET(hbox));
+               gtk_widget_hide(GTK_WIDGET(hbox2));
+               gtk_widget_hide(GTK_WIDGET(offlinesync_rec_checkbtn));
        
        }
        gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_offlinesync),
                                                                 item->prefs->offlinesync);
-       rowcount++;
-
-       gtk_widget_show_all(table);
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_remove_old_offlinesync),
+                                                                item->prefs->remove_old_bodies);
+       gtk_entry_set_text(GTK_ENTRY(entry_offlinesync), itos(item->prefs->offlinesync_days));
 
        page->table = table;
        page->folder_type = folder_type;
+       page->no_save_warning = no_save_warning;
        page->checkbtn_simplify_subject = checkbtn_simplify_subject;
        page->entry_simplify_subject = entry_simplify_subject;
        page->entry_regexp_test_string = entry_regexp_test_string;
@@ -425,6 +538,10 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
        page->checkbtn_enable_processing = checkbtn_enable_processing;
        page->checkbtn_newmailcheck = checkbtn_newmailcheck;
        page->checkbtn_offlinesync = checkbtn_offlinesync;
+       page->label_offlinesync = label_offlinesync;
+       page->entry_offlinesync = entry_offlinesync;
+       page->label_end_offlinesync = label_end_offlinesync;
+       page->checkbtn_remove_old_offlinesync = checkbtn_remove_old_offlinesync;
 
        page->simplify_subject_rec_checkbtn  = simplify_subject_rec_checkbtn;
        page->folder_chmod_rec_checkbtn      = folder_chmod_rec_checkbtn;
@@ -438,7 +555,7 @@ void prefs_folder_item_general_create_widget_func(PrefsPage * page_,
        folder_regexp_set_subject_example_cb(NULL, page);
 }
 
-void prefs_folder_item_general_destroy_widget_func(PrefsPage *page_) 
+static void prefs_folder_item_general_destroy_widget_func(PrefsPage *page_) 
 {
        /* FolderItemGeneralPage *page = (FolderItemGeneralPage *) page_; */
 }
@@ -454,8 +571,6 @@ static void general_save_folder_prefs(FolderItem *folder, FolderItemGeneralPage
        gchar *buf;
        gboolean all = FALSE;
        SpecialFolderItemType type = F_NORMAL;
-       GtkWidget *menu;
-       GtkWidget *menuitem;
 
        if (folder->path == NULL)
                return;
@@ -465,10 +580,7 @@ static void general_save_folder_prefs(FolderItem *folder, FolderItemGeneralPage
        if (page->item == folder) 
                all = TRUE;
 
-       menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(page->folder_type));
-       menuitem = gtk_menu_get_active(GTK_MENU(menu));
-       type = GPOINTER_TO_INT
-               (g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
+       type = combobox_get_active_data(GTK_COMBO_BOX(page->folder_type));
        if (all && folder->stype != type) {
                folder_item_change_type(folder, type);
        }
@@ -510,6 +622,10 @@ static void general_save_folder_prefs(FolderItem *folder, FolderItemGeneralPage
        if (all ||  gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->offlinesync_rec_checkbtn))) {
                prefs->offlinesync = 
                        gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_offlinesync));
+               prefs->offlinesync_days = 
+                       atoi(gtk_entry_get_text(GTK_ENTRY(page->entry_offlinesync)));
+               prefs->remove_old_bodies =
+                       gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_remove_old_offlinesync));
        }
 
        folder_item_prefs_save_config(folder);
@@ -540,12 +656,14 @@ static gboolean general_save_recurse_func(GNode *node, gpointer data)
                return FALSE;
 }
 
-void prefs_folder_item_general_save_func(PrefsPage *page_) 
+static void prefs_folder_item_general_save_func(PrefsPage *page_) 
 {
        FolderItemGeneralPage *page = (FolderItemGeneralPage *) page_;
 
        g_node_traverse(page->item->node, G_PRE_ORDER, G_TRAVERSE_ALL,
                        -1, general_save_recurse_func, page);
+       
+       main_window_set_menu_sensitive(mainwindow_get_mainwindow());
 
 }
 
@@ -559,7 +677,8 @@ static RecvProtocol item_protocol(FolderItem *item)
                return A_NONE;
        return item->folder->account->protocol;
 }
-void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
+
+static void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
                                                   GtkWindow * window,
                                                   gpointer data)
 {
@@ -570,6 +689,7 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
        GtkWidget *table;
        GtkWidget *label;
        
+       GtkWidget *no_save_warning = NULL;
        GtkWidget *checkbtn_request_return_receipt = NULL;
        GtkWidget *checkbtn_save_copy_to_folder = NULL;
        GtkWidget *checkbtn_default_to = NULL;
@@ -578,19 +698,22 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
        GtkWidget *entry_default_reply_to = NULL;
        GtkWidget *checkbtn_enable_default_account = NULL;
        GtkWidget *optmenu_default_account = NULL;
-       GtkWidget *optmenu_default_account_menu = NULL;
-       GtkWidget *optmenu_default_account_menuitem = NULL;
+       GtkListStore *optmenu_default_account_menu = NULL;
+       GtkTreeIter iter;
 #if USE_ASPELL
        GtkWidget *checkbtn_enable_default_dictionary = NULL;
        GtkWidget *optmenu_default_dictionary = NULL;
+       GtkWidget *checkbtn_enable_default_alt_dictionary = NULL;
+       GtkWidget *optmenu_default_alt_dictionary = NULL;
 #endif
        GtkWidget *request_return_receipt_rec_checkbtn = NULL;
        GtkWidget *save_copy_to_folder_rec_checkbtn = NULL;
        GtkWidget *default_to_rec_checkbtn = NULL;
        GtkWidget *default_reply_to_rec_checkbtn = NULL;
-       GtkWidget *default_account_rec_checkbtn = NULL;
+       GtkWidget *default_account_rec_checkbtn = NULL;\f
 #if USE_ASPELL
        GtkWidget *default_dictionary_rec_checkbtn = NULL;
+       GtkWidget *default_alt_dictionary_rec_checkbtn = NULL;
 #endif
 
        GList *cur_ac;
@@ -602,21 +725,34 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
        GtkOptionMenu *optmenu;
        GtkWidget *menu;
        GtkWidget *menuitem;
-       gint account_index, index;
 
        page->item         = item;
 
        /* Table */
 #if USE_ASPELL
-# define TABLEHEIGHT 6
+# define TABLEHEIGHT 7
 #else
-# define TABLEHEIGHT 5
+# define TABLEHEIGHT 6
 #endif
-       table = gtk_table_new(TABLEHEIGHT, 2, FALSE);
+       table = gtk_table_new(TABLEHEIGHT, 3, FALSE);
+       gtk_container_set_border_width (GTK_CONTAINER (table), VBOX_BORDER);
        gtk_table_set_row_spacings(GTK_TABLE(table), 4);
        gtk_table_set_col_spacings(GTK_TABLE(table), 4);
        rowcount = 0;
 
+       if (!can_save) {
+               no_save_warning = gtk_label_new(
+                       _("<i>These preferences will not be saved as this folder "
+                       "is a top-level one. However you can use them to set them "
+                       "to the whole mailbox tree using \"Apply to subfolders\".</i>"));
+               gtk_label_set_use_markup(GTK_LABEL(no_save_warning), TRUE);
+               gtk_label_set_line_wrap(GTK_LABEL(no_save_warning), TRUE);
+               gtk_misc_set_alignment(GTK_MISC(no_save_warning), 0.0, 0.5);
+               gtk_table_attach(GTK_TABLE(table), no_save_warning, 0, 3,
+                        rowcount, rowcount + 1, GTK_FILL, 0, 0, 0);
+               rowcount++;
+       }
+       
        /* Apply to subfolders */
        label = gtk_label_new(_("Apply to\nsubfolders"));
        gtk_misc_set_alignment(GTK_MISC(label), 0.5, 0.5);
@@ -655,7 +791,7 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
                rowcount++;
 
                /* Default To */
-               checkbtn_default_to = gtk_check_button_new_with_label(_("Default To: "));
+               checkbtn_default_to = gtk_check_button_new_with_label(_("Default To:"));
                gtk_table_attach(GTK_TABLE(table), checkbtn_default_to, 0, 1, 
                                 rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, GTK_SHRINK, 0, 0);
                gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_default_to), 
@@ -676,7 +812,7 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
                rowcount++;
 
                /* Default address to reply to */
-               checkbtn_default_reply_to = gtk_check_button_new_with_label(_("Default To for replies: "));
+               checkbtn_default_reply_to = gtk_check_button_new_with_label(_("Default To: for replies"));
                gtk_table_attach(GTK_TABLE(table), checkbtn_default_reply_to, 0, 1, 
                                 rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, GTK_SHRINK, 0, 0);
                gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_default_reply_to), 
@@ -697,20 +833,19 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
                rowcount++;
        }
        /* Default account */
-       checkbtn_enable_default_account = gtk_check_button_new_with_label(_("Default account"));
+       checkbtn_enable_default_account = gtk_check_button_new_with_label(_("Default account"));
        gtk_table_attach(GTK_TABLE(table), checkbtn_enable_default_account, 0, 1, 
                         rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, GTK_SHRINK, 0, 0);
        gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_enable_default_account), 
                                     item->prefs->enable_default_account);
 
-       optmenu_default_account = gtk_option_menu_new ();
+       optmenu_default_account = gtkut_sc_combobox_create(NULL, FALSE);
        gtk_table_attach(GTK_TABLE(table), optmenu_default_account, 1, 2, 
                         rowcount, rowcount + 1, GTK_EXPAND | GTK_FILL, GTK_SHRINK, 0, 0);
-       optmenu_default_account_menu = gtk_menu_new ();
+       optmenu_default_account_menu = GTK_LIST_STORE(
+                       gtk_combo_box_get_model(GTK_COMBO_BOX(optmenu_default_account)));
 
        account_list = account_get_list();
-       account_index = 0;
-       index = 0;
        for (cur_ac = account_list; cur_ac != NULL; cur_ac = cur_ac->next) {
                ac_prefs = (PrefsAccount *)cur_ac->data;
                if (item->folder->account &&
@@ -721,24 +856,16 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
                if (item->folder->klass->type != F_NEWS && ac_prefs->protocol == A_NNTP)
                        continue;
 
-               MENUITEM_ADD (optmenu_default_account_menu, optmenu_default_account_menuitem,
+               COMBOBOX_ADD (optmenu_default_account_menu,
                                        ac_prefs->account_name?ac_prefs->account_name : _("Untitled"),
                                        ac_prefs->account_id);
-               /* get the index for menu's set_history (sad method?) */
+
+               /* Set combobox to current default account id */
                if (ac_prefs->account_id == item->prefs->default_account)
-                       account_index = index;
-               index++;                        
+                       combobox_select_by_data(GTK_COMBO_BOX(optmenu_default_account),
+                                       ac_prefs->account_id);
        }
 
-       optmenu = GTK_OPTION_MENU(optmenu_default_account);
-       gtk_option_menu_set_menu(optmenu, optmenu_default_account_menu);
-
-       gtk_option_menu_set_history(optmenu, account_index);
-
-       menu = gtk_option_menu_get_menu(optmenu);
-       menuitem = gtk_menu_get_active(GTK_MENU(menu));
-       gtk_menu_item_activate(GTK_MENU_ITEM(menuitem));
-
        SET_TOGGLE_SENSITIVITY(checkbtn_enable_default_account, optmenu_default_account);
 
        default_account_rec_checkbtn = gtk_check_button_new();
@@ -748,7 +875,7 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
 
 #if USE_ASPELL
        /* Default dictionary */
-       checkbtn_enable_default_dictionary = gtk_check_button_new_with_label(_("Default dictionary"));
+       checkbtn_enable_default_dictionary = gtk_check_button_new_with_label(_("Default dictionary"));
        gtk_table_attach(GTK_TABLE(table), checkbtn_enable_default_dictionary, 0, 1,
                         rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, GTK_SHRINK, 0, 0);
        gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_enable_default_dictionary),
@@ -779,12 +906,46 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
                         rowcount, rowcount + 1, GTK_SHRINK, GTK_SHRINK, 0, 0);
        
        rowcount++;
+
+       /* Default dictionary */
+       checkbtn_enable_default_alt_dictionary = gtk_check_button_new_with_label(_("Default alternate dictionary"));
+       gtk_table_attach(GTK_TABLE(table), checkbtn_enable_default_alt_dictionary, 0, 1,
+                        rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, GTK_SHRINK, 0, 0);
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_enable_default_alt_dictionary),
+                                    item->prefs->enable_default_alt_dictionary);
+
+       optmenu_default_alt_dictionary = gtk_option_menu_new();
+       gtk_table_attach(GTK_TABLE(table), optmenu_default_alt_dictionary, 1, 2,
+                        rowcount, rowcount + 1, GTK_EXPAND | GTK_FILL, GTK_SHRINK, 0, 0);
+
+       gtk_option_menu_set_menu(GTK_OPTION_MENU(optmenu_default_alt_dictionary), 
+                                gtkaspell_dictionary_option_menu_new_with_refresh(
+                                        prefs_common.aspell_path, FALSE));
+
+       dictionary = item->prefs->default_alt_dictionary;
+
+       optmenu = GTK_OPTION_MENU(optmenu_default_alt_dictionary);
+
+       menu = gtk_option_menu_get_menu(optmenu);
+       if (dictionary)
+               gtkaspell_set_dictionary_menu_active_item(optmenu_default_alt_dictionary, dictionary);
+       menuitem = gtk_menu_get_active(GTK_MENU(menu));
+       gtk_menu_item_activate(GTK_MENU_ITEM(menuitem));
+
+       SET_TOGGLE_SENSITIVITY(checkbtn_enable_default_alt_dictionary, optmenu_default_alt_dictionary);
+
+       default_alt_dictionary_rec_checkbtn = gtk_check_button_new();
+       gtk_table_attach(GTK_TABLE(table), default_alt_dictionary_rec_checkbtn, 2, 3, 
+                        rowcount, rowcount + 1, GTK_SHRINK, GTK_SHRINK, 0, 0);
+       
+       rowcount++;
 #endif
 
        gtk_widget_show_all(table);
 
        page->window = GTK_WIDGET(window);
        page->table = table;
+       page->no_save_warning = no_save_warning;
        page->checkbtn_request_return_receipt = checkbtn_request_return_receipt;
        page->checkbtn_save_copy_to_folder = checkbtn_save_copy_to_folder;
        page->checkbtn_default_to = checkbtn_default_to;
@@ -796,6 +957,8 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
 #ifdef USE_ASPELL
        page->checkbtn_enable_default_dictionary = checkbtn_enable_default_dictionary;
        page->optmenu_default_dictionary = optmenu_default_dictionary;
+       page->checkbtn_enable_default_alt_dictionary = checkbtn_enable_default_alt_dictionary;
+       page->optmenu_default_alt_dictionary = optmenu_default_alt_dictionary;
 #endif
 
        page->request_return_receipt_rec_checkbtn = request_return_receipt_rec_checkbtn;
@@ -805,6 +968,7 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
        page->default_account_rec_checkbtn        = default_account_rec_checkbtn;
 #if USE_ASPELL
        page->default_dictionary_rec_checkbtn = default_dictionary_rec_checkbtn;
+       page->default_alt_dictionary_rec_checkbtn = default_alt_dictionary_rec_checkbtn;
 #endif
 
        address_completion_start(page->window);
@@ -812,7 +976,7 @@ void prefs_folder_item_compose_create_widget_func(PrefsPage * page_,
        page->page.widget = table;
 }
 
-void prefs_folder_item_compose_destroy_widget_func(PrefsPage *page_) 
+static void prefs_folder_item_compose_destroy_widget_func(PrefsPage *page_) 
 {
        FolderItemComposePage *page = (FolderItemComposePage *) page_;
 
@@ -832,7 +996,6 @@ static void compose_save_folder_prefs(FolderItem *folder, FolderItemComposePage
 {
        FolderItemPrefs *prefs = folder->prefs;
        GtkWidget *menu;
-       GtkWidget *menuitem;
        gboolean all = FALSE;
 
        if (folder->path == NULL)
@@ -876,12 +1039,14 @@ static void compose_save_folder_prefs(FolderItem *folder, FolderItemComposePage
                prefs->enable_default_to = FALSE;
                prefs->enable_default_reply_to = FALSE;
        }
-       if (all || gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->default_account_rec_checkbtn))) {
+
+       if (all || gtk_toggle_button_get_active(
+                               GTK_TOGGLE_BUTTON(page->default_account_rec_checkbtn))) {
                prefs->enable_default_account = 
-                       gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_enable_default_account));
-               menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(page->optmenu_default_account));
-               menuitem = gtk_menu_get_active(GTK_MENU(menu));
-               prefs->default_account = GPOINTER_TO_INT(g_object_get_data(G_OBJECT(menuitem), MENU_VAL_ID));
+                       gtk_toggle_button_get_active(
+                                       GTK_TOGGLE_BUTTON(page->checkbtn_enable_default_account));
+               prefs->default_account = combobox_get_active_data(
+                               GTK_COMBO_BOX(page->optmenu_default_account));
        }
 
 #if USE_ASPELL
@@ -892,6 +1057,13 @@ static void compose_save_folder_prefs(FolderItem *folder, FolderItemComposePage
                ASSIGN_STRING(prefs->default_dictionary,
                              gtkaspell_get_dictionary_menu_active_item(menu));
        }
+       if (all || gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->default_alt_dictionary_rec_checkbtn))) {
+               prefs->enable_default_alt_dictionary =
+                       gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_enable_default_alt_dictionary));
+               menu = gtk_option_menu_get_menu(GTK_OPTION_MENU(page->optmenu_default_alt_dictionary));
+               ASSIGN_STRING(prefs->default_alt_dictionary,
+                             gtkaspell_get_dictionary_menu_active_item(menu));
+       }
 #endif
 
        folder_item_prefs_save_config(folder);
@@ -917,14 +1089,15 @@ static gboolean compose_save_recurse_func(GNode *node, gpointer data)
              gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->default_account_rec_checkbtn)) ||
 #if USE_ASPELL
              gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->default_dictionary_rec_checkbtn)) ||
+             gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->default_alt_dictionary_rec_checkbtn)) ||
 #endif
              gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->default_reply_to_rec_checkbtn))))
                return TRUE;
-
-       if ((node == page->item->node) &&
+       else if ((node == page->item->node) && item_protocol(item) == A_NNTP &&
            !(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->default_account_rec_checkbtn)) 
 #if USE_ASPELL
              || gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->default_dictionary_rec_checkbtn))
+             || gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->default_alt_dictionary_rec_checkbtn))
 #endif
                    ))
                return TRUE;
@@ -932,7 +1105,7 @@ static gboolean compose_save_recurse_func(GNode *node, gpointer data)
                return FALSE;
 }
 
-void prefs_folder_item_compose_save_func(PrefsPage *page_) 
+static void prefs_folder_item_compose_save_func(PrefsPage *page_) 
 {
        FolderItemComposePage *page = (FolderItemComposePage *) page_;
 
@@ -941,7 +1114,266 @@ void prefs_folder_item_compose_save_func(PrefsPage *page_)
 
 }
 
-gint prefs_folder_item_chmod_mode(gchar *folder_chmod) 
+static void prefs_folder_item_templates_create_widget_func(PrefsPage * page_,
+                                                  GtkWindow * window,
+                                                  gpointer data)
+{
+       FolderItemTemplatesPage *page = (FolderItemTemplatesPage *) page_;
+       FolderItem *item = (FolderItem *) data;
+
+       GtkWidget *table;
+       GtkWidget *label;
+       guint rowcount;
+       GtkWidget *vbox;
+       GtkWidget *alignment;
+       GtkWidget *new_msg_format_rec_checkbtn;
+       GtkWidget *reply_format_rec_checkbtn;
+       GtkWidget *forward_format_rec_checkbtn;
+
+       page->item         = item;
+
+       /* Table */
+       table = gtk_table_new(5, 3, FALSE);
+       gtk_container_set_border_width (GTK_CONTAINER (table), VBOX_BORDER);
+       gtk_table_set_row_spacings(GTK_TABLE(table), 4);
+       gtk_table_set_col_spacings(GTK_TABLE(table), 4);
+       rowcount = 0;
+
+       /* Apply to subfolders */
+       label = gtk_label_new(_("Apply to\nsubfolders"));
+       gtk_misc_set_alignment(GTK_MISC(label), 0.5, 0.5);
+       gtk_table_attach(GTK_TABLE(table), label, 2, 3,
+                        rowcount, rowcount + 1, GTK_SHRINK, GTK_SHRINK, 0, 0);
+       rowcount++;
+
+       /* compose format */
+       vbox = gtk_vbox_new (FALSE, VSPACING);
+       gtk_widget_show (vbox);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox), 0);
+       gtk_table_attach(GTK_TABLE(table), vbox, 1, 2, 
+                        rowcount, rowcount + 1, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
+
+       quotefmt_create_new_msg_fmt_widgets(
+                               window,
+                               vbox,
+                               &page->checkbtn_compose_with_format,
+                               _("Use a specific format for new messages"),
+                               &page->compose_subject_format,
+                               &page->compose_body_format,
+                               FALSE);
+
+       vbox = gtk_vbox_new (FALSE, VSPACING);
+       gtk_widget_show (vbox);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox), 0);
+       gtk_table_attach(GTK_TABLE(table), vbox, 2, 3, 
+                        rowcount, rowcount + 1, GTK_SHRINK, GTK_FILL, 0, 0);
+
+       new_msg_format_rec_checkbtn = gtk_check_button_new();
+       gtk_box_pack_start (GTK_BOX(vbox), new_msg_format_rec_checkbtn, FALSE, FALSE, 0);
+       alignment = gtk_alignment_new(0, 1, 0, 0);      
+       gtk_box_pack_start (GTK_BOX(vbox), alignment, FALSE, FALSE, 0);
+
+       rowcount++;
+
+       /* reply format */
+       vbox = gtk_vbox_new (FALSE, VSPACING);
+       gtk_widget_show (vbox);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox), 0);
+       gtk_table_attach(GTK_TABLE(table), vbox, 1, 2, 
+                        rowcount, rowcount + 1, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
+
+       quotefmt_create_reply_fmt_widgets(
+                               window,
+                               vbox,
+                               &page->checkbtn_reply_with_format,
+                               _("Use a specific reply quote format"),
+                               &page->reply_quotemark,
+                               &page->reply_body_format,
+                               FALSE);
+
+       vbox = gtk_vbox_new (FALSE, VSPACING);
+       gtk_widget_show (vbox);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox), 0);
+       gtk_table_attach(GTK_TABLE(table), vbox, 2, 3, 
+                        rowcount, rowcount + 1, GTK_SHRINK, GTK_FILL, 0, 0);
+
+       reply_format_rec_checkbtn = gtk_check_button_new();
+       gtk_box_pack_start (GTK_BOX(vbox), reply_format_rec_checkbtn, FALSE, FALSE, 0);
+       alignment = gtk_alignment_new(0, 1, 0, 0);      
+       gtk_box_pack_start (GTK_BOX(vbox), alignment, FALSE, FALSE, 0);
+
+       rowcount++;
+
+       /* forward format */
+       vbox = gtk_vbox_new (FALSE, VSPACING);
+       gtk_widget_show (vbox);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox), 0);
+       gtk_table_attach(GTK_TABLE(table), vbox, 1, 2, 
+                        rowcount, rowcount + 1, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
+
+       quotefmt_create_forward_fmt_widgets(
+                               window,
+                               vbox,
+                               &page->checkbtn_forward_with_format,
+                               _("Use a specific forward quote format"),
+                               &page->forward_quotemark,
+                               &page->forward_body_format,
+                               FALSE);
+
+       vbox = gtk_vbox_new (FALSE, VSPACING);
+       gtk_widget_show (vbox);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox), 0);
+       gtk_table_attach(GTK_TABLE(table), vbox, 2, 3, 
+                        rowcount, rowcount + 1, GTK_SHRINK, GTK_FILL, 0, 0);
+
+       forward_format_rec_checkbtn = gtk_check_button_new();
+       gtk_box_pack_start (GTK_BOX(vbox), forward_format_rec_checkbtn, FALSE, FALSE, 0);
+       alignment = gtk_alignment_new(0, 1, 0, 0);      
+       gtk_box_pack_start (GTK_BOX(vbox), alignment, FALSE, FALSE, 0);
+
+       rowcount++;
+
+       /* information button */
+       vbox = gtk_vbox_new (FALSE, VSPACING);
+       gtk_widget_show (vbox);
+       gtk_container_set_border_width (GTK_CONTAINER (vbox), 0);
+       gtk_table_attach(GTK_TABLE(table), vbox, 1, 2, 
+                        rowcount, rowcount + 1, GTK_EXPAND | GTK_FILL, GTK_FILL, 0, 0);
+       rowcount++;
+       quotefmt_add_info_button(window, vbox);
+
+
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(page->checkbtn_compose_with_format),
+                       item->prefs->compose_with_format);
+       pref_set_entry_from_pref(GTK_ENTRY(page->compose_subject_format),
+                       item->prefs->compose_subject_format);
+       pref_set_textview_from_pref(GTK_TEXT_VIEW(page->compose_body_format),
+                       item->prefs->compose_body_format);
+
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(page->checkbtn_reply_with_format),
+                       item->prefs->reply_with_format);
+       pref_set_entry_from_pref(GTK_ENTRY(page->reply_quotemark),
+                       item->prefs->reply_quotemark);
+       pref_set_textview_from_pref(GTK_TEXT_VIEW(page->reply_body_format),
+                       item->prefs->reply_body_format);
+
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(page->checkbtn_forward_with_format),
+                       item->prefs->forward_with_format);
+       pref_set_entry_from_pref(GTK_ENTRY(page->forward_quotemark),
+                       item->prefs->forward_quotemark);
+       pref_set_textview_from_pref(GTK_TEXT_VIEW(page->forward_body_format),
+                       item->prefs->forward_body_format);
+
+       gtk_widget_show_all(table);
+
+       page->window = GTK_WIDGET(window);
+       page->table = table;
+
+       page->new_msg_format_rec_checkbtn = new_msg_format_rec_checkbtn;
+       page->reply_format_rec_checkbtn = reply_format_rec_checkbtn;
+       page->forward_format_rec_checkbtn = forward_format_rec_checkbtn;
+
+       page->page.widget = table;
+}
+
+static void prefs_folder_item_templates_destroy_widget_func(PrefsPage *page_) 
+{
+       /* FolderItemTemplatesPage *page = (FolderItemTemplatesPage *) page_; */
+}
+
+/** \brief  Save the prefs in page to folder.
+ *
+ *  If the folder is not the one  specified in page->item, then only those properties 
+ *  that have the relevant 'apply to sub folders' button checked are saved
+ */
+static void templates_save_folder_prefs(FolderItem *folder, FolderItemTemplatesPage *page)
+{
+       FolderItemPrefs *prefs = folder->prefs;
+       gboolean all = FALSE;
+
+       if (folder->path == NULL)
+               return;
+
+       if (page->item == folder) 
+               all = TRUE;
+
+       g_return_if_fail(prefs != NULL);
+
+       /* save and check formats */
+
+       if (all || gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->new_msg_format_rec_checkbtn))) {
+               prefs->compose_with_format =
+                       gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_compose_with_format));
+               prefs->compose_subject_format = pref_get_pref_from_entry(
+                               GTK_ENTRY(page->compose_subject_format));
+               prefs->compose_body_format = pref_get_pref_from_textview(
+                               GTK_TEXT_VIEW(page->compose_body_format));
+               quotefmt_check_new_msg_formats(prefs->compose_with_format,
+                                                                               prefs->compose_subject_format,
+                                                                               prefs->compose_body_format);
+       }
+
+       if (all || gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->reply_format_rec_checkbtn))) {
+               prefs->reply_with_format =
+                       gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_reply_with_format));
+               prefs->reply_quotemark = gtk_editable_get_chars(
+                               GTK_EDITABLE(page->reply_quotemark), 0, -1);
+               prefs->reply_body_format = pref_get_pref_from_textview(
+                               GTK_TEXT_VIEW(page->reply_body_format));
+               quotefmt_check_reply_formats(prefs->reply_with_format,
+                                                                               prefs->reply_quotemark,
+                                                                               prefs->reply_body_format);
+       }
+
+       if (all || gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->forward_format_rec_checkbtn))) {
+               prefs->forward_with_format =
+                       gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_forward_with_format));
+               prefs->forward_quotemark = gtk_editable_get_chars(
+                               GTK_EDITABLE(page->forward_quotemark), 0, -1);
+               prefs->forward_body_format = pref_get_pref_from_textview(
+                               GTK_TEXT_VIEW(page->forward_body_format));
+               quotefmt_check_forward_formats(prefs->forward_with_format,
+                                                                               prefs->forward_quotemark,
+                                                                               prefs->forward_body_format);
+       }
+
+       folder_item_prefs_save_config(folder);
+}      
+
+static gboolean templates_save_recurse_func(GNode *node, gpointer data)
+{
+       FolderItem *item = (FolderItem *) node->data;
+       FolderItemTemplatesPage *page = (FolderItemTemplatesPage *) data;
+
+       g_return_val_if_fail(item != NULL, TRUE);
+       g_return_val_if_fail(page != NULL, TRUE);
+
+       templates_save_folder_prefs(item, page);
+
+       /* optimise by not continuing if none of the 'apply to sub folders'
+          check boxes are selected - and optimise the checking by only doing
+          it once */
+       if ((node == page->item->node) &&
+           !(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->new_msg_format_rec_checkbtn)) ||
+             gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->reply_format_rec_checkbtn)) ||
+             gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->forward_format_rec_checkbtn))))
+               return TRUE;
+       else 
+               return FALSE;
+
+       return FALSE;
+}
+
+static void prefs_folder_item_templates_save_func(PrefsPage *page_) 
+{
+       FolderItemTemplatesPage *page = (FolderItemTemplatesPage *) page_;
+
+       g_node_traverse(page->item->node, G_PRE_ORDER, G_TRAVERSE_ALL,
+                       -1, templates_save_recurse_func, page);
+
+}
+
+static gint prefs_folder_item_chmod_mode(gchar *folder_chmod) 
 {
        gint newmode = 0;
        gchar *tmp;
@@ -998,6 +1430,8 @@ static void folder_regexp_test_cb(GtkWidget *widget, gpointer data)
        test_string = g_strdup(gtk_entry_get_text(GTK_ENTRY(page->entry_regexp_test_string)));
 
        if (!regexp || !regexp[0]) {
+               gtk_widget_modify_base(page->entry_simplify_subject,
+                               GTK_STATE_NORMAL, NULL);
                if (test_string) {
                        gtk_entry_set_text(GTK_ENTRY(page->entry_regexp_test_result), test_string);
                        g_free(test_string);
@@ -1094,25 +1528,45 @@ static void register_compose_page(void)
        prefs_folder_item_register_page((PrefsPage *) &folder_item_compose_page);
 }
 
+static void register_templates_page(void)
+{
+       static gchar *pfi_templates_path[2];
+       static FolderItemTemplatesPage folder_item_templates_page;
+
+       pfi_templates_path[0] = _("Templates");
+       pfi_templates_path[1] = NULL;
+
+        folder_item_templates_page.page.path = pfi_templates_path;
+        folder_item_templates_page.page.create_widget = prefs_folder_item_templates_create_widget_func;
+        folder_item_templates_page.page.destroy_widget = prefs_folder_item_templates_destroy_widget_func;
+        folder_item_templates_page.page.save_page = prefs_folder_item_templates_save_func;
+        
+       prefs_folder_item_register_page((PrefsPage *) &folder_item_templates_page);
+}
+
 static GSList *prefs_pages = NULL;
 
 void prefs_folder_item_open(FolderItem *item)
 {
        gchar *id, *title;
-
        if (prefs_pages == NULL) {
                register_general_page();
                register_compose_page();
+               register_templates_page();
        }
 
-       if (item->path)
+       if (item->path) {
                id = folder_item_get_identifier (item);
-       else 
+               can_save = TRUE;
+       } else {
                id = g_strdup(item->name);
+               can_save = FALSE;
+       }
        title = g_strdup_printf (_("Properties for folder %s"), id);
        g_free (id);
        prefswindow_open(title, prefs_pages, item,
                        &prefs_common.folderitemwin_width, &prefs_common.folderitemwin_height);
+       
        g_free (title);
 }