X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fuisupport%2Fuistyle.cpp;h=3b9e079b85b50cd76f4ace915efdf7881dc28208;hb=258df63876c8b2b5f3ff14a6fbae14ea0b713457;hp=fd2bee5283a67ab63ff1f5493bc0bdb5158c0f6d;hpb=27fe4e6f46547c45d19fa39c175fa2104a5feb28;p=quassel.git diff --git a/src/uisupport/uistyle.cpp b/src/uisupport/uistyle.cpp index fd2bee52..3b9e079b 100644 --- a/src/uisupport/uistyle.cpp +++ b/src/uisupport/uistyle.cpp @@ -32,6 +32,7 @@ QHash UiStyle::_formatCodes; bool UiStyle::_useCustomTimestampFormat; /// If true, use the custom timestamp format QString UiStyle::_timestampFormatString; /// Timestamp format QString UiStyle::_systemTimestampFormatString; /// Cached copy of system locale timestamp format +bool UiStyle::_showSenderPrefixes; /// If true, show prefixmodes before sender names bool UiStyle::_showSenderBrackets; /// If true, show brackets around sender names UiStyle::UiStyle(QObject *parent) @@ -74,6 +75,7 @@ UiStyle::UiStyle(QObject *parent) // in there. setUseCustomTimestampFormat(false); setTimestampFormatString(" hh:mm:ss"); + enableSenderPrefixes(false); enableSenderBrackets(true); // BufferView / NickView settings @@ -224,6 +226,13 @@ void UiStyle::setTimestampFormatString(const QString &format) } } +void UiStyle::enableSenderPrefixes(bool enabled) +{ + if (_showSenderPrefixes != enabled) { + _showSenderPrefixes = enabled; + } +} + void UiStyle::enableSenderBrackets(bool enabled) { if (_showSenderBrackets != enabled) { @@ -735,11 +744,28 @@ QString UiStyle::timestampFormatString() UiStyle::StyledMessage::StyledMessage(const Message &msg) : Message(msg) { - if (type() == Message::Plain || type() == Message::Action) - _senderHash = 0xff; - else - _senderHash = 0x00; - // This means we never compute the hash for msgs that aren't Plain or Action + switch (type()) { + // Don't compute the sender hash for message types without a nickname embedded + case Message::Server: + case Message::Info: + case Message::Error: + case Message::DayChange: + case Message::Topic: + case Message::Invite: + // Don't compute the sender hash for messages with multiple nicks + // Fixing this without breaking themes would be.. complex. + case Message::NetsplitJoin: + case Message::NetsplitQuit: + case Message::Kick: + // Don't compute the sender hash for message types that are not yet completed elsewhere + case Message::Kill: + _senderHash = 0x00; + break; + default: + // Compute the sender hash for all other message types + _senderHash = 0xff; + break; + } } @@ -891,15 +917,20 @@ QString UiStyle::StyledMessage::plainSender() const QString UiStyle::StyledMessage::decoratedSender() const { + QString _senderPrefixes; + if (_showSenderPrefixes) { + _senderPrefixes = senderPrefixes(); + } + switch (type()) { case Message::Plain: if (_showSenderBrackets) - return QString("<%1>").arg(plainSender()); + return QString("<%1%2>").arg(_senderPrefixes, plainSender()); else - return QString("%1").arg(plainSender()); + return QString("%1%2").arg(_senderPrefixes, plainSender()); break; case Message::Notice: - return QString("[%1]").arg(plainSender()); break; + return QString("[%1%2]").arg(_senderPrefixes, plainSender()); break; case Message::Action: return "-*-"; break; case Message::Nick: @@ -933,7 +964,7 @@ QString UiStyle::StyledMessage::decoratedSender() const case Message::Invite: return "->"; break; default: - return QString("%1").arg(plainSender()); + return QString("%1%2").arg(_senderPrefixes, plainSender()); } } @@ -944,7 +975,19 @@ quint8 UiStyle::StyledMessage::senderHash() const if (_senderHash != 0xff) return _senderHash; - QString nick = nickFromMask(sender()).toLower(); + QString nick; + + // HACK: Until multiple nicknames with different colors can be solved in the theming engine, + // for /nick change notifications, use the color of the new nickname (if possible), not the old + // nickname. + if (type() == Message::Nick) { + // New nickname is given as contents. Change to that. + nick = stripFormatCodes(contents()).toLower(); + } else { + // Just use the sender directly + nick = nickFromMask(sender()).toLower(); + } + if (!nick.isEmpty()) { int chopCount = 0; while (chopCount < nick.size() && nick.at(nick.count() - 1 - chopCount) == '_')