mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-24 10:22:05 -05:00
LibGUI: Implement move_cursor() in ColumnsView
This commit is contained in:
parent
386c7201d8
commit
37df36dbed
2 changed files with 53 additions and 53 deletions
|
@ -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;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -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;
|
||||
|
|
Loading…
Add table
Reference in a new issue