/***************************************************************************
- * Copyright (C) 2005-09 by the Quassel Project *
+ * Copyright (C) 2005-2020 by the Quassel Project *
* devel@quassel-irc.org *
* *
* This program is free software; you can redistribute it and/or modify *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
- * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
***************************************************************************/
#include "nickview.h"
#include <QApplication>
-#include <QHeaderView>
-#include <QScrollBar>
#include <QDebug>
+#include <QHeaderView>
#include <QMenu>
+#include <QScrollBar>
#include "buffermodel.h"
#include "client.h"
#include "contextmenuactionprovider.h"
#include "graphicalui.h"
+#include "networkmodel.h"
#include "nickview.h"
#include "nickviewfilter.h"
-#include "networkmodel.h"
#include "types.h"
-NickView::NickView(QWidget *parent)
- : QTreeView(parent)
+NickView::NickView(QWidget* parent)
+ : TreeViewTouch(parent)
{
- setIndentation(10);
- header()->hide();
- setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
- setSortingEnabled(true);
- sortByColumn(0, Qt::AscendingOrder);
+ setIndentation(10);
+ header()->hide();
+ setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
+ setSortingEnabled(true);
+ sortByColumn(0, Qt::AscendingOrder);
- setContextMenuPolicy(Qt::CustomContextMenu);
- setSelectionMode(QAbstractItemView::ExtendedSelection);
+ setContextMenuPolicy(Qt::CustomContextMenu);
+ setSelectionMode(QAbstractItemView::ExtendedSelection);
-// // breaks with Qt 4.8
-// if(QString("4.8.0") > qVersion()) // FIXME breaks with Qt versions >= 4.10!
- setAnimated(true);
+ setAnimated(true);
- connect(this, SIGNAL(customContextMenuRequested(const QPoint&)), SLOT(showContextMenu(const QPoint&)));
+ connect(this, &QWidget::customContextMenuRequested, this, &NickView::showContextMenu);
-#if defined Q_WS_QWS || defined Q_WS_X11
- connect(this, SIGNAL(doubleClicked(QModelIndex)), SLOT(startQuery(QModelIndex)));
+#if defined Q_OS_MACOS || defined Q_OS_WIN
+ // afaik this is better on Mac and Windows
+ connect(this, &QAbstractItemView::activated, this, &NickView::startQuery);
#else
- // afaik this is better on Mac and Windows
- connect(this, SIGNAL(activated(QModelIndex)), SLOT(startQuery(QModelIndex)));
+ connect(this, &QAbstractItemView::doubleClicked, this, &NickView::startQuery);
#endif
}
-void NickView::init() {
- if(!model())
- return;
+void NickView::init()
+{
+ if (!model())
+ return;
- for(int i = 1; i < model()->columnCount(); i++)
- setColumnHidden(i, true);
+ for (int i = 1; i < model()->columnCount(); i++)
+ setColumnHidden(i, true);
- connect(selectionModel(), SIGNAL(currentChanged(QModelIndex, QModelIndex)), SIGNAL(selectionUpdated()));
- connect(selectionModel(), SIGNAL(selectionChanged(QItemSelection, QItemSelection)), SIGNAL(selectionUpdated()));
+ connect(selectionModel(), &QItemSelectionModel::currentChanged, this, &NickView::selectionUpdated);
+ connect(selectionModel(), &QItemSelectionModel::selectionChanged, this, &NickView::selectionUpdated);
}
-void NickView::setModel(QAbstractItemModel *model_) {
- if(model())
- disconnect(model(), 0, this, 0);
+void NickView::setModel(QAbstractItemModel* model_)
+{
+ if (model())
+ disconnect(model(), nullptr, this, nullptr);
- QTreeView::setModel(model_);
- init();
+ TreeViewTouch::setModel(model_);
+ init();
}
-void NickView::rowsInserted(const QModelIndex &parent, int start, int end) {
- QTreeView::rowsInserted(parent, start, end);
- if(model()->data(parent, NetworkModel::ItemTypeRole) == NetworkModel::UserCategoryItemType && !isExpanded(parent)) {
- unanimatedExpandAll();
- }
+void NickView::rowsInserted(const QModelIndex& parent, int start, int end)
+{
+ TreeViewTouch::rowsInserted(parent, start, end);
+ if (model()->data(parent, NetworkModel::ItemTypeRole) == NetworkModel::UserCategoryItemType && !isExpanded(parent)) {
+ unanimatedExpandAll();
+ }
}
-void NickView::setRootIndex(const QModelIndex &index) {
- QAbstractItemView::setRootIndex(index);
- if(index.isValid())
- unanimatedExpandAll();
+void NickView::setRootIndex(const QModelIndex& index)
+{
+ QAbstractItemView::setRootIndex(index);
+ if (index.isValid())
+ unanimatedExpandAll();
}
-QModelIndexList NickView::selectedIndexes() const {
- QModelIndexList indexList = QTreeView::selectedIndexes();
+QModelIndexList NickView::selectedIndexes() const
+{
+ QModelIndexList indexList = TreeViewTouch::selectedIndexes();
- // make sure the item we clicked on is first
- if(indexList.contains(currentIndex())) {
- indexList.removeAll(currentIndex());
- indexList.prepend(currentIndex());
- }
+ // make sure the item we clicked on is first
+ if (indexList.contains(currentIndex())) {
+ indexList.removeAll(currentIndex());
+ indexList.prepend(currentIndex());
+ }
- return indexList;
+ return indexList;
}
-void NickView::unanimatedExpandAll() {
- // since of Qt Version 4.8.0 the default expandAll will not properly work if
- // animations are enabled. Therefore we perform an unanimated expand when a
- // model is set or a toplevel node is inserted.
- bool wasAnimated = isAnimated();
- setAnimated(false);
- expandAll();
- setAnimated(wasAnimated);
+void NickView::unanimatedExpandAll()
+{
+ // since of Qt Version 4.8.0 the default expandAll will not properly work if
+ // animations are enabled. Therefore we perform an unanimated expand when a
+ // model is set or a toplevel node is inserted.
+ bool wasAnimated = isAnimated();
+ setAnimated(false);
+ expandAll();
+ setAnimated(wasAnimated);
}
+void NickView::showContextMenu(const QPoint& pos)
+{
+ Q_UNUSED(pos);
-void NickView::showContextMenu(const QPoint &pos ) {
- Q_UNUSED(pos);
-
- QMenu contextMenu(this);
- GraphicalUi::contextMenuActionProvider()->addActions(&contextMenu, selectedIndexes());
- contextMenu.exec(QCursor::pos());
+ QMenu contextMenu(this);
+ GraphicalUi::contextMenuActionProvider()->addActions(&contextMenu, selectedIndexes());
+ contextMenu.exec(QCursor::pos());
}
-void NickView::startQuery(const QModelIndex &index) {
- if(index.data(NetworkModel::ItemTypeRole) != NetworkModel::IrcUserItemType)
- return;
+void NickView::startQuery(const QModelIndex& index)
+{
+ if (index.data(NetworkModel::ItemTypeRole) != NetworkModel::IrcUserItemType)
+ return;
- IrcUser *ircUser = qobject_cast<IrcUser *>(index.data(NetworkModel::IrcUserRole).value<QObject *>());
- NetworkId networkId = index.data(NetworkModel::NetworkIdRole).value<NetworkId>();
- if(!ircUser || !networkId.isValid())
- return;
+ auto* ircUser = qobject_cast<IrcUser*>(index.data(NetworkModel::IrcUserRole).value<QObject*>());
+ NetworkId networkId = index.data(NetworkModel::NetworkIdRole).value<NetworkId>();
+ if (!ircUser || !networkId.isValid())
+ return;
- Client::bufferModel()->switchToOrStartQuery(networkId, ircUser->nick());
+ Client::bufferModel()->switchToOrStartQuery(networkId, ircUser->nick());
}