X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fchatline.cpp;h=0e4df2268c91a944df1c165e9c93fa0291857464;hb=2bd85f1d7a8330fdc4f5dedacdcea8006f971935;hp=ef59fc48622c7b63a2addfed1f1fdf64bd591aa3;hpb=22f141be889377b07472bb967d92186dad23be3e;p=quassel.git diff --git a/src/qtui/chatline.cpp b/src/qtui/chatline.cpp index ef59fc48..0e4df226 100644 --- a/src/qtui/chatline.cpp +++ b/src/qtui/chatline.cpp @@ -18,18 +18,100 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ +#include +#include +#include + +#include "bufferinfo.h" +#include "chatitem.h" #include "chatline.h" +#include "qtui.h" -Chatline::Chatline(const Message &msg) : MessageItem(msg) { +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), + _width(0), + _height(0), + _selection(0) +{ + Q_ASSERT(model); + QModelIndex index = model->index(row, ChatLineModel::ContentsColumn); + setHighlighted(model->data(index, MessageModel::FlagsRole).toInt() & Message::Highlight); +} +QRectF ChatLine::boundingRect () const { + //return childrenBoundingRect(); + return QRectF(0, 0, _width, _height); +} +ChatItem &ChatLine::item(ChatLineModel::ColumnType column) { + switch(column) { + case ChatLineModel::TimestampColumn: + return _timestampItem; + case ChatLineModel::SenderColumn: + return _senderItem; + case ChatLineModel::ContentsColumn: + return _contentsItem; + default: + return *(ChatItem *)0; // provoke an error + } } +qreal ChatLine::setGeometry(qreal width, qreal firstHandlePos, qreal secondHandlePos) { + 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); + + _senderItem.setPos(firstHandlePos + firstsep, 0); + _contentsItem.setPos(secondHandlePos + secondsep, 0); + + _width = width; + return _height; +} + +void ChatLine::setSelected(bool selected, ChatLineModel::ColumnType minColumn) { + if(selected) { + quint8 sel = (_selection & 0x80) | 0x40 | minColumn; + if(sel != _selection) { + _selection = sel; + for(int i = 0; i < minColumn; i++) + item((ChatLineModel::ColumnType)i).clearSelection(); + for(int i = minColumn; i <= ChatLineModel::ContentsColumn; i++) + item((ChatLineModel::ColumnType)i).setFullSelection(); + update(); + } + } else { + quint8 sel = _selection & 0x80; + if(sel != _selection) { + _selection = sel; + for(int i = 0; i <= ChatLineModel::ContentsColumn; i++) + item((ChatLineModel::ColumnType)i).clearSelection(); + update(); + } + } +} -QVariant Chatline::data(int column, int role) const { - return MessageItem::data(column, role); +void ChatLine::setHighlighted(bool highlighted) { + if(highlighted) _selection |= 0x80; + else _selection &= 0x7f; + update(); } -bool Chatline::setData(int column, const QVariant &value, int role) { - return false; +void ChatLine::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) { + if(_selection & Highlighted) { + painter->fillRect(boundingRect(), QBrush(QtUi::style()->highlightColor())); + } + if(_selection & Selected) { + qreal left = item((ChatLineModel::ColumnType)(_selection & 0x3f)).x(); + QRectF selectRect(left, 0, width() - left, height()); + painter->fillRect(selectRect, QApplication::palette().brush(QPalette::Highlight)); + } }