From 03834b258039f35962327530bc1e892b2d3ee8ec Mon Sep 17 00:00:00 2001 From: Harry Lu Date: Wed, 19 Jan 2005 09:06:52 +0000 Subject: Fix for 46359, enable "Alt+Down Arrow" to show the popup for 2005-01-19 Harry Lu Fix for 46359, enable "Alt+Down Arrow" to show the popup for e-combo-cell-editable.c. * e-combo-cell-editable.c: (show_popup): rewrite it to a more generic function. (button_clicked_cb): call the new show_popup function. (entry_key_press_event_cb): show popup if "Alt+Down Arrow". (ecce_grab_focus): new function. (ecce_class_init): add grab_focus handler so that the entry can get focus. svn path=/trunk/; revision=28446 --- widgets/misc/ChangeLog | 13 ++++++++++++ widgets/misc/e-combo-cell-editable.c | 41 +++++++++++++++++++++++++----------- 2 files changed, 42 insertions(+), 12 deletions(-) (limited to 'widgets/misc') diff --git a/widgets/misc/ChangeLog b/widgets/misc/ChangeLog index e26b944509..8c30d8ec92 100644 --- a/widgets/misc/ChangeLog +++ b/widgets/misc/ChangeLog @@ -1,3 +1,16 @@ +2005-01-19 Harry Lu + + Fix for 46359, enable "Alt+Down Arrow" to show the popup for + e-combo-cell-editable.c. + + * e-combo-cell-editable.c: (show_popup): rewrite it to a more + generic function. + (button_clicked_cb): call the new show_popup function. + (entry_key_press_event_cb): show popup if "Alt+Down Arrow". + (ecce_grab_focus): new function. + (ecce_class_init): add grab_focus handler so that the entry + can get focus. + 2005-01-17 Harry Lu Fix for 62831. diff --git a/widgets/misc/e-combo-cell-editable.c b/widgets/misc/e-combo-cell-editable.c index f8de7c9ebc..5a39974f17 100644 --- a/widgets/misc/e-combo-cell-editable.c +++ b/widgets/misc/e-combo-cell-editable.c @@ -225,9 +225,11 @@ position_popup (EComboCellEditable *ecce, gint x, gint y, gint offset) } static void -show_popup (EComboCellEditable *ecce, gint x, gint y, gint offset) +show_popup (EComboCellEditable *ecce) { gint row; + GtkAllocation alloc; + gint x, y; if (!ecce->priv->list) return; @@ -236,7 +238,11 @@ show_popup (EComboCellEditable *ecce, gint x, gint y, gint offset) row = lookup_row (ecce->priv->list, e_combo_cell_editable_get_text (ecce)); set_cursor (ecce->priv->tree_view, row); - position_popup (ecce, x, y, offset); + gtk_editable_select_region (GTK_EDITABLE (ecce->priv->entry), 0, 0); + gdk_window_get_origin (GTK_WIDGET (ecce)->window, &x, &y); + alloc = GTK_WIDGET (ecce)->allocation; + + position_popup (ecce, x, y + alloc.height, alloc.height); gtk_grab_add (GTK_WIDGET (ecce->priv->popup)); gtk_widget_grab_focus (GTK_WIDGET (ecce->priv->tree_view)); @@ -246,21 +252,12 @@ show_popup (EComboCellEditable *ecce, gint x, gint y, gint offset) static void button_clicked_cb (GtkButton *btn, EComboCellEditable *ecce) { - GtkAllocation alloc; - gint x, y; - if (ecce->priv->popup) { kill_popup (ecce); return; } - - gtk_editable_select_region (GTK_EDITABLE (ecce->priv->entry), 0, 0); - - gdk_window_get_origin (GTK_WIDGET (ecce)->window, &x, &y); - - alloc = GTK_WIDGET (ecce)->allocation; - show_popup (ecce, x, y + alloc.height, alloc.height); + show_popup (ecce); } static void @@ -280,6 +277,14 @@ entry_key_press_event_cb (GtkEntry *entry, GdkEventKey *key_event, EComboCellEdi return TRUE; } + if (key_event->state & GDK_MOD1_MASK + && key_event->keyval == GDK_Down) { + if (!ecce->priv->popup) + show_popup (ecce); + + return TRUE; + } + return FALSE; } @@ -335,11 +340,23 @@ ecce_init (EComboCellEditable *ecce) gtk_box_pack_start (GTK_BOX (box), btn, FALSE, TRUE, 0); } +static void +ecce_grab_focus (GtkWidget *widget) +{ + EComboCellEditable *ecce = E_COMBO_CELL_EDITABLE (widget); + + gtk_widget_grab_focus (GTK_WIDGET (ecce->priv->entry)); +} + static void ecce_class_init (GObjectClass *klass) { + GtkWidgetClass *widget_class = (GtkWidgetClass *)klass; + klass->finalize = ecce_finalize; + widget_class->grab_focus = ecce_grab_focus; + parent_class = GTK_EVENT_BOX_CLASS (g_type_class_peek_parent (klass)); } -- cgit v1.2.3