diff options
-rw-r--r-- | Libraries/LibGUI/AbstractView.h | 2 | ||||
-rw-r--r-- | Libraries/LibGUI/TableView.cpp | 13 |
2 files changed, 13 insertions, 2 deletions
diff --git a/Libraries/LibGUI/AbstractView.h b/Libraries/LibGUI/AbstractView.h index 70850fdb62..b98724b3aa 100644 --- a/Libraries/LibGUI/AbstractView.h +++ b/Libraries/LibGUI/AbstractView.h @@ -144,6 +144,7 @@ protected: ModelIndex m_edit_index; RefPtr<Widget> m_edit_widget; Gfx::IntRect m_edit_widget_content_rect; + OwnPtr<ModelEditingDelegate> m_editing_delegate; Gfx::IntPoint m_left_mousedown_position; bool m_might_drag { false }; @@ -156,7 +157,6 @@ protected: private: RefPtr<Model> m_model; - OwnPtr<ModelEditingDelegate> m_editing_delegate; ModelSelection m_selection; ModelIndex m_cursor_index; unsigned m_edit_triggers { EditTrigger::DoubleClicked | EditTrigger::EditKeyPressed }; diff --git a/Libraries/LibGUI/TableView.cpp b/Libraries/LibGUI/TableView.cpp index 4309d307bf..d6b12c0f3d 100644 --- a/Libraries/LibGUI/TableView.cpp +++ b/Libraries/LibGUI/TableView.cpp @@ -29,6 +29,7 @@ #include <LibGUI/HeaderView.h> #include <LibGUI/Menu.h> #include <LibGUI/Model.h> +#include <LibGUI/ModelEditingDelegate.h> #include <LibGUI/Painter.h> #include <LibGUI/ScrollBar.h> #include <LibGUI/TableView.h> @@ -171,7 +172,17 @@ void TableView::keydown_event(KeyEvent& event) activate(cursor_index()); return; } - return AbstractTableView::keydown_event(event); + + AbstractTableView::keydown_event(event); + + if (event.is_accepted()) + return; + + if (is_editable() && edit_triggers() & EditTrigger::AnyKeyPressed && !event.text().is_empty()) { + begin_editing(cursor_index()); + if (m_editing_delegate) + m_editing_delegate->set_value(event.text()); + } } void TableView::move_cursor(CursorMovement movement, SelectionUpdate selection_update) |