X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fnetworkmodel.cpp;h=23e06422129bdf33e4c4f26caad7b23e454ca920;hp=75a18af812b6b117efed7c87ff8870241e7c9e1e;hb=3e8c20eed6bdc729a3eac2946fad70b8e03c1d2a;hpb=28d1a6cc6e9b153dbed0257241abb8aedf706ac2 diff --git a/src/client/networkmodel.cpp b/src/client/networkmodel.cpp index 75a18af8..23e06422 100644 --- a/src/client/networkmodel.cpp +++ b/src/client/networkmodel.cpp @@ -22,7 +22,6 @@ #include -#include "bufferinfo.h" #include "buffermodel.h" #include "client.h" #include "signalproxy.h" @@ -40,11 +39,18 @@ NetworkItem::NetworkItem(const NetworkId &netid, AbstractTreeItem *parent) : PropertyMapItem(QList() << "networkName" << "currentServer" << "nickCount", parent), _networkId(netid) { - setFlags(Qt::ItemIsEnabled); + setFlags(Qt::ItemIsEnabled | Qt::ItemIsSelectable); } QVariant NetworkItem::data(int column, int role) const { switch(role) { + case NetworkModel::BufferIdRole: + case NetworkModel::BufferInfoRole: + case NetworkModel::BufferTypeRole: + if(childCount()) + return child(0)->data(column, role); + else + return QVariant(); case NetworkModel::NetworkIdRole: return qVariantFromValue(_networkId); case NetworkModel::ItemTypeRole: @@ -58,7 +64,7 @@ QVariant NetworkItem::data(int column, int role) const { BufferItem *NetworkItem::findBufferItem(BufferId bufferId) { BufferItem *bufferItem = 0; - + for(int i = 0; i < childCount(); i++) { bufferItem = qobject_cast(child(i)); if(!bufferItem) @@ -74,7 +80,7 @@ BufferItem *NetworkItem::bufferItem(const BufferInfo &bufferInfo) { BufferItem *bufferItem = findBufferItem(bufferInfo); if(bufferItem) return bufferItem; - + switch(bufferInfo.type()) { case BufferInfo::StatusBuffer: bufferItem = new StatusBufferItem(bufferInfo, this); @@ -96,7 +102,7 @@ BufferItem *NetworkItem::bufferItem(const BufferInfo &bufferInfo) { void NetworkItem::attachNetwork(Network *network) { if(!network) return; - + _network = network; connect(network, SIGNAL(networkNameSet(QString)), @@ -111,7 +117,7 @@ void NetworkItem::attachNetwork(Network *network) { this, SIGNAL(dataChanged())); connect(network, SIGNAL(destroyed()), this, SIGNAL(dataChanged())); - + emit dataChanged(); } @@ -174,22 +180,28 @@ QString NetworkItem::toolTip(int column) const { BufferItem::BufferItem(const BufferInfo &bufferInfo, AbstractTreeItem *parent) : PropertyMapItem(QStringList() << "bufferName" << "topic" << "nickCount", parent), _bufferInfo(bufferInfo), - _activity(Buffer::NoActivity) + _activity(BufferInfo::NoActivity) { setFlags(Qt::ItemIsEnabled | Qt::ItemIsSelectable | Qt::ItemIsDragEnabled); } -void BufferItem::setActivityLevel(Buffer::ActivityLevel level) { +void BufferItem::setActivityLevel(BufferInfo::ActivityLevel level) { if(_activity != level) { _activity = level; emit dataChanged(); } } -//void BufferItem::updateActivityLevel(Buffer::ActivityLevel level) { +void BufferItem::clearActivityLevel() { + _activity = BufferInfo::NoActivity; + _lastSeenMarkerMsgId = _lastSeenMsgId; + emit dataChanged(); +} + void BufferItem::updateActivityLevel(const Message &msg) { - if(isCurrentBuffer()) + if(isCurrentBuffer()) { return; + } if(msg.flags() & Message::Self) // don't update activity for our own messages return; @@ -197,14 +209,14 @@ void BufferItem::updateActivityLevel(const Message &msg) { if(lastSeenMsgId() >= msg.msgId()) return; - Buffer::ActivityLevel oldLevel = activityLevel(); + BufferInfo::ActivityLevel oldLevel = activityLevel(); - _activity |= Buffer::OtherActivity; + _activity |= BufferInfo::OtherActivity; if(msg.type() & (Message::Plain | Message::Notice | Message::Action)) - _activity |= Buffer::NewMessage; + _activity |= BufferInfo::NewMessage; if(msg.flags() & Message::Highlight) - _activity |= Buffer::Highlight; + _activity |= BufferInfo::Highlight; if(oldLevel != _activity) emit dataChanged(); @@ -235,7 +247,7 @@ bool BufferItem::setData(int column, const QVariant &value, int role) { qDebug() << "BufferItem::setData(int column, const QVariant &value, int role):" << this << column << value << role; switch(role) { case NetworkModel::BufferActivityRole: - setActivityLevel((Buffer::ActivityLevel)value.toInt()); + setActivityLevel((BufferInfo::ActivityLevel)value.toInt()); return true; default: return PropertyMapItem::setData(column, value, role); @@ -248,6 +260,14 @@ void BufferItem::setBufferName(const QString &name) { emit dataChanged(0); } +void BufferItem::setLastSeenMsgId(const MsgId &msgId) { + _lastSeenMsgId = msgId; + if(!isCurrentBuffer()) { + _lastSeenMarkerMsgId = msgId; + } + setActivityLevel(BufferInfo::NoActivity); +} + bool BufferItem::isCurrentBuffer() const { return _bufferInfo.bufferId() == Client::bufferModel()->currentIndex().data(NetworkModel::BufferIdRole).value(); } @@ -305,7 +325,7 @@ QVariant QueryBufferItem::data(int column, int role) const { } QString QueryBufferItem::toolTip(int column) const { - // pretty much code duplication of IrcUserItem::toolTip() but inheritance won't solve this... + // pretty much code duplication of IrcUserItem::toolTip() but inheritance won't solve this... Q_UNUSED(column); QStringList toolTip; @@ -320,9 +340,9 @@ QString QueryBufferItem::toolTip(int column) const { if(!_ircUser->ircOperator().isEmpty()) toolTip.append(QString("%1 %2").arg(_ircUser->nick()).arg(_ircUser->ircOperator())); if(!_ircUser->suserHost().isEmpty()) toolTip.append(_ircUser->suserHost()); if(!_ircUser->whoisServiceReply().isEmpty()) toolTip.append(_ircUser->whoisServiceReply()); - + toolTip.append(_ircUser->hostmask().remove(0, _ircUser->hostmask().indexOf("!")+1)); - + if(_ircUser->idleTime().isValid()) { QDateTime now = QDateTime::currentDateTime(); QDateTime idle = _ircUser->idleTime(); @@ -332,7 +352,7 @@ QString QueryBufferItem::toolTip(int column) const { if(_ircUser->loginTime().isValid()) { toolTip.append(tr("login time: %1").arg(_ircUser->loginTime().toString())); } - + if(!_ircUser->server().isEmpty()) toolTip.append(tr("server: %1").arg(_ircUser->server())); } @@ -373,35 +393,36 @@ QString ChannelBufferItem::toolTip(int column) const { toolTip.append(tr("Channel %1").arg(bufferName())); if(isActive()) { - //TODO: add channel modes + //TODO: add channel modes toolTip.append(tr("Users: %1").arg(nickCount())); if(_ircChannel) { QString channelMode = _ircChannel->channelModeString(); // channelModeString is compiled on the fly -> thus cache the result if(!channelMode.isEmpty()) - toolTip.append(tr("Mode: %1").arg(channelMode)); + toolTip.append(tr("Mode: %1").arg(channelMode)); } - + BufferSettings s; bool showTopic = s.value("DisplayTopicInTooltip", QVariant(false)).toBool(); if(showTopic) { QString _topic = topic(); if(_topic != "") { - _topic.replace(QString("<"), QString("<")); - _topic.replace(QString(">"), QString(">")); - toolTip.append(QString(" ")); - toolTip.append(tr("Topic: %1").arg(_topic)); + _topic = stripFormatCodes(_topic); + _topic.replace(QString("<"), QString("<")); + _topic.replace(QString(">"), QString(">")); + toolTip.append(QString(" ")); + toolTip.append(tr("Topic: %1").arg(_topic)); } } } else { toolTip.append(tr("Not active
Double-click to join")); } - return tr("

%1

").arg(toolTip.join("
")); + return tr("

%1

").arg(toolTip.join("
")); } void ChannelBufferItem::attachIrcChannel(IrcChannel *ircChannel) { Q_ASSERT(!_ircChannel && ircChannel); - + _ircChannel = ircChannel; connect(ircChannel, SIGNAL(topicSet(QString)), @@ -421,7 +442,7 @@ void ChannelBufferItem::attachIrcChannel(IrcChannel *ircChannel) { if(!ircChannel->ircUsers().isEmpty()) join(ircChannel->ircUsers()); - + emit dataChanged(); } @@ -440,7 +461,7 @@ void ChannelBufferItem::join(const QList &ircUsers) { UserCategoryItem *ChannelBufferItem::findCategoryItem(int categoryId) { UserCategoryItem *categoryItem = 0; - + for(int i = 0; i < childCount(); i++) { categoryItem = qobject_cast(child(i)); if(!categoryItem) @@ -462,7 +483,7 @@ void ChannelBufferItem::addUsersToCategory(const QList &ircUsers) { int categoryId = -1; UserCategoryItem *categoryItem = 0; - + foreach(IrcUser *ircUser, ircUsers) { categoryId = UserCategoryItem::categoryFromModes(_ircChannel->userModes(ircUser)); categoryItem = findCategoryItem(categoryId); @@ -516,7 +537,7 @@ void ChannelBufferItem::userModeChanged(IrcUser *ircUser) { int categoryId = UserCategoryItem::categoryFromModes(_ircChannel->userModes(ircUser)); UserCategoryItem *categoryItem = findCategoryItem(categoryId); - + if(categoryItem) { if(categoryItem->findIrcUser(ircUser)) { return; // already in the right category; @@ -639,7 +660,7 @@ IrcUserItem::IrcUserItem(IrcUser *ircUser, AbstractTreeItem *parent) : PropertyMapItem(QStringList() << "nickName", parent), _ircUser(ircUser) { - setObjectName(ircUser->nick()); + setObjectName(ircUser->nick()); connect(ircUser, SIGNAL(destroyed()), this, SLOT(ircUserDestroyed())); connect(ircUser, SIGNAL(nickSet(QString)), this, SIGNAL(dataChanged())); connect(ircUser, SIGNAL(awaySet(bool)), this, SIGNAL(dataChanged())); @@ -863,7 +884,7 @@ bool NetworkModel::dropMimeData(const QMimeData *data, Qt::DropAction action, in // no self merges (would kill us) if(bufferId == parent.data(BufferIdRole).value()) - return false; + return false; NetworkItem *netItem = findNetworkItem(netId); Q_ASSERT(netItem); @@ -874,11 +895,11 @@ bool NetworkModel::dropMimeData(const QMimeData *data, Qt::DropAction action, in // source must be a query too if(bufferItem->bufferType() != BufferInfo::QueryBuffer) return false; - + // TODO: warn user about buffermerge! qDebug() << "merging" << bufferId << parent.data(BufferIdRole).value(); removeRow(parent.row(), parent.parent()); - + return true; } @@ -908,6 +929,13 @@ MsgId NetworkModel::lastSeenMsgId(BufferId bufferId) { return _bufferItemCache[bufferId]->lastSeenMsgId(); } +MsgId NetworkModel::lastSeenMarkerMsgId(BufferId bufferId) { + if(!_bufferItemCache.contains(bufferId)) + return MsgId(); + + return _bufferItemCache[bufferId]->lastSeenMarkerMsgId(); +} + void NetworkModel::setLastSeenMsgId(const BufferId &bufferId, const MsgId &msgId) { BufferItem *bufferItem = findBufferItem(bufferId); if(!bufferItem) { @@ -918,10 +946,13 @@ void NetworkModel::setLastSeenMsgId(const BufferId &bufferId, const MsgId &msgId } void NetworkModel::updateBufferActivity(const Message &msg) { - bufferItem(msg.bufferInfo())->updateActivityLevel(msg); + BufferItem *item = bufferItem(msg.bufferInfo()); + item->updateActivityLevel(msg); + if(item->isCurrentBuffer()) + emit setLastSeenMsg(item->bufferId(), msg.msgId()); } -void NetworkModel::setBufferActivity(const BufferId &bufferId, Buffer::ActivityLevel level) { +void NetworkModel::setBufferActivity(const BufferId &bufferId, BufferInfo::ActivityLevel level) { BufferItem *bufferItem = findBufferItem(bufferId); if(!bufferItem) { qDebug() << "NetworkModel::setBufferActivity(): buffer is unknown:" << bufferId; @@ -930,6 +961,15 @@ void NetworkModel::setBufferActivity(const BufferId &bufferId, Buffer::ActivityL bufferItem->setActivityLevel(level); } +void NetworkModel::clearBufferActivity(const BufferId &bufferId) { + BufferItem *bufferItem = findBufferItem(bufferId); + if(!bufferItem) { + qDebug() << "NetworkModel::clearBufferActivity(): buffer is unknown:" << bufferId; + return; + } + bufferItem->clearActivityLevel(); +} + const Network *NetworkModel::networkByIndex(const QModelIndex &index) const { QVariant netVariant = index.data(NetworkIdRole); if(!netVariant.isValid()) @@ -942,7 +982,7 @@ const Network *NetworkModel::networkByIndex(const QModelIndex &index) const { void NetworkModel::checkForRemovedBuffers(const QModelIndex &parent, int start, int end) { if(parent.data(ItemTypeRole) != NetworkItemType) return; - + for(int row = start; row <= end; row++) { _bufferItemCache.remove(parent.child(row, 0).data(BufferIdRole).value()); }