X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fchatline.cpp;h=c09bdee01626354b356c8b79214f2f336b9f2aac;hb=3d0af34c02d84199ce680b3460151d02e0ef6d2e;hp=af77b12ca5a29ddf51983b534daefb0dd9efe764;hpb=9d22ec1fd8e8652744e6ea6c91de4a6ec5b2146c;p=quassel.git diff --git a/src/qtui/chatline.cpp b/src/qtui/chatline.cpp index af77b12c..c09bdee0 100644 --- a/src/qtui/chatline.cpp +++ b/src/qtui/chatline.cpp @@ -30,13 +30,14 @@ #include "messagemodel.h" #include "networkmodel.h" #include "qtui.h" +#include "qtuisettings.h" ChatLine::ChatLine(int row, QAbstractItemModel *model, QGraphicsItem *parent) : QGraphicsItem(parent), _row(row), // needs to be set before the items - _timestampItem(ChatLineModel::TimestampColumn, model, this), - _senderItem(ChatLineModel::SenderColumn, model, this), - _contentsItem(ChatLineModel::ContentsColumn, model, this), + _timestampItem(model, this), + _senderItem(model, this), + _contentsItem(model, this), _width(0), _height(0), _selection(0) @@ -64,18 +65,18 @@ ChatItem &ChatLine::item(ChatLineModel::ColumnType column) { } } -qreal ChatLine::setGeometry(qreal width, qreal firstHandlePos, qreal secondHandlePos) { +qreal ChatLine::setGeometry(qreal width) { if(width != _width) prepareGeometryChange(); - qreal firstsep = QtUi::style()->firstColumnSeparator()/2; - qreal secondsep = QtUi::style()->secondColumnSeparator()/2; + QRectF firstColHandleRect = chatScene()->firstColumnHandleRect(); + QRectF secondColHandleRect = chatScene()->secondColumnHandleRect(); - _timestampItem.setWidth(firstHandlePos - firstsep); - _senderItem.setWidth(secondHandlePos - firstHandlePos - (firstsep+secondsep)); - _height = _contentsItem.setWidth(width - secondHandlePos - secondsep); + _height = _contentsItem.setGeometry(width - secondColHandleRect.right()); + _timestampItem.setGeometry(firstColHandleRect.left(), _height); + _senderItem.setGeometry(secondColHandleRect.left() - firstColHandleRect.right(), _height); - _senderItem.setPos(firstHandlePos + firstsep, 0); - _contentsItem.setPos(secondHandlePos + secondsep, 0); + _senderItem.setPos(firstColHandleRect.right(), 0); + _contentsItem.setPos(secondColHandleRect.right(), 0); _width = width; return _height; @@ -110,6 +111,8 @@ void ChatLine::setHighlighted(bool highlighted) { } void ChatLine::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) { + Q_UNUSED(option); + Q_UNUSED(widget); if(_selection & Highlighted) { painter->fillRect(boundingRect(), QBrush(QtUi::style()->highlightColor())); } @@ -119,17 +122,22 @@ void ChatLine::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, painter->fillRect(selectRect, QApplication::palette().brush(QPalette::Highlight)); } + // new line marker const QAbstractItemModel *model_ = model(); if(model_ && row() > 0) { - MsgId msgId = model_->data(model_->index(row() - 1, 0), MessageModel::MsgIdRole).value(); - BufferId bufferId = model_->data(model_->index(row() - 1, 0), MessageModel::BufferIdRole).value(); - if(msgId == Client::networkModel()->lastSeenMsgId(bufferId) && chatScene()->isSingleBufferScene()) { - QLinearGradient gradient(0, 0, 0, height()); - gradient.setColorAt(0, Qt::transparent); - gradient.setColorAt(1, Qt::red); - painter->fillRect(boundingRect(), gradient); + QModelIndex prevRowIdx = model_->index(row() - 1, 0); + MsgId msgId = model_->data(prevRowIdx, MessageModel::MsgIdRole).value(); + Message::Flags flags = (Message::Flags)model_->data(model_->index(row(), 0), MessageModel::FlagsRole).toInt(); + // don't show the marker if we wrote that new line + if(!(flags & Message::Self)) { + BufferId bufferId = model_->data(prevRowIdx, MessageModel::BufferIdRole).value(); + if(msgId == Client::networkModel()->lastSeenMsgId(bufferId) && chatScene()->isSingleBufferScene()) { + QtUiSettings s("QtUiStyle/Colors"); + QLinearGradient gradient(0, 0, 0, height()); + gradient.setColorAt(0, s.value("newMsgMarkerFG", QColor(Qt::red)).value()); + gradient.setColorAt(0.1, Qt::transparent); + painter->fillRect(boundingRect(), gradient); + } } } - - }