X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fnetworkmodel.cpp;h=f04b8430be856d94f4444f578315d81eb30ef52a;hb=4bb04fc5758f566e58d560d6f8c510c5cb038486;hp=8b087d588d4d29e728a6013e7916c10b25729eb1;hpb=7e20c659f88e26ccdfdc65f4894ed6ecf61ca8a9;p=quassel.git diff --git a/src/client/networkmodel.cpp b/src/client/networkmodel.cpp index 8b087d58..f04b8430 100644 --- a/src/client/networkmodel.cpp +++ b/src/client/networkmodel.cpp @@ -107,6 +107,23 @@ BufferItem *NetworkItem::bufferItem(const BufferInfo &bufferInfo) { } newChild(bufferItem); + + // postprocess... this is necessary because Qt doesn't seem to like adding childs which already have childs on their own + switch(bufferInfo.type()) { + case BufferInfo::ChannelBuffer: + { + ChannelBufferItem *channelBufferItem = static_cast(bufferItem); + if(_network) { + IrcChannel *ircChannel = _network->ircChannel(bufferInfo.bufferName()); + if(ircChannel) + channelBufferItem->attachIrcChannel(ircChannel); + } + } + break; + default: + break; + } + return bufferItem; } @@ -216,6 +233,7 @@ void BufferItem::setActivityLevel(BufferInfo::ActivityLevel level) { void BufferItem::clearActivityLevel() { _activity = BufferInfo::NoActivity; _lastSeenMarkerMsgId = _lastSeenMsgId; + _firstUnreadMsgId = MsgId(); emit dataChanged(); } @@ -227,9 +245,15 @@ void BufferItem::updateActivityLevel(const Message &msg) { if(msg.flags() & Message::Self) // don't update activity for our own messages return; - if(lastSeenMsgId() >= msg.msgId()) + if(msg.msgId() <= lastSeenMsgId()) return; + bool stateChanged = false; + if(!firstUnreadMsgId().isValid() || msg.msgId() < firstUnreadMsgId()) { + stateChanged = true; + _firstUnreadMsgId = msg.msgId(); + } + BufferInfo::ActivityLevel oldLevel = activityLevel(); _activity |= BufferInfo::OtherActivity; @@ -239,7 +263,9 @@ void BufferItem::updateActivityLevel(const Message &msg) { if(msg.flags() & Message::Highlight) _activity |= BufferInfo::Highlight; - if(oldLevel != _activity) + stateChanged |= (oldLevel != _activity); + + if(stateChanged) emit dataChanged(); } @@ -259,6 +285,8 @@ QVariant BufferItem::data(int column, int role) const { return isActive(); case NetworkModel::BufferActivityRole: return (int)activityLevel(); + case NetworkModel::BufferFirstUnreadMsgIdRole: + return qVariantFromValue(firstUnreadMsgId()); default: return PropertyMapItem::data(column, role); } @@ -436,13 +464,6 @@ ChannelBufferItem::ChannelBufferItem(const BufferInfo &bufferInfo, AbstractTreeI : BufferItem(bufferInfo, parent), _ircChannel(0) { - const Network *net = Client::network(bufferInfo.networkId()); - if(!net) - return; - - IrcChannel *ircChannel = net->ircChannel(bufferInfo.bufferName()); - if(ircChannel) - attachIrcChannel(ircChannel); } QVariant ChannelBufferItem::data(int column, int role) const { @@ -971,6 +992,7 @@ MsgId NetworkModel::lastSeenMsgId(const BufferId &bufferId) { BufferItem *bufferItem = findBufferItem(bufferId); if(!bufferItem) { qDebug() << "NetworkModel::lastSeenMsgId(): buffer is unknown:" << bufferId; + Client::purgeKnownBufferIds(); return MsgId(); } return bufferItem->lastSeenMsgId(); @@ -980,6 +1002,7 @@ void NetworkModel::setLastSeenMsgId(const BufferId &bufferId, const MsgId &msgId BufferItem *bufferItem = findBufferItem(bufferId); if(!bufferItem) { qDebug() << "NetworkModel::setLastSeenMsgId(): buffer is unknown:" << bufferId; + Client::purgeKnownBufferIds(); return; } bufferItem->setLastSeenMsgId(msgId); @@ -1003,6 +1026,16 @@ void NetworkModel::updateBufferActivity(Message &msg) { msg.setFlags(msg.flags() | Message::Redirected); redirectionTarget = _errorMsgsTarget; break; + // Update IrcUser's last activity + case Message::Plain: + case Message::Action: + if(bufferType(msg.bufferId()) == BufferInfo::ChannelBuffer) { + const Network *net = Client::network(msg.bufferInfo().networkId()); + IrcUser *user = net ? net->ircUser(nickFromMask(msg.sender())) : 0; + if(user) + user->setLastChannelActivity(msg.bufferId(), msg.timestamp()); + } + break; default: break; }