- QAction *whoisAction = nickContextMenu.addAction(tr("WHOIS"));
- QAction *result = nickContextMenu.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;
+
+ IrcUser *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());
+}
+
+void NickView::customEvent(QEvent *event) {
+ // THIS IS A REPLACEMENT FOR expandAll()
+ /* WARNING: do not call expandAll()!
+ * it fucks up big time in combination with sorting and changing the rootIndex
+ * the following sequence of commands leads to unexpected behavior when inserting new items
+ * setSortingEnabled(true);
+ * setModel();
+ * expandAll();
+ * setRootIndex();
+ */
+ if(event->type() != QEvent::User)
+ return;
+
+ if(!model())
+ return;