aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorhiro <hiro@ee746299-78ed-0310-b773-934348b2243d>2005-04-12 09:41:28 +0000
committerhiro <hiro@ee746299-78ed-0310-b773-934348b2243d>2005-04-12 09:41:28 +0000
commit5b061cee06fde861174b7e186c5bfacbd1a97b4c (patch)
tree59a9fbbb5689e339c8a87deef400975db7dac4f9 /src
parent0357b77bd93423f308ed98e31249e51a9d43ed5c (diff)
folderview.c: remember the column width and restored Search menu.
git-svn-id: svn://sylpheed.sraoss.jp/sylpheed/trunk@212 ee746299-78ed-0310-b773-934348b2243d
Diffstat (limited to 'src')
-rw-r--r--src/folderview.c44
-rw-r--r--src/gtkutils.c19
-rw-r--r--src/gtkutils.h3
3 files changed, 37 insertions, 29 deletions
diff --git a/src/folderview.c b/src/folderview.c
index a5aeb9d9..8d3da98e 100644
--- a/src/folderview.c
+++ b/src/folderview.c
@@ -146,6 +146,10 @@ static void folderview_row_collapsed (GtkTreeView *treeview,
static void folderview_popup_close (GtkMenuShell *menu_shell,
FolderView *folderview);
+static void folderview_col_resized (GtkTreeView *treeview,
+ GtkAllocation *allocation,
+ FolderView *folderview);
+
static void folderview_download_cb (FolderView *folderview,
guint action,
GtkWidget *widget);
@@ -347,6 +351,9 @@ FolderView *folderview_create(void)
gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column);
gtk_tree_view_set_expander_column(GTK_TREE_VIEW(treeview), column);
+ g_signal_connect(G_OBJECT(column->button), "size-allocate",
+ G_CALLBACK(folderview_col_resized), folderview);
+
renderer = gtk_cell_renderer_text_new();
g_object_set(renderer, "xalign", 1.0, "ypad", 0, NULL);
column = gtk_tree_view_column_new_with_attributes
@@ -421,9 +428,6 @@ FolderView *folderview_create(void)
G_CALLBACK(folderview_row_collapsed),
folderview);
- //g_signal_connect(G_OBJECT(ctree), "resize_column",
- // G_CALLBACK(folderview_col_resized), folderview);
-
g_signal_connect(G_OBJECT(mail_popup), "selection_done",
G_CALLBACK(folderview_popup_close), folderview);
g_signal_connect(G_OBJECT(imap_popup), "selection_done",
@@ -466,7 +470,6 @@ void folderview_init(FolderView *folderview)
{
GtkWidget *treeview = folderview->treeview;
- //gtk_widget_realize(treeview);
stock_pixbuf_gdk(treeview, STOCK_PIXMAP_INBOX, &inbox_pixbuf);
stock_pixbuf_gdk(treeview, STOCK_PIXMAP_OUTBOX, &outbox_pixbuf);
stock_pixbuf_gdk(treeview, STOCK_PIXMAP_DIR_CLOSE, &folder_pixbuf);
@@ -632,8 +635,9 @@ void folderview_select_next_unread(FolderView *folderview)
return;
}
- if (!folderview->opened) // return if searched from first
+ if (!folderview->opened)
return;
+
/* search again from the first row */
if (folderview_find_next_unread(model, &next, NULL))
folderview_select_row(folderview, &next);
@@ -1411,8 +1415,9 @@ static gboolean folderview_menu_popup(FolderView *folderview,
folder_property = TRUE;
} else {
folder_property = TRUE;
- //if (folderview->selected == folderview->opened)
- // search_folder = TRUE;
+ if (gtkut_tree_row_reference_equal(folderview->selected,
+ folderview->opened))
+ search_folder = TRUE;
}
if (FOLDER_IS_LOCAL(folder) || FOLDER_TYPE(folder) == F_IMAP) {
if (item->parent == NULL)
@@ -1488,8 +1493,6 @@ static gboolean folderview_button_pressed(GtkWidget *widget,
GtkTreeView *treeview = GTK_TREE_VIEW(widget);
GtkTreePath *path;
- //g_print("button pressed\n");
-
if (!event)
return FALSE;
@@ -1513,7 +1516,6 @@ static gboolean folderview_button_released(GtkWidget *treeview,
GdkEventButton *event,
FolderView *folderview)
{
- //g_print("button released\n");
folderview->open_folder = FALSE;
return FALSE;
}
@@ -1700,28 +1702,12 @@ static void folderview_popup_close(GtkMenuShell *menu_shell,
gtk_tree_path_free(path);
}
-#if 0
-static void folderview_col_resized(GtkCList *clist, gint column, gint width,
+static void folderview_col_resized(GtkTreeView *treeview,
+ GtkAllocation *allocation,
FolderView *folderview)
{
- switch (column) {
- case COL_FOLDER:
- prefs_common.folder_col_folder = width;
- break;
- case COL_NEW:
- prefs_common.folder_col_new = width;
- break;
- case COL_UNREAD:
- prefs_common.folder_col_unread = width;
- break;
- case COL_TOTAL:
- prefs_common.folder_col_total = width;
- break;
- default:
- break;
- }
+ prefs_common.folder_col_folder = allocation->width;
}
-#endif
static void folderview_download_func(Folder *folder, FolderItem *item,
gpointer data)
diff --git a/src/gtkutils.c b/src/gtkutils.c
index 02cb7a36..3807c9ef 100644
--- a/src/gtkutils.c
+++ b/src/gtkutils.c
@@ -449,6 +449,25 @@ gboolean gtkut_tree_model_find_by_column_data(GtkTreeModel *model,
return FALSE;
}
+gboolean gtkut_tree_row_reference_equal(GtkTreeRowReference *ref1,
+ GtkTreeRowReference *ref2)
+{
+ GtkTreePath *path1, *path2;
+ gint result;
+
+ g_return_val_if_fail(ref1 != NULL && ref2 != NULL, FALSE);
+
+ path1 = gtk_tree_row_reference_get_path(ref1);
+ path2 = gtk_tree_row_reference_get_path(ref2);
+
+ result = gtk_tree_path_compare(path1, path2);
+
+ gtk_tree_path_free(path2);
+ gtk_tree_path_free(path1);
+
+ return (result == 0);
+}
+
gboolean gtkut_tree_view_find_collapsed_parent(GtkTreeView *treeview,
GtkTreeIter *parent,
GtkTreeIter *iter)
diff --git a/src/gtkutils.h b/src/gtkutils.h
index 724d510f..5aa30081 100644
--- a/src/gtkutils.h
+++ b/src/gtkutils.h
@@ -141,6 +141,9 @@ gboolean gtkut_tree_model_find_by_column_data
gint col,
gpointer data);
+gboolean gtkut_tree_row_reference_equal (GtkTreeRowReference *ref1,
+ GtkTreeRowReference *ref2);
+
gboolean gtkut_tree_view_find_collapsed_parent
(GtkTreeView *treeview,
GtkTreeIter *parent,