diff options
-rw-r--r-- | mail/ChangeLog | 10 | ||||
-rw-r--r-- | mail/em-folder-tree.c | 68 |
2 files changed, 78 insertions, 0 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index bbb3bb1fcd..823be6a2bd 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,3 +1,13 @@ +2004-04-30 Jeffrey Stedfast <fejj@ximian.com> + + * em-folder-tree.c (tree_drag_motion): If the row the cursor is + hovering over has children and is not expanded already, setup a + timer to auto-expand it if the user hovers there long enough. + (tree_autoexpand): Callback to expand the row. + (tree_drag_leave): Disconnect the timer. + (tree_drag_drop): Same. + (em_folder_tree_destroy): Same. + 2004-04-30 Enver ALTIN <enver.altin@frontsite.com.tr> * evolution-mail.schemas.in.in: Fixed a type-o. diff --git a/mail/em-folder-tree.c b/mail/em-folder-tree.c index 56d457a725..714329327e 100644 --- a/mail/em-folder-tree.c +++ b/mail/em-folder-tree.c @@ -88,6 +88,8 @@ struct _EMFolderTreePrivate { guint save_state_id; guint autoscroll_id; + guint autoexpand_id; + GtkTreeRowReference *autoexpand_row; guint loading_row_id; guint loaded_row_id; @@ -400,6 +402,14 @@ em_folder_tree_destroy (GtkObject *obj) priv->autoscroll_id = 0; } + if (priv->autoexpand_id != 0) { + gtk_tree_row_reference_free (priv->autoexpand_row); + priv->autoexpand_row = NULL; + + g_source_remove (priv->autoexpand_id); + priv->autoexpand_id = 0; + } + priv->treeview = NULL; priv->model = NULL; @@ -1286,6 +1296,14 @@ tree_drag_drop (GtkWidget *widget, GdkDragContext *context, int x, int y, guint priv->autoscroll_id = 0; } + if (priv->autoexpand_id != 0) { + gtk_tree_row_reference_free (priv->autoexpand_row); + priv->autoexpand_row = NULL; + + g_source_remove (priv->autoexpand_id); + priv->autoexpand_id = 0; + } + if (!gtk_tree_view_get_path_at_pos (priv->treeview, x, y, &path, &column, &cell_x, &cell_y)) return FALSE; @@ -1320,6 +1338,14 @@ tree_drag_leave (GtkWidget *widget, GdkDragContext *context, guint time, EMFolde priv->autoscroll_id = 0; } + if (priv->autoexpand_id != 0) { + gtk_tree_row_reference_free (priv->autoexpand_row); + priv->autoexpand_row = NULL; + + g_source_remove (priv->autoexpand_id); + priv->autoexpand_id = 0; + } + gtk_tree_view_set_drag_dest_row(emft->priv->treeview, NULL, GTK_TREE_VIEW_DROP_BEFORE); } @@ -1362,12 +1388,26 @@ tree_autoscroll (EMFolderTree *emft) } static gboolean +tree_autoexpand (EMFolderTree *emft) +{ + struct _EMFolderTreePrivate *priv = emft->priv; + GtkTreePath *path; + + path = gtk_tree_row_reference_get_path (priv->autoexpand_row); + gtk_tree_view_expand_row (priv->treeview, path, FALSE); + gtk_tree_path_free (path); + + return TRUE; +} + +static gboolean tree_drag_motion (GtkWidget *widget, GdkDragContext *context, int x, int y, guint time, EMFolderTree *emft) { struct _EMFolderTreePrivate *priv = emft->priv; GtkTreeViewDropPosition pos; GdkDragAction action = 0; GtkTreePath *path; + GtkTreeIter iter; GdkAtom target; int i; @@ -1377,6 +1417,34 @@ tree_drag_motion (GtkWidget *widget, GdkDragContext *context, int x, int y, guin if (priv->autoscroll_id == 0) priv->autoscroll_id = g_timeout_add (150, (GSourceFunc) tree_autoscroll, emft); + gtk_tree_model_get_iter (priv->model, &iter, path); + + if (gtk_tree_model_iter_has_child (priv->model, &iter) && !gtk_tree_view_row_expanded (priv->treeview, path)) { + if (priv->autoexpand_id != 0) { + GtkTreePath *autoexpand_path; + + autoexpand_path = gtk_tree_row_reference_get_path (priv->autoexpand_row); + if (gtk_tree_path_compare (autoexpand_path, path) != 0) { + /* row changed, restart timer */ + gtk_tree_row_reference_free (priv->autoexpand_row); + priv->autoexpand_row = gtk_tree_row_reference_new (priv->model, path); + g_source_remove (priv->autoexpand_id); + priv->autoexpand_id = g_timeout_add (600, (GSourceFunc) tree_autoexpand, emft); + } + + gtk_tree_path_free (autoexpand_path); + } else { + priv->autoexpand_id = g_timeout_add (600, (GSourceFunc) tree_autoexpand, emft); + priv->autoexpand_row = gtk_tree_row_reference_new (priv->model, path); + } + } else if (priv->autoexpand_id != 0) { + gtk_tree_row_reference_free (priv->autoexpand_row); + priv->autoexpand_row = NULL; + + g_source_remove (priv->autoexpand_id); + priv->autoexpand_id = 0; + } + target = emft_drop_target(emft, context, path); if (target != GDK_NONE) { for (i=0; i<NUM_DROP_TYPES; i++) { |