From e4ba6dbc3f1e76890b22773807ea37fe8fa2b1bc Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 10 Apr 2024 22:34:10 +0200 Subject: Adding upstream version 4.2.2. Signed-off-by: Daniel Baumann --- ui/qt/tabnav_tree_widget.cpp | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 ui/qt/tabnav_tree_widget.cpp (limited to 'ui/qt/tabnav_tree_widget.cpp') diff --git a/ui/qt/tabnav_tree_widget.cpp b/ui/qt/tabnav_tree_widget.cpp new file mode 100644 index 00000000..34c31210 --- /dev/null +++ b/ui/qt/tabnav_tree_widget.cpp @@ -0,0 +1,44 @@ +/* tabnav_tree_widget.cpp + * Tree widget with saner tab navigation properties. + * + * Copyright 2017 Peter Wu + * + * Wireshark - Network traffic analyzer + * By Gerald Combs + * Copyright 1998 Gerald Combs + * + * SPDX-License-Identifier: GPL-2.0-or-later + */ + +#include "tabnav_tree_widget.h" + +// Copy of TabnavTreeView, modified to use QTreeWidget instead of QTreeView. + +TabnavTreeWidget::TabnavTreeWidget(QWidget *parent) : QTreeWidget(parent) +{ +} + +// Note: if a QTableWidget is used, then this is not needed anymore since Tab +// works as "expected" (move to next cell instead of row). +// Note 2: this does not help with fields with no widget (like filename). +QModelIndex TabnavTreeWidget::moveCursor(CursorAction cursorAction, Qt::KeyboardModifiers modifiers) +{ + QModelIndex current = currentIndex(); + // If an item is currently selected, interpret Next/Previous. Otherwise, + // fallback to the default selection (e.g. first row for Next). + if (current.isValid()) { + if (cursorAction == MoveNext) { + if (current.column() < model()->columnCount()) { + return current.sibling(current.row(), current.column() + 1); + } + return current; + } else if (cursorAction == MovePrevious) { + if (current.column() > 0) { + return current.sibling(current.row(), current.column() - 1); + } + return current; + } + } + + return QTreeView::moveCursor(cursorAction, modifiers); +} -- cgit v1.2.3