From 7e7cbb0dce33f8527cb348e020f4800b0482f39e Mon Sep 17 00:00:00 2001 From: Linus Torvalds Date: Fri, 1 Feb 2013 09:40:54 +1100 Subject: When switching sort order, scroll the dive list to the current dive Now that we actually seem to understand the whole notion of setting the active dive, let's take that code a bit further, and always scroll to it when we're introducing a new sort ordering. Sure, there may be other selected dives, but we have one primary (current) dive that we show the profile and dive data for, and when we switch sort order we probably want to see that dive in the dive list. Signed-off-by: Linus Torvalds Signed-off-by: Dirk Hohndel --- divelist.c | 44 ++++++++++++++++++++++++++++++++------------ 1 file changed, 32 insertions(+), 12 deletions(-) diff --git a/divelist.c b/divelist.c index 50e279550..1463ef942 100644 --- a/divelist.c +++ b/divelist.c @@ -2502,6 +2502,13 @@ static gboolean button_press_cb(GtkWidget *treeview, GdkEventButton *event, gpoi return FALSE; } +static void scroll_to_path(GtkTreePath *path) +{ + gtk_tree_view_expand_to_path(GTK_TREE_VIEW(dive_list.tree_view), path); + gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(dive_list.tree_view), path, NULL, FALSE, 0, 0); + gtk_tree_view_set_cursor(GTK_TREE_VIEW(dive_list.tree_view), path, NULL, FALSE); +} + /* we need to have a temporary copy of the selected dives while switching model as the selection_cb function keeps getting called when gtk_tree_selection_select_path is called. We also need to @@ -2521,9 +2528,7 @@ static gboolean set_selected(GtkTreeModel *model, GtkTreePath *path, int idx, selected; struct dive *dive; - gtk_tree_model_get(model, iter, - DIVE_INDEX, &idx, - -1); + gtk_tree_model_get(model, iter, DIVE_INDEX, &idx, -1); if (idx < 0) { GtkTreeIter child; if (gtk_tree_model_iter_children(model, &child, iter)) @@ -2539,6 +2544,27 @@ static gboolean set_selected(GtkTreeModel *model, GtkTreePath *path, } +static gboolean scroll_to_this(GtkTreeModel *model, GtkTreePath *path, + GtkTreeIter *iter, gpointer data) +{ + int idx; + struct dive *dive; + + gtk_tree_model_get(model, iter, DIVE_INDEX, &idx, -1); + dive = get_dive(idx); + if (dive == current_dive) { + scroll_to_path(path); + return TRUE; + } + return FALSE; +} + +static void scroll_to_current(GtkTreeModel *model) +{ + if (current_dive) + gtk_tree_model_foreach(model, scroll_to_this, current_dive); +} + static void update_column_and_order(int colid) { /* Careful: the index into treecolumns is off by one as we don't have a @@ -2551,6 +2577,7 @@ static void update_column_and_order(int colid) gtk_tree_sortable_set_sort_column_id(GTK_TREE_SORTABLE(dive_list.model), colid, sortorder[colid]); gtk_tree_view_column_set_sort_order(treecolumns[colid - 1], sortorder[colid]); second_call = FALSE; + scroll_to_current(GTK_TREE_MODEL(dive_list.model)); } /* If the sort column is nr (default), show the tree model. @@ -2851,22 +2878,15 @@ static void scroll_to_selected(GtkTreeIter *iter) { GtkTreePath *treepath; treepath = gtk_tree_model_get_path(MODEL(dive_list), iter); - gtk_tree_view_expand_to_path(GTK_TREE_VIEW(dive_list.tree_view), treepath); - gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(dive_list.tree_view), treepath, NULL, FALSE, 0, 0); + scroll_to_path(treepath); gtk_tree_path_free(treepath); } static void go_to_iter(GtkTreeSelection *selection, GtkTreeIter *iter) { - GtkTreePath *path; - - scroll_to_selected(iter); gtk_tree_selection_unselect_all(selection); gtk_tree_selection_select_iter(selection, iter); - - path = gtk_tree_model_get_path(GTK_TREE_MODEL(dive_list.model), iter); - gtk_tree_view_set_cursor(GTK_TREE_VIEW(dive_list.tree_view), path, NULL, FALSE); - gtk_tree_path_free(path); + scroll_to_selected(iter); } void show_and_select_dive(struct dive *dive) -- cgit v1.2.3-70-g09d2