X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fqtuistyle.cpp;h=ebf1947a642329170e395b1dbc41af131574d065;hp=80485b0caaa773152abc99cfd8e77f065d8ad132;hb=b7cf37ec77eccfde8e515c6638ef8d996c71019f;hpb=b65b9f7615165e8700a44d59b7275a55558dd45b diff --git a/src/qtui/qtuistyle.cpp b/src/qtui/qtuistyle.cpp index 80485b0c..ebf1947a 100644 --- a/src/qtui/qtuistyle.cpp +++ b/src/qtui/qtuistyle.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2015 by the Quassel Project * + * Copyright (C) 2005-2016 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -29,6 +29,11 @@ QtUiStyle::QtUiStyle(QObject *parent) : UiStyle(parent) ChatViewSettings s; s.notify("TimestampFormat", this, SLOT(updateTimestampFormatString())); updateTimestampFormatString(); + s.notify("ShowSenderBrackets", this, SLOT(updateShowSenderBrackets())); + updateShowSenderBrackets(); + + // If no style sheet exists, generate it on first run. + initializeSettingsQss(); } @@ -40,10 +45,29 @@ void QtUiStyle::updateTimestampFormatString() setTimestampFormatString(s.timestampFormatString()); } +void QtUiStyle::updateShowSenderBrackets() +{ + ChatViewSettings s; + enableSenderBrackets(s.showSenderBrackets()); +} + + +void QtUiStyle::initializeSettingsQss() +{ + QFileInfo settingsQss(Quassel::configDirPath() + "settings.qss"); + // Only initialize if it doesn't already exist + if (settingsQss.exists()) + return; + + // Generate and load the new stylesheet + generateSettingsQss(); + reload(); +} void QtUiStyle::generateSettingsQss() const { QFile settingsQss(Quassel::configDirPath() + "settings.qss"); + if (!settingsQss.open(QFile::WriteOnly|QFile::Truncate)) { qWarning() << "Could not open" << settingsQss.fileName() << "for writing!"; return; @@ -94,12 +118,26 @@ void QtUiStyle::generateSettingsQss() const << "\n"; } - if (s.value("UseSenderColors").toBool()) { + if (s.value("UseSenderColors", true).toBool()) { out << "\n// Sender Colors\n" - << "ChatLine::sender#plain[sender=\"self\"] { foreground: " << color("SenderSelf", s) << "; }\n\n"; + << "ChatLine::sender#plain[sender=\"self\"] { foreground: " << color("SenderSelf", s, defaultSenderColorSelf) << "; }\n\n"; + + // Matches qssparser.cpp for UiStyle::PlainMsg + for (int i = 0; i < defaultSenderColors.count(); i++) + out << senderQss(i, s, "plain"); + + // Only color the nicks in CTCP ACTIONs if sender colors are enabled + if (s.value("UseSenderActionColors", true).toBool()) { + // For action messages, color the 'sender' column -and- the nick itself + out << "\n// Sender Nickname Colors for action messages\n" + << "ChatLine::sender#action[sender=\"self\"] { foreground: " << color("SenderSelf", s, defaultSenderColorSelf) << "; }\n" + << "ChatLine::nick#action[sender=\"self\"] { foreground: " << color("SenderSelf", s, defaultSenderColorSelf) << "; }\n\n"; + + // Matches qssparser.cpp for UiStyle::ActionMsg + for (int i = 0; i < defaultSenderColors.count(); i++) + out << senderQss(i, s, "action", true); + } - for (int i = 0; i < 16; i++) - out << senderQss(i, s); } // ItemViews @@ -134,9 +172,9 @@ void QtUiStyle::generateSettingsQss() const } -QString QtUiStyle::color(const QString &key, UiSettings &settings) const +QString QtUiStyle::color(const QString &key, UiSettings &settings, const QColor &defaultColor) const { - return settings.value(key).value().name(); + return settings.value(key, defaultColor).value().name(); } @@ -160,12 +198,20 @@ QString QtUiStyle::msgTypeQss(const QString &msgType, const QString &key, UiSett } -QString QtUiStyle::senderQss(int i, UiSettings &settings) const +QString QtUiStyle::senderQss(int i, UiSettings &settings, const QString &messageType, bool includeNick) const { QString dez = QString::number(i); if (dez.length() == 1) dez.prepend('0'); - return QString("ChatLine::sender#plain[sender=\"0%1\"] { foreground: %2; }\n").arg(QString::number(i, 16), color("Sender"+dez, settings)); + if (includeNick) { + // Include the nickname in the color rules + return QString("ChatLine::sender#%1[sender=\"0%2\"] { foreground: %3; }\n" + "ChatLine::nick#%1[sender=\"0%2\"] { foreground: %3; }\n") + .arg(messageType, QString::number(i, 16), color("Sender"+dez, settings, defaultSenderColors[i])); + } else { + return QString("ChatLine::sender#%1[sender=\"0%2\"] { foreground: %3; }\n") + .arg(messageType, QString::number(i, 16), color("Sender"+dez, settings, defaultSenderColors[i])); + } }