GdkEventKey *event,
gpointer data);
+static gint foldersel_clist_compare (GtkCList *clist,
+ gconstpointer ptr1,
+ gconstpointer ptr2);
+
FolderItem *foldersel_folder_sel(Folder *cur_folder,
FolderSelectionType type,
const gchar *default_folder)
gtk_window_set_position(GTK_WINDOW(window), GTK_WIN_POS_CENTER);
gtk_window_set_modal(GTK_WINDOW(window), TRUE);
gtk_window_set_policy(GTK_WINDOW(window), TRUE, TRUE, TRUE);
+ gtk_window_set_wmclass
+ (GTK_WINDOW(window), "folder_selection", "Sylpheed");
gtk_signal_connect(GTK_OBJECT(window), "delete_event",
GTK_SIGNAL_FUNC(delete_event), NULL);
gtk_signal_connect(GTK_OBJECT(window), "key_press_event",
GTK_SIGNAL_FUNC(key_pressed), NULL);
- gtk_signal_connect(GTK_OBJECT(window), "focus_in_event",
- GTK_SIGNAL_FUNC(manage_window_focus_in), NULL);
- gtk_signal_connect(GTK_OBJECT(window), "focus_out_event",
- GTK_SIGNAL_FUNC(manage_window_focus_out), NULL);
+ MANAGE_WINDOW_SIGNALS_CONNECT(window);
vbox = gtk_vbox_new(FALSE, 4);
gtk_container_add(GTK_CONTAINER(window), vbox);
gtk_ctree_set_expander_style(GTK_CTREE(ctree),
GTK_CTREE_EXPANDER_SQUARE);
gtk_ctree_set_indent(GTK_CTREE(ctree), CTREE_INDENT);
+ gtk_clist_set_compare_func(GTK_CLIST(ctree), foldersel_clist_compare);
GTK_WIDGET_UNSET_FLAGS(GTK_CLIST(ctree)->column[0].button,
GTK_CAN_FOCUS);
/* gtk_signal_connect(GTK_OBJECT(ctree), "tree_select_row",
name = _("Inbox");
break;
case F_OUTBOX:
- name = _("Outbox");
+ name = _("Sent");
break;
case F_QUEUE:
name = _("Queue");
name = _("Trash");
break;
case F_DRAFT:
- name = _("Draft");
+ name = _("Drafts");
break;
default:
name = item->name;
#define SET_SPECIAL_FOLDER(item) \
{ \
if (item) { \
- GtkCTreeNode *node_, *sibling; \
+ GtkCTreeNode *node_, *parent, *sibling; \
\
node_ = gtk_ctree_find_by_row_data \
(GTK_CTREE(ctree), node, item); \
if (!node_) \
g_warning("%s not found.\n", item->path); \
else { \
- if (!prev) \
- sibling = GTK_CTREE_ROW(node)->children; \
- else \
+ parent = GTK_CTREE_ROW(node_)->parent; \
+ if (prev && parent == GTK_CTREE_ROW(prev)->parent) \
sibling = GTK_CTREE_ROW(prev)->sibling; \
+ else \
+ sibling = GTK_CTREE_ROW(parent)->children; \
if (node_ != sibling) \
gtk_ctree_move(GTK_CTREE(ctree), \
- node_, node, sibling); \
+ node_, parent, sibling); \
} \
\
prev = node_; \
folder->node,
foldersel_gnode_func,
NULL);
- gtk_ctree_sort_recursive(GTK_CTREE(ctree), node);
+ gtk_sctree_sort_recursive(GTK_CTREE(ctree), node);
SET_SPECIAL_FOLDER(folder->inbox);
SET_SPECIAL_FOLDER(folder->outbox);
SET_SPECIAL_FOLDER(folder->draft);
if (event && event->keyval == GDK_Escape)
foldersel_cancel(NULL, NULL);
}
+
+static gint foldersel_clist_compare(GtkCList *clist,
+ gconstpointer ptr1, gconstpointer ptr2)
+{
+ FolderItem *item1 = ((GtkCListRow *)ptr1)->data;
+ FolderItem *item2 = ((GtkCListRow *)ptr2)->data;
+
+ if (!item1->name)
+ return (item2->name != NULL);
+ if (!item2->name)
+ return -1;
+
+ return g_strcasecmp(item1->name, item2->name);
+}