X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatlinemodelitem.cpp;h=4e1eb476f7ab2531f10af34bb2bfc060fb738f61;hp=dbd5e933fb48aaed894d7f5d26cce3837f79a8f3;hb=0b9f74984780aacbe85ca04c44ec6304c86557c2;hpb=aefcf3c3799a9deb286723eccc124760ce4d898d diff --git a/src/qtui/chatlinemodelitem.cpp b/src/qtui/chatlinemodelitem.cpp index dbd5e933..4e1eb476 100644 --- a/src/qtui/chatlinemodelitem.cpp +++ b/src/qtui/chatlinemodelitem.cpp @@ -24,28 +24,34 @@ #include "uistyle.h" ChatlineModelItem::ChatlineModelItem(const Message &msg) : MessageModelItem(msg) { - _msg = QtUi::style()->styleMessage(msg); + QtUiStyle::StyledMessage m = QtUi::style()->styleMessage(msg); + + _timestamp.plainText = m.timestamp.plainText; + _sender.plainText = m.sender.plainText; + _contents.plainText = m.contents.plainText; + + _timestamp.formatList = m.timestamp.formatList; + _sender.formatList = m.sender.formatList; + _contents.formatList = m.contents.formatList; } QVariant ChatlineModelItem::data(int column, int role) const { + const ChatlinePart *part; + + switch(column) { + case ChatlineModel::TimestampColumn: part = &_timestamp; break; + case ChatlineModel::SenderColumn: part = &_sender; break; + case ChatlineModel::ContentsColumn: part = &_contents; break; + default: return MessageModelItem::data(column, role); + } + switch(role) { - case ChatlineModel::DisplayRole: - switch(column) { - case ChatlineModel::TimestampColumn: return _msg.timestamp.text; - case ChatlineModel::SenderColumn: return _msg.sender.text; - case ChatlineModel::TextColumn: return _msg.text.text; - } - break; - case ChatlineModel::FormatRole: - switch(column) { - case ChatlineModel::TimestampColumn: return QVariant::fromValue(_msg.timestamp.formats); - case ChatlineModel::SenderColumn: return QVariant::fromValue(_msg.sender.formats); - case ChatlineModel::TextColumn: return QVariant::fromValue(_msg.text.formats); - } - break; + case ChatlineModel::DisplayRole: return part->plainText; + case ChatlineModel::FormatRole: return QVariant::fromValue(part->formatList); } + return MessageModelItem::data(column, role); }