mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-24 18:32:28 -05:00
LibGUI: Table View navigating with arrow keys continuity after update
When a user is navigating a table view with arrow keys and a row is outside of the current view, then scroll_into_view is called, and the position of the rectangle passed to this should take into account the column headers. This can be seen making more pleasant the navigation in the System Monitor in the Processes view, for example.
This commit is contained in:
parent
923979ca93
commit
938380e88b
1 changed files with 4 additions and 12 deletions
|
@ -190,18 +190,6 @@ void SortingProxyModel::sort_mapping(Mapping& mapping, int column, SortOrder sor
|
||||||
|
|
||||||
// FIXME: I really feel like this should be done at the view layer somehow.
|
// FIXME: I really feel like this should be done at the view layer somehow.
|
||||||
for_each_view([&](AbstractView& view) {
|
for_each_view([&](AbstractView& view) {
|
||||||
// Update the view's cursor.
|
|
||||||
auto cursor = view.cursor_index();
|
|
||||||
if (cursor.is_valid() && cursor.parent() == mapping.source_parent) {
|
|
||||||
for (size_t i = 0; i < mapping.source_rows.size(); ++i) {
|
|
||||||
if (mapping.source_rows[i] == view.cursor_index().row()) {
|
|
||||||
auto new_source_index = this->index(i, view.cursor_index().column(), mapping.source_parent);
|
|
||||||
view.set_cursor(new_source_index, AbstractView::SelectionUpdate::None, false);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update the view's selection.
|
// Update the view's selection.
|
||||||
view.selection().change_from_model({}, [&](ModelSelection& selection) {
|
view.selection().change_from_model({}, [&](ModelSelection& selection) {
|
||||||
Vector<ModelIndex> selected_indices_in_source;
|
Vector<ModelIndex> selected_indices_in_source;
|
||||||
|
@ -222,6 +210,10 @@ void SortingProxyModel::sort_mapping(Mapping& mapping, int column, SortOrder sor
|
||||||
if (mapping.source_rows[i] == index.row()) {
|
if (mapping.source_rows[i] == index.row()) {
|
||||||
auto new_source_index = this->index(i, index.column(), mapping.source_parent);
|
auto new_source_index = this->index(i, index.column(), mapping.source_parent);
|
||||||
selection.add(new_source_index);
|
selection.add(new_source_index);
|
||||||
|
// Update the view's cursor.
|
||||||
|
auto cursor = view.cursor_index();
|
||||||
|
if (cursor.is_valid() && cursor.parent() == mapping.source_parent)
|
||||||
|
view.set_cursor(new_source_index, AbstractView::SelectionUpdate::None, false);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue