LibGUI: Implement move_cursor() in ColumnsView

This commit is contained in:
Andreas Kling 2020-09-01 16:26:32 +02:00
parent 386c7201d8
commit 37df36dbed
2 changed files with 53 additions and 53 deletions

View file

@ -164,7 +164,7 @@ void ColumnsView::paint_event(PaintEvent& event)
}
}
void ColumnsView::push_column(ModelIndex& parent_index)
void ColumnsView::push_column(const ModelIndex& parent_index)
{
ASSERT(model());
@ -272,11 +272,55 @@ void ColumnsView::did_update_model(unsigned flags)
update();
}
void ColumnsView::keydown_event(KeyEvent& event)
void ColumnsView::move_cursor(CursorMovement movement, SelectionUpdate selection_update)
{
if (!model())
return;
auto& model = *this->model();
if (!cursor_index().is_valid()) {
set_cursor(model.index(0, m_model_column, {}), SelectionUpdate::Set);
return;
}
ModelIndex new_index;
auto cursor_parent = model.parent_index(cursor_index());
switch (movement) {
case CursorMovement::Up: {
int row = cursor_index().row() > 0 ? cursor_index().row() - 1 : 0;
new_index = model.index(row, cursor_index().column(), cursor_parent);
break;
}
case CursorMovement::Down: {
int row = cursor_index().row() + 1;
new_index = model.index(row, cursor_index().column(), cursor_parent);
break;
}
case CursorMovement::Left:
new_index = cursor_parent;
break;
case CursorMovement::Right:
new_index = model.index(0, m_model_column, cursor_index());
if (model.is_valid(new_index)) {
if (model.is_valid(cursor_index()))
push_column(cursor_index());
update();
break;
}
default:
break;
}
if (new_index.is_valid())
set_cursor(new_index, selection_update);
}
void ColumnsView::keydown_event(KeyEvent& event)
{
if (!model())
return;
SelectionUpdate selection_update = SelectionUpdate::Set;
if (event.key() == KeyCode::Key_Return) {
activate_selected();
@ -284,68 +328,22 @@ void ColumnsView::keydown_event(KeyEvent& event)
}
if (event.key() == KeyCode::Key_Up) {
ModelIndex new_index;
if (!selection().is_empty()) {
auto old_index = selection().first();
auto parent_index = model.parent_index(old_index);
int row = old_index.row() > 0 ? old_index.row() - 1 : 0;
new_index = model.index(row, old_index.column(), parent_index);
} else {
new_index = model.index(0, m_model_column, {});
}
if (model.is_valid(new_index)) {
selection().set(new_index);
update();
}
move_cursor(CursorMovement::Up, selection_update);
return;
}
if (event.key() == KeyCode::Key_Down) {
ModelIndex new_index;
if (!selection().is_empty()) {
auto old_index = selection().first();
auto parent_index = model.parent_index(old_index);
int row = old_index.row() + 1;
new_index = model.index(row, old_index.column(), parent_index);
} else {
new_index = model.index(0, m_model_column, {});
}
if (model.is_valid(new_index)) {
selection().set(new_index);
update();
}
move_cursor(CursorMovement::Down, selection_update);
return;
}
if (event.key() == KeyCode::Key_Left) {
ModelIndex new_index;
if (!selection().is_empty()) {
auto old_index = selection().first();
new_index = model.parent_index(old_index);
} else {
new_index = model.index(0, m_model_column, {});
}
if (model.is_valid(new_index)) {
selection().set(new_index);
update();
}
move_cursor(CursorMovement::Left, selection_update);
return;
}
if (event.key() == KeyCode::Key_Right) {
ModelIndex old_index, new_index;
if (!selection().is_empty()) {
old_index = selection().first();
new_index = model.index(0, m_model_column, old_index);
} else {
new_index = model.index(0, m_model_column, {});
}
if (model.is_valid(new_index)) {
selection().set(new_index);
if (model.is_valid(old_index))
push_column(old_index);
update();
}
move_cursor(CursorMovement::Right, selection_update);
return;
}
}

View file

@ -42,7 +42,7 @@ public:
private:
ColumnsView();
virtual ~ColumnsView() override;
void push_column(ModelIndex& parent_index);
void push_column(const ModelIndex& parent_index);
void update_column_sizes();
int item_height() const { return 16; }
@ -55,6 +55,8 @@ private:
virtual void mousedown_event(MouseEvent& event) override;
virtual void keydown_event(KeyEvent& event) override;
void move_cursor(CursorMovement, SelectionUpdate) override;
virtual void select_all() override;
struct Column {
ModelIndex parent_index;