0.9.3claws34
[claws.git] / src / prefs_folder_item.c
index ce87c2fbd6baae97a0dbfe6854725943b3f94f3c..53ff219947c54d621f98c8425caf51041d0afecd 100644 (file)
+/*
+ * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
+ * Copyright (C) 1999-2001 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
+ * 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.
+ */
+
+/* alfons - all folder item specific settings should migrate into 
+ * folderlist.xml!!! the old folderitemrc file will only serve for a few 
+ * versions (for compatibility) */
+
+#ifdef HAVE_CONFIG_H
+#  include "config.h"
+#endif
+
+#include "intl.h"
 #include "defs.h"
 #include "folder.h"
 #include "prefs_folder_item.h"
+#include "folderview.h"
 #include "summaryview.h"
-#include "prefs.h"
-
-PrefsFolderItem tmp_prefs;
-
-static PrefParam param[] = {
-       {"sort_by_number", "FALSE", &tmp_prefs.sort_by_number, P_BOOL,
-        NULL, NULL, NULL},
-       {"sort_by_size", "FALSE", &tmp_prefs.sort_by_size, P_BOOL,
-        NULL, NULL, NULL},
-       {"sort_by_date", "FALSE", &tmp_prefs.sort_by_date, P_BOOL,
-        NULL, NULL, NULL},
-       {"sort_by_from", "FALSE", &tmp_prefs.sort_by_from, P_BOOL,
-        NULL, NULL, NULL},
-       {"sort_by_subject", "FALSE", &tmp_prefs.sort_by_subject, P_BOOL,
-        NULL, NULL, NULL},
-       {"sort_by_score", "FALSE", &tmp_prefs.sort_by_score, P_BOOL,
-        NULL, NULL, NULL},
-       {"sort_descending", "FALSE", &tmp_prefs.sort_descending, P_BOOL,
-        NULL, NULL, NULL},
-       {"enable_thread", "TRUE", &tmp_prefs.enable_thread, P_BOOL,
-        NULL, NULL, NULL},
-       {NULL, NULL, NULL, P_OTHER, NULL, NULL, NULL}
+#include "menu.h"
+#include "account.h"
+#include "prefs_gtk.h"
+#include "manage_window.h"
+#include "utils.h"
+#include "addr_compl.h"
+#include "prefs_scoring.h"
+#include "gtkutils.h"
+#include "filtering.h"
+#include "folder_item_prefs.h"
+
+struct FolderItemSettingsPage
+{
+       PrefsPage page;
+
+       FolderItem *item;
+
+       GtkWidget *window;
+       GtkWidget *table;
+       GtkWidget *checkbtn_request_return_receipt;
+       GtkWidget *checkbtn_save_copy_to_folder;
+       GtkWidget *checkbtn_default_to;
+       GtkWidget *entry_default_to;
+       GtkWidget *checkbtn_default_reply_to;
+       GtkWidget *entry_default_reply_to;
+       GtkWidget *checkbtn_simplify_subject;
+       GtkWidget *entry_simplify_subject;
+       GtkWidget *checkbtn_folder_chmod;
+       GtkWidget *entry_folder_chmod;
+       GtkWidget *checkbtn_enable_default_account;
+       GtkWidget *optmenu_default_account;
+       GtkWidget *folder_color;
+       GtkWidget *folder_color_btn;
+
+       GtkWidget *color_dialog;
 };
 
-void prefs_folder_item_read_config(FolderItem * item)
+
+gint prefs_folder_item_chmod_mode              (gchar *folder_chmod);
+
+static void set_button_color(guint rgbvalue, GtkWidget *button);
+static void folder_color_set_dialog(GtkWidget *widget, gpointer data);
+static void folder_color_set_dialog_ok(GtkWidget *widget, gpointer data);
+static void folder_color_set_dialog_cancel(GtkWidget *widget, gpointer data);
+static void folder_color_set_dialog_key_pressed(GtkWidget *widget,
+                                               GdkEventKey *event,
+                                               gpointer data);
+
+#define SAFE_STRING(str) \
+       (str) ? (str) : ""
+
+void prefs_folder_item_settings_create_widget_func(PrefsPage * _page,
+                                                  GtkWindow * window,
+                                                  gpointer data)
 {
-       gchar * path;
+       struct FolderItemSettingsPage *page = (struct FolderItemSettingsPage *) _page;
+       FolderItem *item = (FolderItem *) data;
+       guint rowcount;
+
+       GtkWidget *table;
+       
+       GtkWidget *checkbtn_request_return_receipt;
+       GtkWidget *checkbtn_save_copy_to_folder;
+       GtkWidget *checkbtn_default_to;
+       GtkWidget *entry_default_to;
+       GtkWidget *checkbtn_default_reply_to;
+       GtkWidget *entry_default_reply_to;
+       GtkWidget *checkbtn_simplify_subject;
+       GtkWidget *entry_simplify_subject;
+       GtkWidget *checkbtn_folder_chmod;
+       GtkWidget *entry_folder_chmod;
+       GtkWidget *checkbtn_enable_default_account;
+       GtkWidget *optmenu_default_account;
+       GtkWidget *optmenu_default_account_menu;
+       GtkWidget *optmenu_default_account_menuitem;
+       GtkWidget *folder_color;
+       GtkWidget *folder_color_btn;
+       GList *cur_ac;
+       GList *account_list;
+       PrefsAccount *ac_prefs;
+       GtkOptionMenu *optmenu;
+       GtkWidget *menu;
+       GtkWidget *menuitem;
+       gint account_index, index;
+
+       page->item         = item;
+
+       /* Table */
+       table = gtk_table_new(8, 2, FALSE);
+       gtk_widget_show(table);
+       gtk_table_set_row_spacings(GTK_TABLE(table), VSPACING_NARROW);
+       rowcount = 0;
+
+       /* Request Return Receipt */
+       checkbtn_request_return_receipt = gtk_check_button_new_with_label
+               (_("Request Return Receipt"));
+       gtk_widget_show(checkbtn_request_return_receipt);
+       gtk_table_attach(GTK_TABLE(table), checkbtn_request_return_receipt, 
+                        0, 2, rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, 
+                        GTK_SHRINK, 0, 0);
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_request_return_receipt),
+                                    item->ret_rcpt ? TRUE : FALSE);
+
+       rowcount++;
+
+       /* Save Copy to Folder */
+       checkbtn_save_copy_to_folder = gtk_check_button_new_with_label
+               (_("Save copy of outgoing messages to this folder instead of Sent"));
+       gtk_widget_show(checkbtn_save_copy_to_folder);
+       gtk_table_attach(GTK_TABLE(table), checkbtn_save_copy_to_folder, 0, 2, 
+                        rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, GTK_SHRINK, 0, 0);
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_save_copy_to_folder),
+                                    item->prefs->save_copy_to_folder ? TRUE : FALSE);
+
+       rowcount++;
+
+       /* Default To */
+       checkbtn_default_to = gtk_check_button_new_with_label(_("Default To: "));
+       gtk_widget_show(checkbtn_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), 
+                                    item->prefs->enable_default_to);
+
+       entry_default_to = gtk_entry_new();
+       gtk_widget_show(entry_default_to);
+       gtk_table_attach_defaults(GTK_TABLE(table), entry_default_to, 1, 2, rowcount, rowcount + 1);
+       SET_TOGGLE_SENSITIVITY(checkbtn_default_to, entry_default_to);
+       gtk_entry_set_text(GTK_ENTRY(entry_default_to), SAFE_STRING(item->prefs->default_to));
+       address_completion_register_entry(GTK_ENTRY(entry_default_to));
+
+       rowcount++;
+
+       /* Default address to reply to */
+       checkbtn_default_reply_to = gtk_check_button_new_with_label(_("Send replies to: "));
+       gtk_widget_show(checkbtn_default_reply_to);
+       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), 
+                                    item->prefs->enable_default_reply_to);
+
+       entry_default_reply_to = gtk_entry_new();
+       gtk_widget_show(entry_default_reply_to);
+       gtk_table_attach_defaults(GTK_TABLE(table), entry_default_reply_to, 1, 2, rowcount, rowcount + 1);
+       SET_TOGGLE_SENSITIVITY(checkbtn_default_reply_to, entry_default_reply_to);
+       gtk_entry_set_text(GTK_ENTRY(entry_default_reply_to), SAFE_STRING(item->prefs->default_reply_to));
+       address_completion_register_entry(GTK_ENTRY(entry_default_reply_to));
+
+       rowcount++;
+
+       /* Simplify Subject */
+       checkbtn_simplify_subject = gtk_check_button_new_with_label(_("Simplify Subject RegExp: "));
+       gtk_widget_show(checkbtn_simplify_subject);
+       gtk_table_attach(GTK_TABLE(table), checkbtn_simplify_subject, 0, 1, 
+                        rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, GTK_SHRINK, 0, 0);
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_simplify_subject), 
+                                    item->prefs->enable_simplify_subject);
+
+       entry_simplify_subject = gtk_entry_new();
+       gtk_widget_show(entry_simplify_subject);
+       gtk_table_attach_defaults(GTK_TABLE(table), entry_simplify_subject, 1, 2, 
+                                 rowcount, rowcount + 1);
+       SET_TOGGLE_SENSITIVITY(checkbtn_simplify_subject, entry_simplify_subject);
+       gtk_entry_set_text(GTK_ENTRY(entry_simplify_subject), 
+                          SAFE_STRING(item->prefs->simplify_subject_regexp));
+
+       rowcount++;
+
+       /* Folder chmod */
+       checkbtn_folder_chmod = gtk_check_button_new_with_label(_("Folder chmod: "));
+       gtk_widget_show(checkbtn_folder_chmod);
+       gtk_table_attach(GTK_TABLE(table), checkbtn_folder_chmod, 0, 1, 
+                        rowcount, rowcount + 1, GTK_SHRINK | GTK_FILL, GTK_SHRINK, 0, 0);
+
+       gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbtn_folder_chmod), 
+                                    item->prefs->enable_folder_chmod);
+
+       entry_folder_chmod = gtk_entry_new();
+       gtk_widget_show(entry_folder_chmod);
+       gtk_table_attach_defaults(GTK_TABLE(table), entry_folder_chmod, 1, 2, 
+                                 rowcount, rowcount + 1);
+       SET_TOGGLE_SENSITIVITY(checkbtn_folder_chmod, entry_folder_chmod);
+       if (item->prefs->folder_chmod) {
+               gchar *buf;
+
+               buf = g_strdup_printf("%o", item->prefs->folder_chmod);
+               gtk_entry_set_text(GTK_ENTRY(entry_folder_chmod), buf);
+               g_free(buf);
+       }
+       
+       rowcount++;
+
+       /* Default account */
+       checkbtn_enable_default_account = gtk_check_button_new_with_label(_("Default account: "));
+       gtk_widget_show(checkbtn_enable_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 ();
+       gtk_widget_show (optmenu_default_account);
+       gtk_table_attach_defaults(GTK_TABLE(table), optmenu_default_account, 1, 2, 
+                                 rowcount, rowcount + 1);
+       optmenu_default_account_menu = gtk_menu_new ();
+
+       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;
+               MENUITEM_ADD (optmenu_default_account_menu, optmenu_default_account_menuitem,
+                                       ac_prefs->account_name?ac_prefs->account_name : _("Untitled"),
+                                       ac_prefs->account_id);
+               /* get the index for menu's set_history (sad method?) */
+               if (ac_prefs->account_id == item->prefs->default_account)
+                       account_index = index;
+               index++;                        
+       }
+
+       page->item->prefs->default_account = item->prefs->default_account;
+
+       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);
+
+       rowcount++;
+
+       /* Folder color */
+       folder_color = gtk_label_new(_("Folder color: "));
+       gtk_misc_set_alignment(GTK_MISC(folder_color), 0, 0.5);
+       gtk_widget_show(folder_color);
+       gtk_table_attach_defaults(GTK_TABLE(table), folder_color, 0, 1, 
+                        rowcount, rowcount + 1);
+
+       folder_color_btn = gtk_button_new_with_label("");
+       gtk_widget_set_usize(folder_color_btn, 36, 26);
+       gtk_container_set_border_width(GTK_CONTAINER(folder_color_btn), 2);
+       gtk_widget_show(folder_color_btn);
+       gtk_table_attach(GTK_TABLE(table), folder_color_btn,
+                        1, 2, rowcount, rowcount + 1,
+                        GTK_SHRINK, 0, 0, 0);
 
-       path = folder_item_get_path(item);
-       if (!is_dir_exist(path))
-               make_dir_hier(path);
+       page->item->prefs->color = item->prefs->color;
 
-       prefs_read_config(param, path, FOLDERITEM_RC);
-       g_free(path);
+       gtk_signal_connect(GTK_OBJECT(folder_color_btn), "clicked",
+                          GTK_SIGNAL_FUNC(folder_color_set_dialog),
+                          page);
 
-       * item->prefs = tmp_prefs;
+       set_button_color(item->prefs->color, folder_color_btn);
+
+       rowcount++;
+
+       page->window = GTK_WIDGET(window);
+       page->table = table;
+       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;
+       page->entry_default_to = entry_default_to;
+       page->checkbtn_default_reply_to = checkbtn_default_reply_to;
+       page->entry_default_reply_to = entry_default_reply_to;
+       page->checkbtn_simplify_subject = checkbtn_simplify_subject;
+       page->entry_simplify_subject = entry_simplify_subject;
+       page->checkbtn_folder_chmod = checkbtn_folder_chmod;
+       page->entry_folder_chmod = entry_folder_chmod;
+       page->checkbtn_enable_default_account = checkbtn_enable_default_account;
+       page->optmenu_default_account = optmenu_default_account;
+       page->folder_color = folder_color;
+       page->folder_color_btn = folder_color_btn;
+
+       address_completion_start(page->window);
+
+       page->page.widget = table;
+}
+
+void prefs_folder_item_settings_destroy_widget_func(PrefsPage *_page) 
+{
+       struct FolderItemSettingsPage *page = (struct FolderItemSettingsPage *) _page;
+
+       address_completion_unregister_entry(GTK_ENTRY(page->entry_default_to));
+       address_completion_unregister_entry(GTK_ENTRY(page->entry_default_reply_to));
+       address_completion_end(page->window);
 }
 
-void prefs_folder_item_save_config(FolderItem * item)
-{      
-       gchar * path;
+void prefs_folder_item_settings_save_func(PrefsPage *_page) 
+{
+       gchar *buf;
+       struct FolderItemSettingsPage *page = (struct FolderItemSettingsPage *) _page;
+       FolderItemPrefs *prefs = page->item->prefs;
+       GtkWidget *menu;
+       GtkWidget *menuitem;
+       gboolean   old_simplify_val;
+       gchar     *old_simplify_str;
+
+       g_return_if_fail(prefs != NULL);
+
+       old_simplify_val = prefs->enable_simplify_subject;
+       old_simplify_str = prefs->simplify_subject_regexp;
+
+       prefs->request_return_receipt = 
+           gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_request_return_receipt));
+       /* MIGRATION */    
+       page->item->ret_rcpt = prefs->request_return_receipt;
 
-       tmp_prefs = * item->prefs;
+       prefs->save_copy_to_folder = 
+           gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_save_copy_to_folder));
 
-       path = folder_item_get_path(item);
-       if (!is_dir_exist(path))
-               make_dir_hier(path);
+       prefs->enable_default_to = 
+           gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_default_to));
+       g_free(prefs->default_to);
+       prefs->default_to = 
+           gtk_editable_get_chars(GTK_EDITABLE(page->entry_default_to), 0, -1);
 
-       prefs_save_config(param, path, FOLDERITEM_RC);
-       g_free(path);
+       prefs->enable_default_reply_to = 
+           gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_default_reply_to));
+       g_free(prefs->default_reply_to);
+       prefs->default_reply_to = 
+           gtk_editable_get_chars(GTK_EDITABLE(page->entry_default_reply_to), 0, -1);
+
+       prefs->enable_simplify_subject =
+           gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_simplify_subject));
+       prefs->simplify_subject_regexp = 
+           gtk_editable_get_chars(GTK_EDITABLE(page->entry_simplify_subject), 0, -1);
+       
+/*
+       if (page->item == page->folderview->summaryview->folder_item &&
+           (prefs->enable_simplify_subject != old_simplify_val ||  
+           0 != strcmp2(prefs->simplify_subject_regexp, old_simplify_str))) {
+               summary_clear_all(page->folderview->summaryview);
+               page->folderview->opened = NULL;
+               page->folderview->selected = NULL;
+               folderview_select(page->folderview, page->item);
+       }
+*/
+       if (old_simplify_str) g_free(old_simplify_str);
+
+       prefs->enable_folder_chmod = 
+           gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(page->checkbtn_folder_chmod));
+       buf = gtk_editable_get_chars(GTK_EDITABLE(page->entry_folder_chmod), 0, -1);
+       prefs->folder_chmod = prefs_folder_item_chmod_mode(buf);
+       g_free(buf);
+
+       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(gtk_object_get_user_data(GTK_OBJECT(menuitem)));
+
+       prefs->color = page->item->prefs->color;
+       /* update folder view */
+       if (prefs->color > 0)
+               folder_item_update(page->item, F_ITEM_UPDATE_MSGCNT);
+
+       folder_item_prefs_save_config(page->item);
 }
 
-void prefs_folder_item_set_config(FolderItem * item,
-                                 int sort_type, gint sort_mode)
+gint prefs_folder_item_chmod_mode(gchar *folder_chmod) 
 {
-       tmp_prefs = * item->prefs;
-
-       tmp_prefs.sort_by_number = FALSE;
-       tmp_prefs.sort_by_size = FALSE;
-       tmp_prefs.sort_by_date = FALSE;
-       tmp_prefs.sort_by_from = FALSE;
-       tmp_prefs.sort_by_subject = FALSE;
-       tmp_prefs.sort_by_score = FALSE;
-
-       switch (sort_mode) {
-       case SORT_BY_NUMBER:
-               tmp_prefs.sort_by_number = TRUE;
-               break;
-       case SORT_BY_SIZE:
-               tmp_prefs.sort_by_size = TRUE;
-               break;
-       case SORT_BY_DATE:
-               tmp_prefs.sort_by_date = TRUE;
-               break;
-       case SORT_BY_FROM:
-               tmp_prefs.sort_by_from = TRUE;
-               break;
-       case SORT_BY_SUBJECT:
-               tmp_prefs.sort_by_subject = TRUE;
-               break;
-       case SORT_BY_SCORE:
-               tmp_prefs.sort_by_score = TRUE;
-               break;
+       gint newmode = 0;
+       gchar *tmp;
+
+       if (folder_chmod) {
+               newmode = strtol(folder_chmod, &tmp, 8);
+               if (!(*(folder_chmod) && !(*tmp)))
+                       newmode = 0;
        }
-       tmp_prefs.sort_descending = (sort_type == GTK_SORT_DESCENDING);
 
-       * item->prefs = tmp_prefs;
+       return newmode;
 }
 
-PrefsFolderItem * prefs_folder_item_new(void)
+static void set_button_color(guint rgbvalue, GtkWidget *button)
 {
-       PrefsFolderItem * prefs;
+       GtkStyle *newstyle;
+       GdkColor gdk_color;
 
-       prefs = g_new0(PrefsFolderItem, 1);
+       gtkut_convert_int_to_gdk_color(rgbvalue, &gdk_color);
+       newstyle = gtk_style_copy(gtk_widget_get_default_style());
+       newstyle->bg[GTK_STATE_NORMAL]   = gdk_color;
+       newstyle->bg[GTK_STATE_PRELIGHT] = gdk_color;
+       newstyle->bg[GTK_STATE_ACTIVE]   = gdk_color;
+       gtk_widget_set_style(GTK_WIDGET(button), newstyle);
+}
 
-       tmp_prefs.sort_by_number = FALSE;
-       tmp_prefs.sort_by_size = FALSE;
-       tmp_prefs.sort_by_date = FALSE;
-       tmp_prefs.sort_by_from = FALSE;
-       tmp_prefs.sort_by_subject = FALSE;
-       tmp_prefs.sort_by_score = FALSE;
-       tmp_prefs.sort_descending = FALSE;
+static void folder_color_set_dialog(GtkWidget *widget, gpointer data)
+{
+       struct FolderItemSettingsPage *page = (struct FolderItemSettingsPage *) data;
+       GtkColorSelectionDialog *dialog;
+       gdouble color[4] = {0.0, 0.0, 0.0, 0.0};
+       guint rgbcolor;
 
-       * prefs = tmp_prefs;
-       
-       return prefs;
+       page->color_dialog = gtk_color_selection_dialog_new(_("Pick color for folder"));
+       gtk_window_set_position(GTK_WINDOW(page->color_dialog), GTK_WIN_POS_CENTER);
+       gtk_window_set_modal(GTK_WINDOW(page->color_dialog), TRUE);
+       gtk_window_set_policy(GTK_WINDOW(page->color_dialog), FALSE, FALSE, FALSE);
+       manage_window_set_transient(GTK_WINDOW(page->color_dialog));
+
+       gtk_signal_connect(GTK_OBJECT(GTK_COLOR_SELECTION_DIALOG(page->color_dialog)->ok_button),
+                          "clicked", GTK_SIGNAL_FUNC(folder_color_set_dialog_ok), data);
+       gtk_signal_connect(GTK_OBJECT(GTK_COLOR_SELECTION_DIALOG(page->color_dialog)->cancel_button),
+                          "clicked", GTK_SIGNAL_FUNC(folder_color_set_dialog_cancel), data);
+       gtk_signal_connect(GTK_OBJECT(page->color_dialog), "key_press_event",
+                          GTK_SIGNAL_FUNC(folder_color_set_dialog_key_pressed),
+                          data);
+
+       rgbcolor = page->item->prefs->color;
+       color[0] = (gdouble) ((rgbcolor & 0xff0000) >> 16) / 255.0;
+       color[1] = (gdouble) ((rgbcolor & 0x00ff00) >>  8) / 255.0;
+       color[2] = (gdouble)  (rgbcolor & 0x0000ff)        / 255.0;
+
+       dialog = GTK_COLOR_SELECTION_DIALOG(page->color_dialog);
+       gtk_color_selection_set_color(GTK_COLOR_SELECTION(dialog->colorsel), color);
+
+       gtk_widget_show(page->color_dialog);
 }
 
-void prefs_folder_item_free(PrefsFolderItem * prefs)
+static void folder_color_set_dialog_ok(GtkWidget *widget, gpointer data)
 {
-       g_free(prefs);
+       struct FolderItemSettingsPage *page = (struct FolderItemSettingsPage *) data;
+       GtkColorSelection *colorsel = (GtkColorSelection *)
+                               ((GtkColorSelectionDialog *) page->color_dialog)->colorsel;
+       gdouble color[4];
+       guint red, green, blue, rgbvalue;
+
+       gtk_color_selection_get_color(colorsel, color);
+
+       red      = (guint) (color[0] * 255.0);
+       green    = (guint) (color[1] * 255.0);
+       blue     = (guint) (color[2] * 255.0);
+       rgbvalue = (guint) ((red * 0x10000) | (green * 0x100) | blue);
+
+       page->item->prefs->color = rgbvalue;
+       set_button_color(rgbvalue, page->folder_color_btn);
+
+       gtk_widget_destroy(page->color_dialog);
 }
 
-gint prefs_folder_item_get_sort_mode(FolderItem * item)
+static void folder_color_set_dialog_cancel(GtkWidget *widget, gpointer data)
 {
-       tmp_prefs = * item->prefs;
-
-       if (tmp_prefs.sort_by_number)
-               return SORT_BY_NUMBER;
-       if (tmp_prefs.sort_by_size)
-               return SORT_BY_SIZE;
-       if (tmp_prefs.sort_by_date)
-               return SORT_BY_DATE;
-       if (tmp_prefs.sort_by_from)
-               return SORT_BY_FROM;
-       if (tmp_prefs.sort_by_subject)
-               return SORT_BY_SUBJECT;
-       if (tmp_prefs.sort_by_score)
-               return SORT_BY_SCORE;
-       return SORT_BY_NONE;
+       struct FolderItemSettingsPage *page = (struct FolderItemSettingsPage *) data;
+       gtk_widget_destroy(page->color_dialog);
 }
 
-gint prefs_folder_item_get_sort_type(FolderItem * item)
+static void folder_color_set_dialog_key_pressed(GtkWidget *widget,
+                                               GdkEventKey *event,
+                                               gpointer data)
 {
-       tmp_prefs = * item->prefs;
+       struct FolderItemSettingsPage *page = (struct FolderItemSettingsPage *) data;
+       gtk_widget_destroy(page->color_dialog);
+}
 
-       if (tmp_prefs.sort_descending)
-               return GTK_SORT_DESCENDING;
-       else
-               return GTK_SORT_ASCENDING;
+struct FolderItemSettingsPage folder_item_settings_page;
+
+static void register_settings_page()
+{
+        folder_item_settings_page.page.path = "Settings";
+        folder_item_settings_page.page.create_widget = prefs_folder_item_settings_create_widget_func;
+        folder_item_settings_page.page.destroy_widget = prefs_folder_item_settings_destroy_widget_func;
+        folder_item_settings_page.page.save_page = prefs_folder_item_settings_save_func;
+        
+       prefs_folder_item_register_page((PrefsPage *) &folder_item_settings_page);
+}
+
+static GSList *prefs_pages = NULL;
+
+void prefs_folder_item_open(FolderItem *item)
+{
+       if (prefs_pages == NULL) {
+               register_settings_page();
+       }
+
+       prefswindow_open(_("Settings for folder"), prefs_pages, item);
+}
+
+void prefs_folder_item_register_page(PrefsPage *page)
+{
+       prefs_pages = g_slist_append(prefs_pages, page);
+}
+
+void prefs_folder_item_unregister_page(PrefsPage *page)
+{
+       prefs_pages = g_slist_remove(prefs_pages, page);
 }