X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fclient%2Fbuffer.cpp;h=54bd81a1c02b06def25a1a8033e0dad492c35c78;hb=87f95344178f652061d2c27ad6eda60d738a2041;hp=10f395cf70c22cab1eedfd6108ad42273a056945;hpb=50706d89d4d60e258ebb6873d3778383621898e4;p=quassel.git diff --git a/src/client/buffer.cpp b/src/client/buffer.cpp index 10f395cf..54bd81a1 100644 --- a/src/client/buffer.cpp +++ b/src/client/buffer.cpp @@ -21,19 +21,24 @@ #include "buffer.h" +#include "buffersyncer.h" #include "client.h" +#include "networkmodel.h" +#include "quasselui.h" #include "util.h" Buffer::Buffer(BufferInfo bufferid, QObject *parent) : QObject(parent), - _bufferInfo(bufferid) + _bufferInfo(bufferid), + _isVisible(false), + _activityLevel(NoActivity) { + } BufferInfo Buffer::bufferInfo() const { - // still needed to process user input... *sigh* - // ... and for the gui *sigh* to request the backlogs *sigh* + // still needed by the gui *sigh* to request the backlogs *sigh* return _bufferInfo; } @@ -42,12 +47,14 @@ QList Buffer::contents() const { } void Buffer::appendMsg(const Message &msg) { + updateActivityLevel(msg); AbstractUiMsg *m = Client::layoutMsg(msg); layoutedMsgs.append(m); emit msgAppended(m); } void Buffer::prependMsg(const Message &msg) { + updateActivityLevel(msg); layoutQueue.append(msg); } @@ -60,8 +67,33 @@ bool Buffer::layoutMsg() { return layoutQueue.count(); } -void Buffer::processUserInput(QString msg) { - // TODO User Input processing (plugins) -> well, this goes through MainWin into Core for processing... so... - emit userInput(_bufferInfo, msg); +void Buffer::setVisible(bool visible) { + _isVisible = visible; + setActivityLevel(NoActivity); + if(!layoutedMsgs.count()) return; + setLastSeen(layoutedMsgs.last()->timestamp()); } +void Buffer::setLastSeen(const QDateTime &seen) { + if(seen.isValid() && seen > lastSeen()) { //qDebug() << "setting:" << bufferInfo().bufferName() << seen; + _lastSeen = seen; + Client::bufferSyncer()->requestSetLastSeen(bufferInfo().bufferId(), seen); + setActivityLevel(NoActivity); + } +} + +void Buffer::setActivityLevel(ActivityLevel level) { + _activityLevel = level; + if(bufferInfo().bufferId() > 0) Client::networkModel()->setBufferActivity(bufferInfo(), level); +} + +void Buffer::updateActivityLevel(const Message &msg) { + if(isVisible()) return; + if(lastSeen().isValid() && lastSeen() >= msg.timestamp()) return; + + ActivityLevel level = activityLevel() | OtherActivity; + if(msg.type() == Message::Plain || msg.type() == Message::Notice) level |= NewMessage; + if(msg.flags() & Message::Highlight) level |= Highlight; + + if(level != activityLevel()) setActivityLevel(level); +}