static GdkPixbuf *folder_pixbuf = NULL;
static GdkPixbuf *folderopen_pixbuf = NULL;
static GdkPixbuf *foldernoselect_pixbuf = NULL;
+static GdkPixbuf *foldernoselectopen_pixbuf = NULL;
static GtkWidget *window;
static GtkWidget *treeview;
static gboolean cancelled;
static gboolean finished;
-static void foldersel_create (void);
+static void foldersel_create (const gchar *title);
static void foldersel_init (void);
static void foldersel_append_item (GtkTreeStore *store,
FolderItemSearch *data);
FolderItem *foldersel_folder_sel(Folder *cur_folder, FolderSelectionType type,
- const gchar *default_folder, gboolean can_sel_mailbox)
+ const gchar *default_folder, gboolean can_sel_mailbox,
+ const gchar *title)
{
selected_item = NULL;
root_selectable = can_sel_mailbox;
if (!window) {
- foldersel_create();
+ foldersel_create(title);
foldersel_init();
}
gtk_widget_grab_focus(treeview);
gtk_window_present(GTK_WINDOW(window));
- gtk_window_set_modal(GTK_WINDOW(window), TRUE);
manage_window_set_transient(GTK_WINDOW(window));
+ gtk_window_set_modal(GTK_WINDOW(window), TRUE);
cancelled = finished = FALSE;
prefs_common.folderselwin_height = allocation->height;
}
-static void foldersel_create(void)
+static void foldersel_create(const gchar *title)
{
GtkWidget *vbox;
GtkWidget *scrolledwin;
GtkWidget *confirm_area;
+ GtkWidget *label;
GtkTreeViewColumn *column;
GtkCellRenderer *renderer;
GtkTreeSelection *selection;
static GdkGeometry geometry;
window = gtkut_window_new(GTK_WINDOW_TOPLEVEL, "foldersel");
- gtk_window_set_title(GTK_WINDOW(window), _("Select folder"));
+ gtk_window_set_title(GTK_WINDOW(window),_("Select folder"));
gtk_container_set_border_width(GTK_CONTAINER(window), 4);
gtk_window_set_position(GTK_WINDOW(window), GTK_WIN_POS_CENTER);
gtk_window_set_resizable(GTK_WINDOW(window), TRUE);
vbox = gtk_vbox_new(FALSE, 4);
gtk_container_add(GTK_CONTAINER(window), vbox);
+ if (title != NULL) {
+ label = gtk_label_new(title);
+ gtk_label_set_line_wrap(GTK_LABEL(label), TRUE);
+ gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0);
+ }
+
scrolledwin = gtk_scrolled_window_new(NULL, NULL);
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwin),
GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS);
/* create text renderer */
renderer = gtk_cell_renderer_text_new();
+ gtk_cell_renderer_set_padding(renderer, 0, 0);
gtk_tree_view_column_pack_start(column, renderer, TRUE);
gtk_tree_view_column_set_attributes
(column, renderer,
static void foldersel_init(void)
{
- stock_pixbuf_gdk(treeview, STOCK_PIXMAP_DIR_CLOSE,
- &folder_pixbuf);
- stock_pixbuf_gdk(treeview, STOCK_PIXMAP_DIR_OPEN,
- &folderopen_pixbuf);
- stock_pixbuf_gdk(treeview, STOCK_PIXMAP_DIR_NOSELECT,
- &foldernoselect_pixbuf);
+ stock_pixbuf_gdk(STOCK_PIXMAP_DIR_CLOSE, &folder_pixbuf);
+ stock_pixbuf_gdk(STOCK_PIXMAP_DIR_OPEN, &folderopen_pixbuf);
+ stock_pixbuf_gdk(STOCK_PIXMAP_DIR_NOSELECT_CLOSE, &foldernoselect_pixbuf);
+ stock_pixbuf_gdk(STOCK_PIXMAP_DIR_NOSELECT_OPEN, &foldernoselectopen_pixbuf);
}
void foldersel_reflect_prefs_pixmap_theme(void)
g_object_unref(folderopen_pixbuf);
if (foldernoselect_pixbuf)
g_object_unref(foldernoselect_pixbuf);
+ if (foldernoselectopen_pixbuf)
+ g_object_unref(foldernoselectopen_pixbuf);
foldersel_init();
}
gtkut_convert_int_to_gdk_color(prefs_common.color_new, &color_new);
- name = tmpname = folder_item_get_name(item);
-
- if (item->stype != F_NORMAL && FOLDER_IS_LOCAL(item->folder)) {
- switch (item->stype) {
- case F_INBOX:
- if (!strcmp2(item->name, INBOX_DIR))
- name = _("Inbox");
- break;
- case F_OUTBOX:
- if (!strcmp2(item->name, OUTBOX_DIR))
- name = _("Sent");
- break;
- case F_QUEUE:
- if (!strcmp2(item->name, QUEUE_DIR))
- name = _("Queue");
- break;
- case F_TRASH:
- if (!strcmp2(item->name, TRASH_DIR))
- name = _("Trash");
- break;
- case F_DRAFT:
- if (!strcmp2(item->name, DRAFT_DIR))
- name = _("Drafts");
- break;
- default:
- break;
- }
- }
+ name = folder_item_get_name(item);
if (folder_has_parent_of_type(item, F_QUEUE) && item->total_msgs > 0) {
- name = g_strdup_printf("%s (%d)", name, item->total_msgs);
+ tmpname = g_strdup_printf("%s (%d)", name, item->total_msgs);
} else if (item->unread_msgs > 0) {
- name = g_strdup_printf("%s (%d)", name, item->unread_msgs);
+ tmpname = g_strdup_printf("%s (%d)", name, item->unread_msgs);
} else
- name = g_strdup(name);
+ tmpname = g_strdup(name);
+
+ g_free(name);
+ name = tmpname;
pixbuf = item->no_select ? foldernoselect_pixbuf : folder_pixbuf;
pixbuf_open =
- item->no_select ? foldernoselect_pixbuf : folderopen_pixbuf;
+ item->no_select ? foldernoselectopen_pixbuf : folderopen_pixbuf;
if (folder_has_parent_of_type(item, F_DRAFT) ||
folder_has_parent_of_type(item, F_OUTBOX) ||
FOLDERSEL_BOLD, weight,
-1);
- g_free(tmpname);
+ g_free(name);
}
static void foldersel_insert_gnode_in_store(GtkTreeStore *store, GNode *node,
static gboolean key_pressed(GtkWidget *widget, GdkEventKey *event, gpointer data)
{
- if (event && event->keyval == GDK_KEY_Escape)
+ if (!event)
+ return FALSE;
+
+ if (event->keyval == GDK_KEY_Escape) {
foldersel_cancel(NULL, NULL);
+ return TRUE;
+ }
+
+ GtkTreePath *path = NULL;
+ gtk_tree_view_get_cursor(GTK_TREE_VIEW(treeview), &path, NULL);
+ if (path == NULL)
+ return FALSE;
+
+ switch (event->keyval) {
+ case GDK_KEY_Left:
+ if (gtk_tree_view_row_expanded(GTK_TREE_VIEW(treeview), path)) {
+ gtk_tree_view_collapse_row(GTK_TREE_VIEW(treeview), path);
+ } else {
+ gtk_tree_path_up(path);
+ gtk_tree_view_set_cursor(GTK_TREE_VIEW(treeview), path, NULL, FALSE);
+ }
+ return TRUE;
+ break;
+ case GDK_KEY_Right:
+ if (!gtk_tree_view_row_expanded(GTK_TREE_VIEW(treeview), path)) {
+ gtk_tree_view_expand_row(GTK_TREE_VIEW(treeview), path, FALSE);
+ } else {
+ gtk_tree_path_down(path);
+ gtk_tree_view_set_cursor(GTK_TREE_VIEW(treeview), path, NULL, FALSE);
+ }
+ return TRUE;
+ break;
+ }
+
+ gtk_tree_path_free(path);
+
return FALSE;
}