Fix red text color persisting from message overflow highlight (#4204)

Co-authored-by: Felanbird <41973452+Felanbird@users.noreply.github.com>
Co-authored-by: pajlada <rasmus.karlsson@pajlada.com>
This commit is contained in:
kornes 2022-12-03 11:10:11 +00:00 committed by GitHub
parent 188782ddca
commit db12693a27
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 23 additions and 18 deletions

View file

@ -2,6 +2,7 @@
## Unversioned
- Bugfix: Fixed message input showing as red after removing a message that was more than 500 characters. (#4204)
- Bugfix: Fixed unnecessary saving of windows layout. (#4201)
- Dev: Ignore `WM_SHOWWINDOW` hide events, causing fewer attempted rescales. (#4198)

View file

@ -15,6 +15,8 @@ namespace chatterino {
static const char *ANONYMOUS_USERNAME ATTR_UNUSED = "justinfan64537";
static constexpr int TWITCH_MESSAGE_LIMIT = 500;
inline QByteArray getDefaultClientID()
{
return QByteArray("7ue61iz46fz11y3cugd0l3tawb4taal");

View file

@ -6,6 +6,7 @@
#include "controllers/hotkeys/HotkeyController.hpp"
#include "messages/Link.hpp"
#include "providers/twitch/TwitchChannel.hpp"
#include "providers/twitch/TwitchCommon.hpp"
#include "providers/twitch/TwitchIrcServer.hpp"
#include "singletons/Settings.hpp"
#include "singletons/Theme.hpp"
@ -25,6 +26,7 @@
#include <QCompleter>
#include <QPainter>
#include <QSignalBlocker>
#include <functional>
@ -885,25 +887,29 @@ void SplitInput::editTextChanged()
app->commands->execCommand(text, this->split_->getChannel(), true);
}
if (getSettings()->messageOverflow.getValue() == MessageOverflow::Highlight)
if (text.length() > 0 &&
getSettings()->messageOverflow.getValue() == MessageOverflow::Highlight)
{
if (text.length() > TWITCH_MESSAGE_LIMIT &&
text.length() > this->lastOverflowLength)
{
QTextCharFormat format;
format.setForeground(Qt::red);
QTextCursor cursor = this->ui_.textEdit->textCursor();
QTextCharFormat format;
QList<QTextEdit::ExtraSelection> selections;
QTextCursor cursor = this->ui_.textEdit->textCursor();
cursor.setPosition(lastOverflowLength, QTextCursor::MoveAnchor);
cursor.setPosition(qMin(text.length(), TWITCH_MESSAGE_LIMIT),
QTextCursor::MoveAnchor);
cursor.movePosition(QTextCursor::Start, QTextCursor::KeepAnchor);
selections.append({cursor, format});
if (text.length() > TWITCH_MESSAGE_LIMIT)
{
cursor.setPosition(TWITCH_MESSAGE_LIMIT, QTextCursor::MoveAnchor);
cursor.movePosition(QTextCursor::End, QTextCursor::KeepAnchor);
this->lastOverflowLength = text.length();
cursor.setCharFormat(format);
format.setForeground(Qt::red);
selections.append({cursor, format});
}
else if (this->lastOverflowLength != TWITCH_MESSAGE_LIMIT)
// block reemit of QTextEdit::textChanged()
{
this->lastOverflowLength = TWITCH_MESSAGE_LIMIT;
const QSignalBlocker b(this->ui_.textEdit);
this->ui_.textEdit->setExtraSelections(selections);
}
}

View file

@ -52,8 +52,6 @@ public:
QString getInputText() const;
void insertText(const QString &text);
static const int TWITCH_MESSAGE_LIMIT = 500;
void setReply(std::shared_ptr<MessageThread> reply,
bool showInlineReplying = true);
void setPlaceholderText(const QString &text);
@ -151,8 +149,6 @@ protected:
QString currMsg_;
int prevIndex_ = 0;
int lastOverflowLength = TWITCH_MESSAGE_LIMIT;
// Hidden denotes whether this split input should be hidden or not
// This is used instead of the regular QWidget::hide/show because
// focus events don't work as expected, so instead we use this bool and