#include "mainwindow.h"
#include "folderview.h"
#include "summaryview.h"
+#include "summary_search.h"
#include "inputdialog.h"
#include "grouplistdialog.h"
#include "manage_window.h"
#include "inc.h"
#include "pixmaps/inbox.xpm"
+#include "pixmaps/inbox-hrm.xpm"
#include "pixmaps/outbox.xpm"
+#include "pixmaps/outbox-hrm.xpm"
#include "pixmaps/dir-close.xpm"
#include "pixmaps/dir-open.xpm"
+#include "pixmaps/dir-open-hrm.xpm"
#include "pixmaps/trash.xpm"
+#include "pixmaps/trash-hrm.xpm"
typedef enum
{
static GdkPixmap *inboxxpm;
static GdkBitmap *inboxxpmmask;
+static GdkPixmap *inboxhrmxpm;
+static GdkBitmap *inboxhrmxpmmask;
static GdkPixmap *outboxxpm;
static GdkBitmap *outboxxpmmask;
+static GdkPixmap *outboxhrmxpm;
+static GdkBitmap *outboxhrmxpmmask;
static GdkPixmap *folderxpm;
static GdkBitmap *folderxpmmask;
static GdkPixmap *folderopenxpm;
static GdkBitmap *folderopenxpmmask;
+static GdkPixmap *folderopenhrmxpm;
+static GdkBitmap *folderopenhrmxpmmask;
static GdkPixmap *trashxpm;
static GdkBitmap *trashxpmmask;
+static GdkPixmap *trashhrmxpm;
+static GdkBitmap *trashhrmxpmmask;
static void folderview_select_node (FolderView *folderview,
GtkCTreeNode *node);
guint action,
GtkWidget *widget);
+static void folderview_search_cb (FolderView *folderview,
+ guint action,
+ GtkWidget *widget);
+
static gboolean folderview_drag_motion_cb(GtkWidget *widget,
GdkDragContext *context,
gint x,
FolderView *folderview);
static void folderview_scoring_cb(FolderView *folderview, guint action,
GtkWidget *widget);
+static void folderview_processing_cb(FolderView *folderview, guint action,
+ GtkWidget *widget);
static void folderview_property_cb(FolderView *folderview, guint action, GtkWidget *widget);
static GtkItemFactoryEntry folderview_mbox_popup_entries[] =
{N_("/Remove _mailbox"), NULL, folderview_remove_mailbox_cb, 0, NULL},
{N_("/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Property..."), NULL, NULL, 0, NULL},
+ {N_("/_Processing..."), NULL, folderview_processing_cb, 0, NULL},
{N_("/_Scoring..."), NULL, folderview_scoring_cb, 0, NULL}
};
{N_("/_Delete folder"), NULL, folderview_delete_folder_cb, 0, NULL},
{N_("/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Update folder tree"), NULL, folderview_update_tree_cb, 0, NULL},
- {N_("/Re_scan folder tree"), NULL, folderview_update_tree_cb, 1, NULL},
+ {N_("/R_escan folder tree"), NULL, folderview_update_tree_cb, 1, NULL},
{N_("/---"), NULL, NULL, 0, "<Separator>"},
{N_("/Remove _mailbox"), NULL, folderview_remove_mailbox_cb, 0, NULL},
{N_("/---"), NULL, NULL, 0, "<Separator>"},
+ {N_("/_Search folder..."), NULL, folderview_search_cb, 0, NULL},
{N_("/_Property..."), NULL, folderview_property_cb, 0, NULL},
- {N_("/_Scoring..."), NULL, folderview_scoring_cb, 0, NULL}
+ {N_("/_Processing..."), NULL, folderview_processing_cb, 0, NULL},
+ {N_("/S_coring..."), NULL, folderview_scoring_cb, 0, NULL}
};
static GtkItemFactoryEntry folderview_imap_popup_entries[] =
{N_("/_Delete folder"), NULL, folderview_rm_imap_folder_cb, 0, NULL},
{N_("/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Update folder tree"), NULL, folderview_update_tree_cb, 0, NULL},
- {N_("/Re_scan folder tree"), NULL, folderview_update_tree_cb, 1, NULL},
+ {N_("/R_escan folder tree"), NULL, folderview_update_tree_cb, 1, NULL},
{N_("/---"), NULL, NULL, 0, "<Separator>"},
{N_("/Remove _IMAP4 account"), NULL, folderview_rm_imap_server_cb, 0, NULL},
{N_("/---"), NULL, NULL, 0, "<Separator>"},
+ {N_("/_Search folder..."), NULL, folderview_search_cb, 0, NULL},
{N_("/_Property..."), NULL, NULL, 0, NULL},
- {N_("/_Scoring..."), NULL, folderview_scoring_cb, 0, NULL}
+ {N_("/_Processing..."), NULL, folderview_processing_cb, 0, NULL},
+ {N_("/S_coring..."), NULL, folderview_scoring_cb, 0, NULL}
};
static GtkItemFactoryEntry folderview_news_popup_entries[] =
{N_("/---"), NULL, NULL, 0, "<Separator>"},
{N_("/Remove _news account"), NULL, folderview_rm_news_server_cb, 0, NULL},
{N_("/---"), NULL, NULL, 0, "<Separator>"},
+ {N_("/_Search folder..."), NULL, folderview_search_cb, 0, NULL},
{N_("/_Property..."), NULL, NULL, 0, NULL},
- {N_("/_Scoring..."), NULL, folderview_scoring_cb, 0, NULL}
+ {N_("/_Processing..."), NULL, folderview_processing_cb, 0, NULL},
+ {N_("/S_coring..."), NULL, folderview_scoring_cb, 0, NULL}
};
gtk_drag_dest_set(ctree, GTK_DEST_DEFAULT_ALL &
~GTK_DEST_DEFAULT_HIGHLIGHT,
summary_drag_types, 1,
- GDK_ACTION_MOVE);
+ GDK_ACTION_MOVE|GDK_ACTION_COPY|GDK_ACTION_DEFAULT);
gtk_signal_connect(GTK_OBJECT(ctree), "drag_motion",
GTK_SIGNAL_FUNC(folderview_drag_motion_cb),
folderview);
GtkWidget *ctree = folderview->ctree;
PIXMAP_CREATE(ctree, inboxxpm, inboxxpmmask, inbox_xpm);
+ PIXMAP_CREATE(ctree, inboxhrmxpm, inboxhrmxpmmask, inbox_hrm_xpm);
PIXMAP_CREATE(ctree, outboxxpm, outboxxpmmask, outbox_xpm);
+ PIXMAP_CREATE(ctree, outboxhrmxpm, outboxhrmxpmmask, outbox_hrm_xpm);
PIXMAP_CREATE(ctree, folderxpm, folderxpmmask, dir_close_xpm);
PIXMAP_CREATE(ctree, folderopenxpm, folderopenxpmmask, dir_open_xpm);
+ PIXMAP_CREATE(ctree, folderopenhrmxpm, folderopenhrmxpmmask,
+ dir_open_hrm_xpm);
PIXMAP_CREATE(ctree, trashxpm, trashxpmmask, trash_xpm);
+ PIXMAP_CREATE(ctree, trashhrmxpm, trashhrmxpmmask, trash_hrm_xpm);
if (!normalfont)
normalfont = gdk_fontset_load(NORMAL_FONT);
item = gtk_ctree_node_get_row_data(ctree, row);
if (!item) return;
+
+ /* CLAWS: don't know why but this always seems to be true
+ * when deleting messages. Somewhere claws does a folder
+ * scan which sets all new, unread & total to the correct
+ * values. It then enters this function, but leaves it
+ * because new, unread and total are the same... */
+#ifndef CLAWS
if (prev_row == row &&
item->new == new &&
item->unread == unread &&
- item->total == total)
+ item->total == total)
return;
+#endif
prev_row = row;
switch (item->stype) {
case F_INBOX:
- xpm = openxpm = inboxxpm;
- mask = openmask = inboxxpmmask;
+ xpm = inboxxpm;
+ mask = inboxxpmmask;
+ if (item->hide_read_msgs) {
+ openxpm = inboxhrmxpm;
+ openmask = inboxhrmxpmmask;
+ } else {
+ openxpm = inboxxpm;
+ openmask = inboxxpmmask;
+ }
name = g_strdup(_("Inbox"));
break;
case F_OUTBOX:
- xpm = openxpm = outboxxpm;
- mask = openmask = outboxxpmmask;
+ xpm = outboxxpm;
+ mask =outboxxpmmask;
+ if (item->hide_read_msgs) {
+ openxpm = outboxhrmxpm;
+ openmask = outboxhrmxpmmask;
+ } else {
+ openxpm = outboxxpm;
+ openmask = outboxxpmmask;
+ }
name = g_strdup(_("Outbox"));
break;
case F_QUEUE:
- xpm = openxpm = outboxxpm;
- mask = openmask = outboxxpmmask;
+ xpm = outboxxpm;
+ mask =outboxxpmmask;
+ if (item->hide_read_msgs) {
+ openxpm = outboxhrmxpm;
+ openmask = outboxhrmxpmmask;
+ } else {
+ openxpm = outboxxpm;
+ openmask = outboxxpmmask;
+ }
name = g_strdup(_("Queue"));
break;
case F_TRASH:
- xpm = openxpm = trashxpm;
- mask = openmask = trashxpmmask;
+ xpm = trashxpm;
+ mask = trashxpmmask;
+ if (item->hide_read_msgs) {
+ openxpm = trashhrmxpm;
+ openmask = trashhrmxpmmask;
+ } else {
+ openxpm = trashxpm;
+ openmask = trashxpmmask;
+ }
name = g_strdup(_("Trash"));
break;
case F_DRAFT:
xpm = folderxpm;
mask = folderxpmmask;
- openxpm = folderopenxpm;
- openmask = folderopenxpmmask;
+ if (item->hide_read_msgs) {
+ openxpm = folderopenhrmxpm;
+ openmask = folderopenhrmxpmmask;
+ } else {
+ openxpm = folderopenxpm;
+ openmask = folderopenxpmmask;
+ }
name = g_strdup(_("Draft"));
break;
default:
xpm = folderxpm;
mask = folderxpmmask;
- openxpm = folderopenxpm;
- openmask = folderopenxpmmask;
+ if (item->hide_read_msgs) {
+ openxpm = folderopenhrmxpm;
+ openmask = folderopenhrmxpmmask;
+ } else {
+ openxpm = folderopenxpm;
+ openmask = folderopenxpmmask;
+ }
if (!item->parent) {
switch (item->folder->type) {
case F_MH:
gboolean rescan_tree = FALSE;
gboolean remove_tree = FALSE;
gboolean folder_property = FALSE;
+ gboolean folder_processing = FALSE;
gboolean folder_scoring = FALSE;
+ gboolean search_folder = FALSE;
if (!event) return;
new_folder = TRUE;
if (item->parent == NULL)
update_tree = remove_tree = TRUE;
+ else
+ search_folder = TRUE;
if (FOLDER_IS_LOCAL(folder) || FOLDER_TYPE(folder) == F_IMAP || FOLDER_TYPE(folder) == F_MBOX) {
if (item->parent == NULL)
update_tree = rescan_tree = TRUE;
else if (item->stype == F_NORMAL)
- rename_folder = delete_folder = folder_property = folder_scoring = TRUE;
+ rename_folder = delete_folder = folder_property = folder_scoring = folder_processing = TRUE;
+ else if (item->stype == F_INBOX)
+ folder_property = folder_scoring = folder_processing = TRUE;
+ else if (item->stype == F_TRASH)
+ folder_processing = TRUE;
+ else if (item->stype == F_OUTBOX)
+ folder_processing = TRUE;
} else if (FOLDER_TYPE(folder) == F_NEWS) {
if (item->parent != NULL)
- delete_folder = folder_scoring = TRUE;
+ delete_folder = folder_scoring = folder_processing = TRUE;
}
}
SET_SENS(mail_factory, "/Rescan folder tree", rescan_tree);
SET_SENS(mail_factory, "/Remove mailbox", remove_tree);
SET_SENS(mail_factory, "/Property...", folder_property);
+ SET_SENS(mail_factory, "/Processing...", folder_processing);
SET_SENS(mail_factory, "/Scoring...", folder_scoring);
+ SET_SENS(mail_factory, "/Search folder...", search_folder);
} else if (FOLDER_TYPE(folder) == F_IMAP) {
popup = folderview->imap_popup;
menu_set_insensitive_all(GTK_MENU_SHELL(popup));
SET_SENS(imap_factory, "/Update folder tree", update_tree);
SET_SENS(imap_factory, "/Rescan folder tree", rescan_tree);
SET_SENS(imap_factory, "/Remove IMAP4 account", remove_tree);
+ SET_SENS(imap_factory, "/Processing...", folder_processing);
SET_SENS(imap_factory, "/Scoring...", folder_scoring);
+ SET_SENS(imap_factory, "/Search folder...", search_folder);
} else if (FOLDER_TYPE(folder) == F_NEWS) {
popup = folderview->news_popup;
menu_set_insensitive_all(GTK_MENU_SHELL(popup));
SET_SENS(news_factory, "/Subscribe to newsgroup...", new_folder);
SET_SENS(news_factory, "/Remove newsgroup", delete_folder);
SET_SENS(news_factory, "/Remove news account", remove_tree);
+ SET_SENS(news_factory, "/Search folder...", search_folder);
+ SET_SENS(news_factory, "/Processing...", folder_processing);
SET_SENS(news_factory, "/Scoring...", folder_scoring);
} else if (FOLDER_TYPE(folder) == F_MBOX) {
popup = folderview->mbox_popup;
SET_SENS(mbox_factory, "/Create new folder...", new_folder);
SET_SENS(mbox_factory, "/Rename folder...", rename_folder);
SET_SENS(mbox_factory, "/Delete folder", delete_folder);
+ SET_SENS(mbox_factory, "/Processing...", folder_processing);
SET_SENS(mbox_factory, "/Scoring...", folder_scoring);
} else
return;
_("NewFolder"));
if (!new_folder) return;
- if (strchr(new_folder, G_DIR_SEPARATOR) != NULL) {
- alertpanel_error(_("`%c' can't be included in folder name."),
- G_DIR_SEPARATOR);
- g_free(new_folder);
- return;
+ if (item->folder->type != F_MBOX) {
+ if (strchr(new_folder, G_DIR_SEPARATOR) != NULL) {
+ alertpanel_error(_("`%c' can't be included in folder name."),
+ G_DIR_SEPARATOR);
+ g_free(new_folder);
+ return;
+ }
}
/* find whether the directory already exists */
}
new_item = item->folder->create_folder(item->folder, item, new_folder);
+ if (!new_item) {
+ alertpanel_error(_("The folder `%s' could not be created."),
+ new_folder);
+ g_free(new_folder);
+ return;
+ }
g_free(new_folder);
- if (!new_item) return;
gtk_clist_freeze(GTK_CLIST(ctree));
folder_write_list();
}
-
-
-
-
-static GList *folderview_news_get_subscriptions(GtkCTree *ctree,
- GtkCTreeNode *node)
-{
- FolderItem *item;
- GList * result;
-
- result = NULL;
-
- if (!node)
- node = GTK_CTREE_NODE(GTK_CLIST(ctree)->row_list);
- if (!node)
- return NULL;
-
- node = GTK_CTREE_ROW(node)->children;
-
- while (node) {
- item = gtk_ctree_node_get_row_data(ctree, node);
-
- result = g_list_append(result, item->name);
- node = GTK_CTREE_ROW(node)->sibling;
- }
-
- return result;
-}
-
-
static void folderview_new_news_group_cb(FolderView *folderview, guint action,
GtkWidget *widget)
{
GtkCTree *ctree = GTK_CTREE(folderview->ctree);
gchar *text[N_FOLDER_COLS] = {NULL, "0", "0", "0"};
GtkCTreeNode *servernode, *node;
+ Folder *folder;
FolderItem *item;
+ FolderItem *rootitem;
FolderItem *newitem;
- const gchar *server;
- GList * subscriptions;
- GList * new_subscriptions;
- GList * l;
+ GSList *new_subscr;
+ GSList *cur;
+ GNode *gnode;
if (!folderview->selected) return;
item = gtk_ctree_node_get_row_data(ctree, folderview->selected);
g_return_if_fail(item != NULL);
- g_return_if_fail(item->folder != NULL);
- g_return_if_fail(item->folder->type == F_NEWS);
- g_return_if_fail(item->folder->account != NULL);
+ folder = item->folder;
+ g_return_if_fail(folder != NULL);
+ g_return_if_fail(folder->type == F_NEWS);
+ g_return_if_fail(folder->account != NULL);
if (GTK_CTREE_ROW(folderview->selected)->parent != NULL)
servernode = GTK_CTREE_ROW(folderview->selected)->parent;
else
servernode = folderview->selected;
- subscriptions = folderview_news_get_subscriptions(ctree, servernode);
+ rootitem = gtk_ctree_node_get_row_data(ctree, servernode);
- new_subscriptions = grouplist_dialog(item->folder, subscriptions);
+ new_subscr = grouplist_dialog(folder);
- for(l = subscriptions ; l != NULL ; l = l->next) {
- gchar * name;
-
- name = (gchar *) l->data;
+ /* remove unsubscribed newsgroups */
+ for (gnode = folder->node->children; gnode != NULL; ) {
+ GNode *next = gnode->next;
- if (g_list_find_custom(new_subscriptions, name,
- (GCompareFunc) g_strcasecmp) == NULL) {
- GtkCTreeNode * sel;
+ item = FOLDER_ITEM(gnode->data);
+ if (g_slist_find_custom(new_subscr, item->name,
+ (GCompareFunc)g_strcasecmp) != NULL) {
+ gnode = next;
+ continue;
+ }
- /* remove subscription */
+ node = gtk_ctree_find_by_row_data(ctree, servernode, item);
+ if (!node) {
+ gnode = next;
+ continue;
+ }
- sel = folderview_find_by_name(ctree, servernode, name);
- g_return_if_fail(sel != NULL);
+ if (folderview->opened == node) {
+ summary_clear_all(folderview->summaryview);
+ folderview->opened = NULL;
+ }
- item = gtk_ctree_node_get_row_data(ctree, sel);
+ folder_item_remove(item);
+ gtk_ctree_remove_node(ctree, node);
- g_return_if_fail(item != NULL);
- g_return_if_fail(item->folder != NULL);
- g_return_if_fail(item->folder->type == F_NEWS);
- g_return_if_fail(item->folder->account != NULL);
+ gnode = next;
+ }
- if (folderview->opened == sel) {
- summary_clear_all(folderview->summaryview);
- folderview->opened = NULL;
- }
-
- folder_item_remove(item);
- gtk_ctree_remove_node(ctree, sel);
+ gtk_clist_freeze(GTK_CLIST(ctree));
- }
- }
+ /* add subscribed newsgroups */
+ for (cur = new_subscr; cur != NULL; cur = cur->next) {
+ gchar *name = (gchar *)cur->data;
+
+ if (folderview_find_by_name(ctree, servernode, name) != NULL)
+ continue;
- g_list_free(subscriptions);
-
- for(l = new_subscriptions ; l != NULL ; l = l->next) {
- gchar * name;
-
- name = (gchar *) l->data;
-
- if (folderview_find_by_name(ctree, servernode, name) == NULL) {
-
- /* add newsgroup */
-
- gtk_clist_freeze(GTK_CLIST(ctree));
-
- text[COL_FOLDER] = name;
- node = gtk_ctree_insert_node(ctree, servernode, NULL, text,
- FOLDER_SPACING,
- folderxpm, folderxpmmask,
- folderopenxpm, folderopenxpmmask,
- FALSE, FALSE);
- gtk_ctree_expand(ctree, servernode);
-
- item = gtk_ctree_node_get_row_data(ctree, servernode);
- server = item->folder->account->nntp_server;
-
- newitem = folder_item_new(name, name);
- folder_item_append(item, newitem);
- gtk_ctree_node_set_row_data(ctree, node, newitem);
- gtk_ctree_sort_node(ctree, servernode);
-
- gtk_clist_thaw(GTK_CLIST(ctree));
-
- }
+ text[COL_FOLDER] = name;
+ node = gtk_ctree_insert_node(ctree, servernode, NULL, text,
+ FOLDER_SPACING,
+ folderxpm, folderxpmmask,
+ folderopenxpm, folderopenxpmmask,
+ FALSE, FALSE);
+ gtk_ctree_expand(ctree, servernode);
+
+ newitem = folder_item_new(name, name);
+ folder_item_append(rootitem, newitem);
+ gtk_ctree_node_set_row_data(ctree, node, newitem);
}
- list_free_strings(new_subscriptions);
- g_list_free(new_subscriptions);
+ gtk_ctree_sort_node(ctree, servernode);
+ gtk_clist_thaw(GTK_CLIST(ctree));
+
+ slist_free_strings(new_subscr);
+ g_slist_free(new_subscr);
folder_write_list();
}
folder_write_list();
}
+static void folderview_search_cb(FolderView *folderview, guint action,
+ GtkWidget *widget)
+{
+ summary_search(folderview->summaryview);
+}
+
static gboolean folderview_drag_motion_cb(GtkWidget *widget,
GdkDragContext *context,
gint x,
}
if (acceptable) {
+ gtk_signal_handler_block_by_func(GTK_OBJECT(widget),GTK_SIGNAL_FUNC(folderview_selected), folderview);
gtk_ctree_select(GTK_CTREE(widget), node);
- gdk_drag_status(context, context->suggested_action, time);
+ gtk_signal_handler_unblock_by_func(GTK_OBJECT(widget),GTK_SIGNAL_FUNC(folderview_selected), folderview);
+ gdk_drag_status(context,
+ (context->actions == GDK_ACTION_COPY ?
+ GDK_ACTION_COPY : GDK_ACTION_MOVE) , time);
} else {
gtk_ctree_select(GTK_CTREE(widget), folderview->opened);
gdk_drag_status(context, 0, time);
node = gtk_ctree_node_nth(GTK_CTREE(widget), row);
item = gtk_ctree_node_get_row_data(GTK_CTREE(widget), node);
if (item != NULL) {
- summary_move_selected_to(folderview->summaryview, item);
- gtk_drag_finish(drag_context, TRUE, TRUE, time);
+ switch (drag_context->action) {
+ case GDK_ACTION_COPY:
+ summary_copy_selected_to(folderview->summaryview, item);
+ gtk_drag_finish(drag_context, TRUE, FALSE, time);
+ break;
+ case GDK_ACTION_MOVE:
+ case GDK_ACTION_DEFAULT:
+ default:
+ summary_move_selected_to(folderview->summaryview, item);
+ gtk_drag_finish(drag_context, TRUE, TRUE, time);
+ break;
+ }
} else
gtk_drag_finish(drag_context, FALSE, FALSE, time);
}
prefs_scoring_open(item);
}
+static void folderview_processing_cb(FolderView *folderview, guint action,
+ GtkWidget *widget)
+{
+ GtkCTree *ctree = GTK_CTREE(folderview->ctree);
+ FolderItem *item;
+
+ if (!folderview->selected) return;
+
+ item = gtk_ctree_node_get_row_data(ctree, folderview->selected);
+ g_return_if_fail(item != NULL);
+ g_return_if_fail(item->folder != NULL);
+
+ prefs_filtering_open(item);
+}
+
static void folderview_property_cb(FolderView *folderview, guint action, GtkWidget *widget) {
GtkCTree *ctree = GTK_CTREE(folderview->ctree);
FolderItem *item;