#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);
{N_("/---"), NULL, NULL, 0, "<Separator>"},
{N_("/Remove _mailbox"), NULL, folderview_remove_mailbox_cb, 0, NULL},
{N_("/---"), NULL, NULL, 0, "<Separator>"},
- {N_("/_Search messages..."), NULL, folderview_search_cb, 0, NULL},
+ {N_("/_Search folder..."), NULL, folderview_search_cb, 0, NULL},
{N_("/_Property..."), NULL, folderview_property_cb, 0, NULL},
{N_("/_Processing..."), NULL, folderview_processing_cb, 0, NULL},
{N_("/S_coring..."), NULL, folderview_scoring_cb, 0, 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 messages..."), NULL, folderview_search_cb, 0, NULL},
+ {N_("/_Search folder..."), NULL, folderview_search_cb, 0, NULL},
{N_("/_Property..."), NULL, NULL, 0, NULL},
{N_("/_Processing..."), NULL, folderview_processing_cb, 0, NULL},
{N_("/S_coring..."), NULL, folderview_scoring_cb, 0, NULL}
{N_("/---"), NULL, NULL, 0, "<Separator>"},
{N_("/Remove _news account"), NULL, folderview_rm_news_server_cb, 0, NULL},
{N_("/---"), NULL, NULL, 0, "<Separator>"},
- {N_("/_Search messages..."), NULL, folderview_search_cb, 0, NULL},
+ {N_("/_Search folder..."), NULL, folderview_search_cb, 0, NULL},
{N_("/_Property..."), NULL, NULL, 0, NULL},
- {N_("/_Processing..."), NULL, folderview_processing_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:
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 messages...", search_folder);
+ 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, "/Remove IMAP4 account", remove_tree);
SET_SENS(imap_factory, "/Processing...", folder_processing);
SET_SENS(imap_factory, "/Scoring...", folder_scoring);
- SET_SENS(imap_factory, "/Search messages...", search_folder);
+ 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 messages...", search_folder);
+ 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) {
}
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);
}