+QModelIndexList NickView::selectedIndexes() const {
+ QModelIndexList indexList = QTreeView::selectedIndexes();
+
+ // make sure the item we clicked on is first
+ if(indexList.contains(currentIndex())) {
+ indexList.removeAll(currentIndex());
+ indexList.prepend(currentIndex());
+ }
+
+ return indexList;
+}
+
+void NickView::showContextMenu(const QPoint &pos ) {
+ Q_UNUSED(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;
+
+ QModelIndex topLevelIdx;
+ for(int i = 0; i < model()->rowCount(rootIndex()); i++) {
+ topLevelIdx = model()->index(i, 0, rootIndex());
+ if(isExpanded(topLevelIdx))
+ continue;
+ else {
+ expand(topLevelIdx);
+ if(i < model()->rowCount(rootIndex()) - 1)
+ QCoreApplication::postEvent(this, new ExpandAllEvent);
+ break;
+ }
+ }
+ event->accept();
+}