149 lines
5.5 KiB
Diff
149 lines
5.5 KiB
Diff
|
From 0fe90a931acbef48d8b50b380ee05362ecdf0058 Mon Sep 17 00:00:00 2001
|
||
|
From: Cosimo Cecchi <cosimoc@gnome.org>
|
||
|
Date: Fri, 11 Jun 2010 13:19:29 +0200
|
||
|
Subject: [PATCH 050/249] [file-manager] GSEAL fm-list-view.
|
||
|
|
||
|
---
|
||
|
src/file-manager/fm-list-view.c | 43 ++++++++++++++++++++++++++------------
|
||
|
1 files changed, 29 insertions(+), 14 deletions(-)
|
||
|
|
||
|
diff --git a/src/file-manager/fm-list-view.c b/src/file-manager/fm-list-view.c
|
||
|
index 2ac6fee..5d23d7f 100644
|
||
|
--- a/src/file-manager/fm-list-view.c
|
||
|
+++ b/src/file-manager/fm-list-view.c
|
||
|
@@ -74,6 +74,7 @@ struct FMListViewDetails {
|
||
|
GtkCellRendererPixbuf *pixbuf_cell;
|
||
|
GtkCellRendererText *file_name_cell;
|
||
|
GList *cells;
|
||
|
+ GtkCellEditable *editable_widget;
|
||
|
|
||
|
NautilusZoomLevel zoom_level;
|
||
|
|
||
|
@@ -506,9 +507,9 @@ motion_notify_callback (GtkWidget *widget,
|
||
|
|
||
|
if ((old_hover_path != NULL) != (view->details->hover_path != NULL)) {
|
||
|
if (view->details->hover_path != NULL) {
|
||
|
- gdk_window_set_cursor (widget->window, hand_cursor);
|
||
|
+ gdk_window_set_cursor (gtk_widget_get_window (widget), hand_cursor);
|
||
|
} else {
|
||
|
- gdk_window_set_cursor (widget->window, NULL);
|
||
|
+ gdk_window_set_cursor (gtk_widget_get_window (widget), NULL);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
@@ -578,7 +579,7 @@ enter_notify_callback (GtkWidget *widget,
|
||
|
NULL, NULL, NULL);
|
||
|
|
||
|
if (view->details->hover_path != NULL) {
|
||
|
- gdk_window_set_cursor (widget->window, hand_cursor);
|
||
|
+ gdk_window_set_cursor (gtk_widget_get_window (widget), hand_cursor);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
@@ -1142,6 +1143,8 @@ static void
|
||
|
cell_renderer_editing_canceled (GtkCellRendererText *cell,
|
||
|
FMListView *view)
|
||
|
{
|
||
|
+ view->details->editable_widget = NULL;
|
||
|
+
|
||
|
fm_directory_view_unfreeze_updates (FM_DIRECTORY_VIEW (view));
|
||
|
}
|
||
|
|
||
|
@@ -1155,6 +1158,8 @@ cell_renderer_edited (GtkCellRendererText *cell,
|
||
|
NautilusFile *file;
|
||
|
GtkTreeIter iter;
|
||
|
|
||
|
+ view->details->editable_widget = NULL;
|
||
|
+
|
||
|
/* Don't allow a rename with an empty string. Revert to original
|
||
|
* without notifying the user.
|
||
|
*/
|
||
|
@@ -1798,11 +1803,10 @@ stop_cell_editing (FMListView *list_view)
|
||
|
* changes directories without exiting cell edit mode. It also prevents
|
||
|
* the edited handler from being called on the cleared list model.
|
||
|
*/
|
||
|
-
|
||
|
column = list_view->details->file_name_column;
|
||
|
- if (column != NULL && column->editable_widget != NULL &&
|
||
|
- GTK_IS_CELL_EDITABLE (column->editable_widget)) {
|
||
|
- gtk_cell_editable_editing_done (column->editable_widget);
|
||
|
+ if (column != NULL && list_view->details->editable_widget != NULL &&
|
||
|
+ GTK_IS_CELL_EDITABLE (list_view->details->editable_widget)) {
|
||
|
+ gtk_cell_editable_editing_done (list_view->details->editable_widget);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
@@ -2274,7 +2278,7 @@ create_column_editor (FMListView *view)
|
||
|
box = gtk_vbox_new (FALSE, 12);
|
||
|
gtk_container_set_border_width (GTK_CONTAINER (box), 12);
|
||
|
gtk_widget_show (box);
|
||
|
- gtk_container_add (GTK_CONTAINER (GTK_DIALOG (window)->vbox), box);
|
||
|
+ gtk_container_add (GTK_CONTAINER (gtk_dialog_get_content_area (GTK_DIALOG (window))), box);
|
||
|
|
||
|
label_text = _("Choose the order of information to appear in this folder:");
|
||
|
str = g_strconcat ("<b>", label_text, "</b>", NULL);
|
||
|
@@ -2589,13 +2593,16 @@ fm_list_view_start_renaming_file (FMDirectoryView *view,
|
||
|
GtkTreePath *path;
|
||
|
GtkEntry *entry;
|
||
|
int start_offset, end_offset;
|
||
|
+ gchar *path_str;
|
||
|
+ GdkRectangle cell_area;
|
||
|
+ GdkRectangle background_area;
|
||
|
|
||
|
list_view = FM_LIST_VIEW (view);
|
||
|
|
||
|
/* Select all if we are in renaming mode already */
|
||
|
- if (list_view->details->file_name_column && list_view->details->file_name_column->editable_widget) {
|
||
|
+ if (list_view->details->file_name_column && list_view->details->editable_widget) {
|
||
|
gtk_editable_select_region (
|
||
|
- GTK_EDITABLE (list_view->details->file_name_column->editable_widget),
|
||
|
+ GTK_EDITABLE (list_view->details->editable_widget),
|
||
|
0,
|
||
|
-1);
|
||
|
return;
|
||
|
@@ -2609,13 +2616,21 @@ fm_list_view_start_renaming_file (FMDirectoryView *view,
|
||
|
fm_directory_view_freeze_updates (FM_DIRECTORY_VIEW (view));
|
||
|
|
||
|
path = gtk_tree_model_get_path (GTK_TREE_MODEL (list_view->details->model), &iter);
|
||
|
+ path_str = gtk_tree_path_to_string (path);
|
||
|
+ gtk_tree_view_get_cell_area (list_view->details->tree_view, path,
|
||
|
+ list_view->details->file_name_column, &cell_area);
|
||
|
+ gtk_tree_view_get_background_area (list_view->details->tree_view, path,
|
||
|
+ list_view->details->file_name_column, &background_area);
|
||
|
|
||
|
- /*Make filename-cells editable.*/
|
||
|
+ /* Make filename-cells editable. */
|
||
|
g_object_set (G_OBJECT (list_view->details->file_name_cell),
|
||
|
"editable", TRUE,
|
||
|
NULL);
|
||
|
|
||
|
-
|
||
|
+ list_view->details->editable_widget =
|
||
|
+ gtk_cell_renderer_start_editing (GTK_CELL_RENDERER (list_view->details->file_name_cell),
|
||
|
+ NULL, NULL, path_str, &background_area,
|
||
|
+ &cell_area, 0);
|
||
|
gtk_tree_view_scroll_to_cell (list_view->details->tree_view,
|
||
|
NULL,
|
||
|
list_view->details->file_name_column,
|
||
|
@@ -2625,7 +2640,7 @@ fm_list_view_start_renaming_file (FMDirectoryView *view,
|
||
|
list_view->details->file_name_column,
|
||
|
TRUE);
|
||
|
|
||
|
- entry = GTK_ENTRY (list_view->details->file_name_column->editable_widget);
|
||
|
+ entry = GTK_ENTRY (list_view->details->editable_widget);
|
||
|
|
||
|
/* Free a previously allocated original_name */
|
||
|
g_free (list_view->details->original_name);
|
||
|
@@ -2674,7 +2689,7 @@ fm_list_view_click_policy_changed (FMDirectoryView *directory_view)
|
||
|
|
||
|
tree = view->details->tree_view;
|
||
|
if (gtk_widget_get_realized (GTK_WIDGET (tree))) {
|
||
|
- win = GTK_WIDGET (tree)->window;
|
||
|
+ win = gtk_widget_get_window (GTK_WIDGET (tree));
|
||
|
gdk_window_set_cursor (win, NULL);
|
||
|
|
||
|
display = gtk_widget_get_display (GTK_WIDGET (view));
|
||
|
--
|
||
|
1.7.2
|
||
|
|