- BufferId bufId = Client::networkModel()->bufferId(networkId, ircUser->nick());
- if(bufId.isValid())
- Client::bufferModel()->switchToBuffer(bufId);
- else
- Client::userInput(index.data(NetworkModel::BufferInfoRole).value<BufferInfo>(), QString("/QUERY %1").arg(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;
-
- 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();
-}
-
-
-// ****************************************
-// NickViewDelgate
-// ****************************************
-NickViewDelegate::NickViewDelegate(QObject *parent)
- : QStyledItemDelegate(parent)
-{
- UiSettings s("QtUiStyle/Colors");
- _FgOnlineStatus = s.value("onlineStatusFG", QVariant(QColor(Qt::black))).value<QColor>();
- _FgAwayStatus = s.value("awayStatusFG", QVariant(QColor(Qt::gray))).value<QColor>();
-}
-
-void NickViewDelegate::initStyleOption(QStyleOptionViewItem *option, const QModelIndex &index) const {
- QStyledItemDelegate::initStyleOption(option, index);
-
- if(!index.isValid())
- return;
-
- QColor fgColor = _FgOnlineStatus;
- if(!index.data(NetworkModel::ItemActiveRole).toBool())
- fgColor = _FgAwayStatus;
-
- option->palette.setColor(QPalette::Text, fgColor);