X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fchatline.cpp;h=1a8501c7316840b1f4a3c8e7159b2aa55ba998ae;hb=ba934ceb1bfe30d01d5fb5c072c3197f8080be04;hp=4e03f064bcb98ef5c0f116a40457d6427c4fe271;hpb=de6bcf921abc4880b1dd75d68e99761a12eb0d33;p=quassel.git diff --git a/src/qtui/chatline.cpp b/src/qtui/chatline.cpp index 4e03f064..1a8501c7 100644 --- a/src/qtui/chatline.cpp +++ b/src/qtui/chatline.cpp @@ -27,17 +27,19 @@ #include "client.h" #include "chatitem.h" #include "chatline.h" +#include "columnhandleitem.h" #include "messagemodel.h" #include "networkmodel.h" #include "qtui.h" #include "qtuisettings.h" +#include "qtuistyle.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) @@ -65,18 +67,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; - _timestampItem.setWidth(firstHandlePos - firstsep); - _senderItem.setWidth(secondHandlePos - firstHandlePos - (firstsep+secondsep)); - _height = _contentsItem.setWidth(width - secondHandlePos - secondsep); + ColumnHandleItem *firstColumnHandle = chatScene()->firstColumnHandle(); + ColumnHandleItem *secondColumnHandle = chatScene()->secondColumnHandle(); + _height = _contentsItem.setGeometry(width - secondColumnHandle->sceneRight()); + _timestampItem.setGeometry(firstColumnHandle->sceneLeft(), _height); + _senderItem.setGeometry(secondColumnHandle->sceneLeft() - firstColumnHandle->sceneRight(), _height); - _senderItem.setPos(firstHandlePos + firstsep, 0); - _contentsItem.setPos(secondHandlePos + secondsep, 0); + _senderItem.setPos(firstColumnHandle->sceneRight(), 0); + _contentsItem.setPos(secondColumnHandle->sceneRight(), 0); _width = width; return _height; @@ -111,6 +113,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())); } @@ -130,7 +134,7 @@ void ChatLine::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, if(!(flags & Message::Self)) { BufferId bufferId = model_->data(prevRowIdx, MessageModel::BufferIdRole).value(); if(msgId == Client::networkModel()->lastSeenMsgId(bufferId) && chatScene()->isSingleBufferScene()) { - QtUiSettings s("QtUiStyle/Colors"); + QtUiStyleSettings s("Colors"); QLinearGradient gradient(0, 0, 0, height()); gradient.setColorAt(0, s.value("newMsgMarkerFG", QColor(Qt::red)).value()); gradient.setColorAt(0.1, Qt::transparent);