summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Libraries/LibGUI/AbstractView.h2
-rw-r--r--Libraries/LibGUI/TableView.cpp13
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)