libreport/0006-gui-support-Enter-2Click-in-Preferences-list.patch
2014-07-23 09:40:14 +02:00

92 lines
3.1 KiB
Diff

From 7eccd835673ebea736a756537c8ca7c1b9ab711a Mon Sep 17 00:00:00 2001
From: Jakub Filak <jfilak@redhat.com>
Date: Fri, 18 Jul 2014 11:11:57 +0200
Subject: [PATCH 6/8] gui: support Enter & 2Click in Preferences list
Related to rhbz#1067123
Signed-off-by: Jakub Filak <jfilak@redhat.com>
---
src/gtk-helpers/config_dialog.c | 43 +++++++++++++++++++++++++++++++++++++----
1 file changed, 39 insertions(+), 4 deletions(-)
diff --git a/src/gtk-helpers/config_dialog.c b/src/gtk-helpers/config_dialog.c
index c99ea85..2a723cc 100644
--- a/src/gtk-helpers/config_dialog.c
+++ b/src/gtk-helpers/config_dialog.c
@@ -18,6 +18,7 @@
*/
#include <gtk/gtk.h>
+#include <gdk/gdk.h>
#include "internal_libreport_gtk.h"
enum
@@ -206,6 +207,40 @@ static gboolean config_filter_func(GtkTreeModel *model,
return visible;
}
+static void open_config_for_selected_row(GtkTreeView *tv)
+{
+ config_dialog_t *cdialog = (config_dialog_t *)get_column_value_from_row(tv, CONFIG_DIALOG, TYPE_POINTER);
+ const char *name = (const char *)get_column_value_from_row(tv, COLUMN_NAME, TYPE_STR);
+
+ cdialog_run(cdialog, name);
+}
+
+static gboolean on_key_press_event_cb(GtkWidget *btn, GdkEvent *event, gpointer user_data)
+{
+ GdkEventKey *ek = (GdkEventKey *)event;
+
+ if (ek->keyval == GDK_KEY_Return)
+ {
+ GtkTreeView *tv = (GtkTreeView *)user_data;
+ open_config_for_selected_row(tv);
+ }
+
+ return FALSE;
+}
+
+static gboolean on_button_press_event_cb(GtkWidget *btn, GdkEvent *event, gpointer user_data)
+{
+ GdkEventButton *eb = (GdkEventButton *)event;
+
+ if (eb->type == GDK_2BUTTON_PRESS)
+ {
+ GtkTreeView *tv = (GtkTreeView *)user_data;
+ open_config_for_selected_row(tv);
+ }
+
+ return FALSE;
+}
+
GtkWidget *create_config_tab_content(const char *column_label,
GtkListStore *store)
{
@@ -216,6 +251,9 @@ GtkWidget *create_config_tab_content(const char *column_label,
GTK_POLICY_AUTOMATIC);
/* workflow list treeview */
GtkWidget *tv = gtk_tree_view_new();
+ g_signal_connect(tv, "key-press-event", G_CALLBACK(on_key_press_event_cb), tv);
+ g_signal_connect(tv, "button-press-event", G_CALLBACK(on_button_press_event_cb), tv);
+
/* column with workflow name and description */
GtkCellRenderer *renderer;
GtkTreeViewColumn *column;
@@ -272,11 +310,8 @@ static void on_configure_cb(GtkWidget *btn, gpointer user_data)
GtkWidget *vbox = gtk_notebook_get_nth_page(nb, current_page_n);
GList *children = gtk_container_get_children(GTK_CONTAINER(vbox));
GtkScrolledWindow *sw = (GtkScrolledWindow *)children->data;
- GtkTreeView *tv = (GtkTreeView *)gtk_bin_get_child(GTK_BIN(sw));
- config_dialog_t *cdialog = (config_dialog_t *)get_column_value_from_row(tv, CONFIG_DIALOG, TYPE_POINTER);
- const char *name = (const char *)get_column_value_from_row(tv, COLUMN_NAME, TYPE_STR);
- cdialog_run(cdialog, name);
+ open_config_for_selected_row((GtkTreeView *)gtk_bin_get_child(GTK_BIN(sw)));
}
static void on_close_cb(GtkWidget *btn, gpointer config_list_w)
--
1.9.3