diff options
Diffstat (limited to 'addressbook/gui/widgets/e-minicard.c')
-rw-r--r-- | addressbook/gui/widgets/e-minicard.c | 115 |
1 files changed, 90 insertions, 25 deletions
diff --git a/addressbook/gui/widgets/e-minicard.c b/addressbook/gui/widgets/e-minicard.c index c587d9764e..36038eef48 100644 --- a/addressbook/gui/widgets/e-minicard.c +++ b/addressbook/gui/widgets/e-minicard.c @@ -519,6 +519,44 @@ editor_closed_cb (GtkObject *editor, gpointer data) } static gboolean +activiate_editor(GnomeCanvasItem *item) +{ + EMinicard *e_minicard; + e_minicard = E_MINICARD (item); + + if (e_minicard->editor) { + eab_editor_raise (e_minicard->editor); + } + else { + EBook *book = NULL; + if (E_IS_MINICARD_VIEW(item->parent)) { + g_object_get(item->parent, "book", &book, NULL); + } + + if (book != NULL) { + if (e_contact_get (e_minicard->contact, E_CONTACT_IS_LIST)) { + EContactListEditor *editor = eab_show_contact_list_editor (book, e_minicard->contact, + FALSE, e_minicard->editable); + e_minicard->editor = G_OBJECT (editor); + } + else { + EContactEditor *editor = eab_show_contact_editor (book, e_minicard->contact, + FALSE, e_minicard->editable); + e_minicard->editor = G_OBJECT (editor); + } + + g_object_ref (e_minicard->editor); + g_signal_connect (e_minicard->editor, "editor_closed", + G_CALLBACK (editor_closed_cb), e_minicard); + + g_object_unref (book); + } + } + + return TRUE; +} + +static gboolean e_minicard_event (GnomeCanvasItem *item, GdkEvent *event) { EMinicard *e_minicard; @@ -601,36 +639,63 @@ e_minicard_event (GnomeCanvasItem *item, GdkEvent *event) break; case GDK_2BUTTON_PRESS: if (event->button.button == 1 && E_IS_MINICARD_VIEW(item->parent)) { - if (e_minicard->editor) { - eab_editor_raise (e_minicard->editor); - } else { - EBook *book = NULL; - if (E_IS_MINICARD_VIEW(item->parent)) { - g_object_get(item->parent, - "book", &book, - NULL); - } + return activiate_editor(item); + } + break; + case GDK_KEY_PRESS: + if (event->key.keyval == GDK_Tab || + event->key.keyval == GDK_KP_Tab || + event->key.keyval == GDK_ISO_Left_Tab) { - if (book != NULL) { - if (e_contact_get (e_minicard->contact, E_CONTACT_IS_LIST)) { - EContactListEditor *editor = eab_show_contact_list_editor (book, e_minicard->contact, - FALSE, e_minicard->editable); - e_minicard->editor = EAB_EDITOR (editor); - } - else { - EContactEditor *editor = eab_show_contact_editor (book, e_minicard->contact, - FALSE, e_minicard->editable); - e_minicard->editor = EAB_EDITOR (editor); - } - g_object_ref (e_minicard->editor); + EMinicardView *view = E_MINICARD_VIEW(item->parent); + EReflow *reflow = E_REFLOW(view); - g_signal_connect (e_minicard->editor, "editor_closed", - G_CALLBACK (editor_closed_cb), e_minicard); + if (reflow == NULL) { + return FALSE; + } - g_object_unref (book); + if (event->key.state & GDK_SHIFT_MASK) { + if (event->key.state & GDK_CONTROL_MASK) { + return FALSE; + } + else { + int row_count = e_selection_model_row_count(reflow->selection); + int model_index = e_selection_model_cursor_row (reflow->selection); + int view_index = e_sorter_model_to_sorted (reflow->selection->sorter, model_index); + + if (view_index == 0) + view_index = row_count-1; + else + view_index--; + + model_index = e_sorter_sorted_to_model (E_SORTER (reflow->sorter), view_index); + e_canvas_item_grab_focus(reflow->items[model_index], FALSE); + return TRUE; + } + } + else { + if (event->key.state & GDK_CONTROL_MASK) { + return FALSE; + } + else { + int row_count = e_selection_model_row_count(reflow->selection); + int model_index = e_selection_model_cursor_row (reflow->selection); + int view_index = e_sorter_model_to_sorted (reflow->selection->sorter, model_index); + + if (view_index == row_count-1) + view_index = 0; + else + view_index++; + + model_index = e_sorter_sorted_to_model (E_SORTER (reflow->sorter), view_index); + e_canvas_item_grab_focus(reflow->items[model_index], FALSE); + return TRUE; } } - return TRUE; + } + else if (event->key.keyval == GDK_Return || + event->key.keyval == GDK_KP_Enter) { + return activiate_editor(item); } break; default: |