diff --git a/src/chatlog/chatmessage.cpp b/src/chatlog/chatmessage.cpp index b6a1b840d..864351a28 100644 --- a/src/chatlog/chatmessage.cpp +++ b/src/chatlog/chatmessage.cpp @@ -30,7 +30,6 @@ #include "src/persistence/settings.h" #include "src/persistence/smileypack.h" -#include "src/widget/style.h" #define NAME_COL_WIDTH 90.0 #define TIME_COL_WIDTH 90.0 @@ -75,8 +74,13 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString &sender, const QSt } // Note: Eliding cannot be enabled for RichText items. (QTBUG-17207) - msg->addColumn(new Text(senderText, isMe ? Style::getFont(Style::BigBold) : Style::getFont(Style::Big), true, sender, type == ACTION ? actionColor : Qt::black), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); - msg->addColumn(new Text(text, Style::getFont(Style::Big), false, ((type == ACTION) && isMe) ? QString("%1 %2").arg(sender, rawMessage) : rawMessage), ColumnFormat(1.0, ColumnFormat::VariableSize)); + QFont baseFont = Settings::getInstance().getChatMessageFont(); + QFont authorFont = baseFont; + if (isMe) + authorFont.setBold(true); + + msg->addColumn(new Text(senderText, authorFont, true, sender, type == ACTION ? actionColor : Qt::black), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + msg->addColumn(new Text(text, baseFont, false, ((type == ACTION) && isMe) ? QString("%1 %2").arg(sender, rawMessage) : rawMessage), ColumnFormat(1.0, ColumnFormat::VariableSize)); msg->addColumn(new Spinner(":/ui/chatArea/spinner.svg", QSize(16, 16), 360.0/1.6), ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); if (!date.isNull()) @@ -98,9 +102,11 @@ ChatMessage::Ptr ChatMessage::createChatInfoMessage(const QString &rawMessage, S case TYPING: img = ":/ui/chatArea/typing.svg"; break; } + QFont baseFont = Settings::getInstance().getChatMessageFont(); + msg->addColumn(new Image(QSize(18, 18), img), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); - msg->addColumn(new Text("" + text + "", Style::getFont(Style::Big), false, ""), ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Left)); - msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(), Style::getFont(Style::Big)), ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + msg->addColumn(new Text("" + text + "", baseFont, false, ""), ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Left)); + msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(), baseFont), ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); return msg; } @@ -109,9 +115,14 @@ ChatMessage::Ptr ChatMessage::createFileTransferMessage(const QString& sender, T { ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage); - msg->addColumn(new Text(sender, isMe ? Style::getFont(Style::BigBold) : Style::getFont(Style::Big), true), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + QFont baseFont = Settings::getInstance().getChatMessageFont(); + QFont authorFont = baseFont; + if (isMe) + authorFont.setBold(true); + + msg->addColumn(new Text(sender, authorFont, true), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); msg->addColumn(new ChatLineContentProxy(new FileTransferWidget(0, file), 320, 0.6f), ColumnFormat(1.0, ColumnFormat::VariableSize)); - msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(), Style::getFont(Style::Big)), ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); + msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(), baseFont), ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); return msg; } @@ -120,6 +131,8 @@ ChatMessage::Ptr ChatMessage::createTypingNotification() { ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage); + QFont baseFont = Settings::getInstance().getChatMessageFont(); + // Note: "[user]..." is just a placeholder. The actual text is set in ChatForm::setFriendTyping() // // FIXME: Due to circumstances, placeholder is being used in a case where @@ -127,7 +140,7 @@ ChatMessage::Ptr ChatMessage::createTypingNotification() // This causes "[user]..." to be displayed in place of user nick, as long // as user will keep typing. Issue #1280 msg->addColumn(new NotificationIcon(QSize(18, 18)), ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right)); - msg->addColumn(new Text("[user]...", Style::getFont(Style::Big), false, ""), ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Left)); + msg->addColumn(new Text("[user]...", baseFont, false, ""), ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Left)); return msg; } @@ -135,17 +148,21 @@ ChatMessage::Ptr ChatMessage::createTypingNotification() ChatMessage::Ptr ChatMessage::createBusyNotification() { ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage); + QFont baseFont = Settings::getInstance().getChatMessageFont(); + baseFont.setPixelSize(baseFont.pixelSize() + 2); + baseFont.setBold(true); - // TODO: Bigger font - msg->addColumn(new Text(QObject::tr("Resizing"), Style::getFont(Style::ExtraBig), false, ""), ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Center)); + msg->addColumn(new Text(QObject::tr("Resizing"), baseFont, false, ""), ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Center)); return msg; } void ChatMessage::markAsSent(const QDateTime &time) { + QFont baseFont = Settings::getInstance().getChatMessageFont(); + // remove the spinner and replace it by $time - replaceContent(2, new Timestamp(time, Settings::getInstance().getTimestampFormat(), Style::getFont(Style::Big))); + replaceContent(2, new Timestamp(time, Settings::getInstance().getTimestampFormat(), baseFont)); } QString ChatMessage::toString() const diff --git a/src/chatlog/content/text.cpp b/src/chatlog/content/text.cpp index 4e4adfc8c..d3272f185 100644 --- a/src/chatlog/content/text.cpp +++ b/src/chatlog/content/text.cpp @@ -31,10 +31,13 @@ #include #include -Text::Text(const QString& txt, QFont font, bool enableElide, const QString &rwText, const QColor c) +Text::Text(const QString& txt, const QFont& font, bool enableElide, const QString &rwText, const QColor c) : rawText(rwText) , elide(enableElide) , defFont(font) + , defStyleSheet(QString::fromUtf8("body{font: '%1' %2px %3;}") + .arg(font.family()).arg(font.pixelSize()) + .arg(font.bold() ? "bold" : QString())) , color(c) { setText(txt); @@ -247,9 +250,14 @@ void Text::regenerate() doc->setDefaultFont(defFont); if (!elide) + { + doc->setDefaultStyleSheet(defStyleSheet); doc->setHtml(text); + } else + { doc->setPlainText(elidedText); + } // wrap mode QTextOption opt; diff --git a/src/chatlog/content/text.h b/src/chatlog/content/text.h index 3bdc59d3c..b307fed13 100644 --- a/src/chatlog/content/text.h +++ b/src/chatlog/content/text.h @@ -31,7 +31,7 @@ class Text : public ChatLineContent public: // txt: may contain html code // rawText: does not contain html code - Text(const QString& txt = "", QFont font = QFont(), bool enableElide = false, const QString& rawText = QString(), const QColor c = Qt::black); + Text(const QString& txt = "", const QFont& font = QFont(), bool enableElide = false, const QString& rawText = QString(), const QColor c = Qt::black); virtual ~Text(); void setText(const QString& txt); @@ -87,6 +87,7 @@ private: qreal ascent = 0.0; qreal width = 0.0; QFont defFont; + QString defStyleSheet; QColor color; };