mirror of
https://github.com/RGBCube/serenity
synced 2025-05-19 23:25:08 +00:00
GTableView: Allow initiating keyboard navigation with no current selection.
This commit is contained in:
parent
7e955f7b60
commit
06bd2fb2d5
1 changed files with 10 additions and 2 deletions
|
@ -198,7 +198,11 @@ void GTableView::keydown_event(GKeyEvent& event)
|
|||
return;
|
||||
}
|
||||
if (event.key() == KeyCode::Key_Up) {
|
||||
GModelIndex new_index(model.selected_index().row() - 1, model.selected_index().column());
|
||||
GModelIndex new_index;
|
||||
if (model.selected_index().is_valid())
|
||||
new_index = { model.selected_index().row() - 1, model.selected_index().column() };
|
||||
else
|
||||
new_index = { 0, 0 };
|
||||
if (model.is_valid(new_index)) {
|
||||
model.set_selected_index(new_index);
|
||||
scroll_into_view(new_index, Orientation::Vertical);
|
||||
|
@ -207,7 +211,11 @@ void GTableView::keydown_event(GKeyEvent& event)
|
|||
return;
|
||||
}
|
||||
if (event.key() == KeyCode::Key_Down) {
|
||||
GModelIndex new_index(model.selected_index().row() + 1, model.selected_index().column());
|
||||
GModelIndex new_index;
|
||||
if (model.selected_index().is_valid())
|
||||
new_index = { model.selected_index().row() + 1, model.selected_index().column() };
|
||||
else
|
||||
new_index = { 0, 0 };
|
||||
if (model.is_valid(new_index)) {
|
||||
model.set_selected_index(new_index);
|
||||
scroll_into_view(new_index, Orientation::Vertical);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue