Remove nick colors
This commit is contained in:
parent
18625d9d27
commit
43b1bdfe63
@ -1,10 +1,12 @@
|
|||||||
---
|
---
|
||||||
Language: Cpp
|
Language: Cpp
|
||||||
AccessModifierOffset: -8
|
AccessModifierOffset: -8
|
||||||
AlignAfterOpenBracket: true
|
AlignAfterOpenBracket: Align
|
||||||
|
AlignConsecutiveAssignments: true
|
||||||
AlignEscapedNewlinesLeft: false
|
AlignEscapedNewlinesLeft: false
|
||||||
AlignTrailingComments: false
|
AlignTrailingComments: false
|
||||||
AllowAllParametersOfDeclarationOnNextLine: true
|
AllowAllParametersOfDeclarationOnNextLine: true
|
||||||
|
AllowShortFunctionsOnASingleLine: Empty
|
||||||
AllowShortFunctionsOnASingleLine: None
|
AllowShortFunctionsOnASingleLine: None
|
||||||
AllowShortIfStatementsOnASingleLine: false
|
AllowShortIfStatementsOnASingleLine: false
|
||||||
BasedOnStyle: Mozilla
|
BasedOnStyle: Mozilla
|
||||||
@ -12,10 +14,10 @@ BinPackArguments: false
|
|||||||
BinPackParameters: false
|
BinPackParameters: false
|
||||||
BreakBeforeBraces: Linux
|
BreakBeforeBraces: Linux
|
||||||
BreakConstructorInitializersBeforeComma: true
|
BreakConstructorInitializersBeforeComma: true
|
||||||
ColumnLimit: 120
|
ColumnLimit: 100
|
||||||
ContinuationIndentWidth: 8
|
CompactNamespaces: false
|
||||||
IndentCaseLabels: false
|
IndentCaseLabels: false
|
||||||
IndentWidth: 8
|
IndentWidth: 8
|
||||||
|
KeepEmptyLinesAtTheStartOfBlocks: false
|
||||||
MaxEmptyLinesToKeep: 1
|
MaxEmptyLinesToKeep: 1
|
||||||
PointerAlignment: Right
|
PointerAlignment: Right
|
||||||
UseTab: Always
|
|
||||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -77,3 +77,4 @@ result
|
|||||||
|
|
||||||
*.dmg
|
*.dmg
|
||||||
dist/MacOS/nheko.app/Contents/MacOS/nheko
|
dist/MacOS/nheko.app/Contents/MacOS/nheko
|
||||||
|
.clang
|
||||||
|
@ -40,19 +40,19 @@ class TimelineItem : public QWidget
|
|||||||
public:
|
public:
|
||||||
TimelineItem(const events::MessageEvent<msgs::Notice> &e,
|
TimelineItem(const events::MessageEvent<msgs::Notice> &e,
|
||||||
bool with_sender,
|
bool with_sender,
|
||||||
const QString &color,
|
|
||||||
QWidget *parent = 0);
|
QWidget *parent = 0);
|
||||||
TimelineItem(const events::MessageEvent<msgs::Text> &e,
|
TimelineItem(const events::MessageEvent<msgs::Text> &e,
|
||||||
bool with_sender,
|
bool with_sender,
|
||||||
const QString &color,
|
|
||||||
QWidget *parent = 0);
|
QWidget *parent = 0);
|
||||||
|
|
||||||
// For local messages.
|
// For local messages.
|
||||||
TimelineItem(const QString &userid, const QString &color, QString body, QWidget *parent = 0);
|
TimelineItem(const QString &userid, QString body, QWidget *parent = 0);
|
||||||
TimelineItem(QString body, QWidget *parent = 0);
|
TimelineItem(QString body, QWidget *parent = 0);
|
||||||
|
|
||||||
TimelineItem(ImageItem *img, const events::MessageEvent<msgs::Image> &e, const QString &color, QWidget *parent);
|
TimelineItem(ImageItem *img,
|
||||||
TimelineItem(ImageItem *img, const events::MessageEvent<msgs::Image> &e, QWidget *parent);
|
const events::MessageEvent<msgs::Image> &e,
|
||||||
|
bool with_sender,
|
||||||
|
QWidget *parent);
|
||||||
|
|
||||||
void setUserAvatar(const QImage &pixmap);
|
void setUserAvatar(const QImage &pixmap);
|
||||||
inline DescInfo descriptionMessage() const;
|
inline DescInfo descriptionMessage() const;
|
||||||
@ -63,7 +63,7 @@ private:
|
|||||||
void init();
|
void init();
|
||||||
|
|
||||||
void generateBody(const QString &body);
|
void generateBody(const QString &body);
|
||||||
void generateBody(const QString &userid, const QString &color, const QString &body);
|
void generateBody(const QString &userid, const QString &body);
|
||||||
void generateTimestamp(const QDateTime &time);
|
void generateTimestamp(const QDateTime &time);
|
||||||
QString descriptiveTime(const QDateTime &then);
|
QString descriptiveTime(const QDateTime &then);
|
||||||
|
|
||||||
|
@ -67,16 +67,15 @@ public:
|
|||||||
QSharedPointer<MatrixClient> client,
|
QSharedPointer<MatrixClient> client,
|
||||||
const QString &room_id,
|
const QString &room_id,
|
||||||
QWidget *parent = 0);
|
QWidget *parent = 0);
|
||||||
TimelineView(QSharedPointer<MatrixClient> client, const QString &room_id, QWidget *parent = 0);
|
TimelineView(QSharedPointer<MatrixClient> client,
|
||||||
|
const QString &room_id,
|
||||||
|
QWidget *parent = 0);
|
||||||
|
|
||||||
TimelineItem *createTimelineItem(const events::MessageEvent<msgs::Image> &e,
|
TimelineItem *createTimelineItem(const events::MessageEvent<msgs::Image> &e,
|
||||||
const QString &color,
|
|
||||||
bool with_sender);
|
bool with_sender);
|
||||||
TimelineItem *createTimelineItem(const events::MessageEvent<msgs::Notice> &e,
|
TimelineItem *createTimelineItem(const events::MessageEvent<msgs::Notice> &e,
|
||||||
const QString &color,
|
|
||||||
bool with_sender);
|
bool with_sender);
|
||||||
TimelineItem *createTimelineItem(const events::MessageEvent<msgs::Text> &e,
|
TimelineItem *createTimelineItem(const events::MessageEvent<msgs::Text> &e,
|
||||||
const QString &color,
|
|
||||||
bool with_sender);
|
bool with_sender);
|
||||||
|
|
||||||
// Add new events at the end of the timeline.
|
// Add new events at the end of the timeline.
|
||||||
|
@ -43,10 +43,8 @@ public:
|
|||||||
void clearAll();
|
void clearAll();
|
||||||
|
|
||||||
static QString chooseRandomColor();
|
static QString chooseRandomColor();
|
||||||
static QString getUserColor(const QString &userid);
|
|
||||||
static QString displayName(const QString &userid);
|
static QString displayName(const QString &userid);
|
||||||
|
|
||||||
static QMap<QString, QString> NICK_COLORS;
|
|
||||||
static QMap<QString, QString> DISPLAY_NAMES;
|
static QMap<QString, QString> DISPLAY_NAMES;
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
|
@ -69,7 +69,7 @@ TimelineItem::init()
|
|||||||
/*
|
/*
|
||||||
* For messages created locally. The avatar and the username are displayed.
|
* For messages created locally. The avatar and the username are displayed.
|
||||||
*/
|
*/
|
||||||
TimelineItem::TimelineItem(const QString &userid, const QString &color, QString body, QWidget *parent)
|
TimelineItem::TimelineItem(const QString &userid, QString body, QWidget *parent)
|
||||||
: QWidget(parent)
|
: QWidget(parent)
|
||||||
{
|
{
|
||||||
init();
|
init();
|
||||||
@ -79,7 +79,7 @@ TimelineItem::TimelineItem(const QString &userid, const QString &color, QString
|
|||||||
auto displayName = TimelineViewManager::displayName(userid);
|
auto displayName = TimelineViewManager::displayName(userid);
|
||||||
|
|
||||||
generateTimestamp(QDateTime::currentDateTime());
|
generateTimestamp(QDateTime::currentDateTime());
|
||||||
generateBody(displayName, color, body);
|
generateBody(displayName, body);
|
||||||
|
|
||||||
setupAvatarLayout(displayName);
|
setupAvatarLayout(displayName);
|
||||||
|
|
||||||
@ -116,7 +116,7 @@ TimelineItem::TimelineItem(QString body, QWidget *parent)
|
|||||||
*/
|
*/
|
||||||
TimelineItem::TimelineItem(ImageItem *image,
|
TimelineItem::TimelineItem(ImageItem *image,
|
||||||
const events::MessageEvent<msgs::Image> &event,
|
const events::MessageEvent<msgs::Image> &event,
|
||||||
const QString &color,
|
bool with_sender,
|
||||||
QWidget *parent)
|
QWidget *parent)
|
||||||
: QWidget(parent)
|
: QWidget(parent)
|
||||||
{
|
{
|
||||||
@ -132,46 +132,23 @@ TimelineItem::TimelineItem(ImageItem *image,
|
|||||||
descriptiveTime(QDateTime::fromMSecsSinceEpoch(event.timestamp())) };
|
descriptiveTime(QDateTime::fromMSecsSinceEpoch(event.timestamp())) };
|
||||||
|
|
||||||
generateTimestamp(timestamp);
|
generateTimestamp(timestamp);
|
||||||
generateBody(displayName, color, "");
|
|
||||||
|
|
||||||
setupAvatarLayout(displayName);
|
|
||||||
|
|
||||||
auto imageLayout = new QHBoxLayout();
|
|
||||||
imageLayout->addWidget(image);
|
|
||||||
imageLayout->addStretch(1);
|
|
||||||
|
|
||||||
mainLayout_->addLayout(headerLayout_);
|
|
||||||
mainLayout_->addLayout(imageLayout);
|
|
||||||
|
|
||||||
AvatarProvider::resolve(event.sender(), this);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Used to display images. Only the image is displayed.
|
|
||||||
*/
|
|
||||||
TimelineItem::TimelineItem(ImageItem *image, const events::MessageEvent<msgs::Image> &event, QWidget *parent)
|
|
||||||
: QWidget(parent)
|
|
||||||
{
|
|
||||||
init();
|
|
||||||
|
|
||||||
auto displayName = TimelineViewManager::displayName(event.sender());
|
|
||||||
|
|
||||||
QSettings settings;
|
|
||||||
descriptionMsg_ = { event.sender() == settings.value("auth/user_id") ? "You" : displayName,
|
|
||||||
event.sender(),
|
|
||||||
" sent an image",
|
|
||||||
descriptiveTime(QDateTime::fromMSecsSinceEpoch(event.timestamp())) };
|
|
||||||
|
|
||||||
auto timestamp = QDateTime::fromMSecsSinceEpoch(event.timestamp());
|
|
||||||
generateTimestamp(timestamp);
|
|
||||||
|
|
||||||
setupSimpleLayout();
|
|
||||||
|
|
||||||
auto imageLayout = new QHBoxLayout();
|
auto imageLayout = new QHBoxLayout();
|
||||||
imageLayout->setMargin(0);
|
imageLayout->setMargin(0);
|
||||||
imageLayout->addWidget(image);
|
imageLayout->addWidget(image);
|
||||||
imageLayout->addStretch(1);
|
imageLayout->addStretch(1);
|
||||||
|
|
||||||
|
if (with_sender) {
|
||||||
|
generateBody(displayName, "");
|
||||||
|
setupAvatarLayout(displayName);
|
||||||
|
|
||||||
|
mainLayout_->addLayout(headerLayout_);
|
||||||
|
|
||||||
|
AvatarProvider::resolve(event.sender(), this);
|
||||||
|
} else {
|
||||||
|
setupSimpleLayout();
|
||||||
|
}
|
||||||
|
|
||||||
mainLayout_->addLayout(imageLayout);
|
mainLayout_->addLayout(imageLayout);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -180,7 +157,6 @@ TimelineItem::TimelineItem(ImageItem *image, const events::MessageEvent<msgs::Im
|
|||||||
*/
|
*/
|
||||||
TimelineItem::TimelineItem(const events::MessageEvent<msgs::Notice> &event,
|
TimelineItem::TimelineItem(const events::MessageEvent<msgs::Notice> &event,
|
||||||
bool with_sender,
|
bool with_sender,
|
||||||
const QString &color,
|
|
||||||
QWidget *parent)
|
QWidget *parent)
|
||||||
: QWidget(parent)
|
: QWidget(parent)
|
||||||
{
|
{
|
||||||
@ -201,7 +177,7 @@ TimelineItem::TimelineItem(const events::MessageEvent<msgs::Notice> &event,
|
|||||||
if (with_sender) {
|
if (with_sender) {
|
||||||
auto displayName = TimelineViewManager::displayName(event.sender());
|
auto displayName = TimelineViewManager::displayName(event.sender());
|
||||||
|
|
||||||
generateBody(displayName, color, body);
|
generateBody(displayName, body);
|
||||||
setupAvatarLayout(displayName);
|
setupAvatarLayout(displayName);
|
||||||
|
|
||||||
mainLayout_->addLayout(headerLayout_);
|
mainLayout_->addLayout(headerLayout_);
|
||||||
@ -220,7 +196,6 @@ TimelineItem::TimelineItem(const events::MessageEvent<msgs::Notice> &event,
|
|||||||
*/
|
*/
|
||||||
TimelineItem::TimelineItem(const events::MessageEvent<msgs::Text> &event,
|
TimelineItem::TimelineItem(const events::MessageEvent<msgs::Text> &event,
|
||||||
bool with_sender,
|
bool with_sender,
|
||||||
const QString &color,
|
|
||||||
QWidget *parent)
|
QWidget *parent)
|
||||||
: QWidget(parent)
|
: QWidget(parent)
|
||||||
{
|
{
|
||||||
@ -243,7 +218,7 @@ TimelineItem::TimelineItem(const events::MessageEvent<msgs::Text> &event,
|
|||||||
if (with_sender) {
|
if (with_sender) {
|
||||||
auto displayName = TimelineViewManager::displayName(event.sender());
|
auto displayName = TimelineViewManager::displayName(event.sender());
|
||||||
|
|
||||||
generateBody(displayName, color, body);
|
generateBody(displayName, body);
|
||||||
setupAvatarLayout(displayName);
|
setupAvatarLayout(displayName);
|
||||||
|
|
||||||
mainLayout_->addLayout(headerLayout_);
|
mainLayout_->addLayout(headerLayout_);
|
||||||
@ -275,7 +250,7 @@ TimelineItem::generateBody(const QString &body)
|
|||||||
|
|
||||||
// The username/timestamp is displayed along with the message body.
|
// The username/timestamp is displayed along with the message body.
|
||||||
void
|
void
|
||||||
TimelineItem::generateBody(const QString &userid, const QString &color, const QString &body)
|
TimelineItem::generateBody(const QString &userid, const QString &body)
|
||||||
{
|
{
|
||||||
auto sender = userid;
|
auto sender = userid;
|
||||||
|
|
||||||
@ -283,7 +258,7 @@ TimelineItem::generateBody(const QString &userid, const QString &color, const QS
|
|||||||
if (userid.split(":")[0].split("@").size() > 1)
|
if (userid.split(":")[0].split("@").size() > 1)
|
||||||
sender = userid.split(":")[0].split("@")[1];
|
sender = userid.split(":")[0].split("@")[1];
|
||||||
|
|
||||||
QString userContent("<span style=\"color: %1\"> %2 </span>");
|
QString userContent("<span style=\"color: #171717\"> %1 </span>");
|
||||||
QString bodyContent("<span style=\"color: #171717;\"> %1 </span>");
|
QString bodyContent("<span style=\"color: #171717;\"> %1 </span>");
|
||||||
|
|
||||||
QFont usernameFont = font_;
|
QFont usernameFont = font_;
|
||||||
@ -291,7 +266,7 @@ TimelineItem::generateBody(const QString &userid, const QString &color, const QS
|
|||||||
|
|
||||||
userName_ = new QLabel(this);
|
userName_ = new QLabel(this);
|
||||||
userName_->setFont(usernameFont);
|
userName_->setFont(usernameFont);
|
||||||
userName_->setText(userContent.arg(color).arg(sender));
|
userName_->setText(userContent.arg(sender));
|
||||||
|
|
||||||
if (body.isEmpty())
|
if (body.isEmpty())
|
||||||
return;
|
return;
|
||||||
@ -332,7 +307,8 @@ TimelineItem::replaceEmoji(const QString &body)
|
|||||||
|
|
||||||
// TODO: Be more precise here.
|
// TODO: Be more precise here.
|
||||||
if (code > 9000)
|
if (code > 9000)
|
||||||
fmtBody += QString("<span style=\"font-family: Emoji One; font-size: %1px\">")
|
fmtBody += QString("<span style=\"font-family: Emoji "
|
||||||
|
"One; font-size: %1px\">")
|
||||||
.arg(conf::emojiSize) +
|
.arg(conf::emojiSize) +
|
||||||
QString(c) + "</span>";
|
QString(c) + "</span>";
|
||||||
else
|
else
|
||||||
@ -376,15 +352,18 @@ TimelineItem::setupSimpleLayout()
|
|||||||
timestamp_->adjustSize();
|
timestamp_->adjustSize();
|
||||||
|
|
||||||
// Align the end of the avatar bubble with the end of the timestamp for
|
// Align the end of the avatar bubble with the end of the timestamp for
|
||||||
// messages with and without avatar. Otherwise their bodies would not be aligned.
|
// messages with and without avatar. Otherwise their bodies would not be
|
||||||
|
// aligned.
|
||||||
int tsWidth = timestamp_->fontMetrics().width(plainText);
|
int tsWidth = timestamp_->fontMetrics().width(plainText);
|
||||||
int offset = std::max(0, conf::timeline::avatarSize - tsWidth);
|
int offset = std::max(0, conf::timeline::avatarSize - tsWidth);
|
||||||
|
|
||||||
int defaultFontHeight = QFontMetrics(font_).ascent();
|
int defaultFontHeight = QFontMetrics(font_).ascent();
|
||||||
|
|
||||||
timestamp_->setAlignment(Qt::AlignTop);
|
timestamp_->setAlignment(Qt::AlignTop);
|
||||||
timestamp_->setContentsMargins(offset + 1, defaultFontHeight - timestamp_->fontMetrics().ascent(), 0, 0);
|
timestamp_->setContentsMargins(
|
||||||
topLayout_->setContentsMargins(conf::timeline::msgMargin, conf::timeline::msgMargin / 3, 0, 0);
|
offset + 1, defaultFontHeight - timestamp_->fontMetrics().ascent(), 0, 0);
|
||||||
|
topLayout_->setContentsMargins(
|
||||||
|
conf::timeline::msgMargin, conf::timeline::msgMargin / 3, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -403,13 +382,12 @@ TimelineItem::descriptiveTime(const QDateTime &then)
|
|||||||
|
|
||||||
auto days = then.daysTo(now);
|
auto days = then.daysTo(now);
|
||||||
|
|
||||||
if (days == 0) {
|
if (days == 0)
|
||||||
return then.toString("HH:mm");
|
return then.toString("HH:mm");
|
||||||
} else if (days < 2) {
|
else if (days < 2)
|
||||||
return QString("Yesterday");
|
return QString("Yesterday");
|
||||||
} else if (days < 365) {
|
else if (days < 365)
|
||||||
return then.toString("dd/MM");
|
return then.toString("dd/MM");
|
||||||
}
|
|
||||||
|
|
||||||
return then.toString("dd/MM/yy");
|
return then.toString("dd/MM/yy");
|
||||||
}
|
}
|
||||||
|
@ -49,7 +49,9 @@ TimelineView::TimelineView(const Timeline &timeline,
|
|||||||
addEvents(timeline);
|
addEvents(timeline);
|
||||||
}
|
}
|
||||||
|
|
||||||
TimelineView::TimelineView(QSharedPointer<MatrixClient> client, const QString &room_id, QWidget *parent)
|
TimelineView::TimelineView(QSharedPointer<MatrixClient> client,
|
||||||
|
const QString &room_id,
|
||||||
|
QWidget *parent)
|
||||||
: QWidget(parent)
|
: QWidget(parent)
|
||||||
, room_id_{ room_id }
|
, room_id_{ room_id }
|
||||||
, client_{ client }
|
, client_{ client }
|
||||||
@ -118,7 +120,8 @@ TimelineView::scrollDown()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// If the gap is small enough move the scroll bar down. e.g when a new message appears.
|
// If the gap is small enough move the scroll bar down. e.g when a new
|
||||||
|
// message appears.
|
||||||
if (max - current < SCROLL_BAR_GAP)
|
if (max - current < SCROLL_BAR_GAP)
|
||||||
scroll_area_->verticalScrollBar()->setValue(max);
|
scroll_area_->verticalScrollBar()->setValue(max);
|
||||||
}
|
}
|
||||||
@ -134,14 +137,16 @@ TimelineView::sliderMoved(int position)
|
|||||||
if (isTimelineFinished)
|
if (isTimelineFinished)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Prevent user from moving up when there is pagination in progress.
|
// Prevent user from moving up when there is pagination in
|
||||||
|
// progress.
|
||||||
// TODO: Keep a map of the event ids to filter out duplicates.
|
// TODO: Keep a map of the event ids to filter out duplicates.
|
||||||
if (isPaginationInProgress_)
|
if (isPaginationInProgress_)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
isPaginationInProgress_ = true;
|
isPaginationInProgress_ = true;
|
||||||
|
|
||||||
// FIXME: Maybe move this to TimelineViewManager to remove the extra calls?
|
// FIXME: Maybe move this to TimelineViewManager to remove the
|
||||||
|
// extra calls?
|
||||||
client_->messages(room_id_, prev_batch_token_);
|
client_->messages(room_id_, prev_batch_token_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -160,7 +165,8 @@ TimelineView::addBackwardsEvents(const QString &room_id, const RoomMessages &msg
|
|||||||
isTimelineFinished = false;
|
isTimelineFinished = false;
|
||||||
QList<TimelineItem *> items;
|
QList<TimelineItem *> items;
|
||||||
|
|
||||||
// Parse in reverse order to determine where we should not show sender's name.
|
// Parse in reverse order to determine where we should not show sender's
|
||||||
|
// name.
|
||||||
auto it = msgs.chunk().constEnd();
|
auto it = msgs.chunk().constEnd();
|
||||||
while (it != msgs.chunk().constBegin()) {
|
while (it != msgs.chunk().constBegin()) {
|
||||||
--it;
|
--it;
|
||||||
@ -188,8 +194,8 @@ TimelineView::addBackwardsEvents(const QString &room_id, const RoomMessages &msg
|
|||||||
if (!msgs.chunk().isEmpty() && scroll_layout_->count() > 1)
|
if (!msgs.chunk().isEmpty() && scroll_layout_->count() > 1)
|
||||||
notifyForLastEvent();
|
notifyForLastEvent();
|
||||||
|
|
||||||
// If this batch is the first being rendered (i.e the first and the last events
|
// If this batch is the first being rendered (i.e the first and the last
|
||||||
// originate from this batch), set the last sender.
|
// events originate from this batch), set the last sender.
|
||||||
if (lastSender_.isEmpty() && !items.isEmpty())
|
if (lastSender_.isEmpty() && !items.isEmpty())
|
||||||
lastSender_ = items.constFirst()->descriptionMessage().userid;
|
lastSender_ = items.constFirst()->descriptionMessage().userid;
|
||||||
}
|
}
|
||||||
@ -223,11 +229,10 @@ TimelineView::parseMessageEvent(const QJsonObject &event, TimelineDirection dire
|
|||||||
}
|
}
|
||||||
|
|
||||||
auto with_sender = isSenderRendered(text.sender(), direction);
|
auto with_sender = isSenderRendered(text.sender(), direction);
|
||||||
auto color = TimelineViewManager::getUserColor(text.sender());
|
|
||||||
|
|
||||||
updateLastSender(text.sender(), direction);
|
updateLastSender(text.sender(), direction);
|
||||||
|
|
||||||
return createTimelineItem(text, color, with_sender);
|
return createTimelineItem(text, with_sender);
|
||||||
} else if (msg_type == events::MessageEventType::Notice) {
|
} else if (msg_type == events::MessageEventType::Notice) {
|
||||||
events::MessageEvent<msgs::Notice> notice;
|
events::MessageEvent<msgs::Notice> notice;
|
||||||
|
|
||||||
@ -245,11 +250,10 @@ TimelineView::parseMessageEvent(const QJsonObject &event, TimelineDirection dire
|
|||||||
eventIds_[notice.eventId()] = true;
|
eventIds_[notice.eventId()] = true;
|
||||||
|
|
||||||
auto with_sender = isSenderRendered(notice.sender(), direction);
|
auto with_sender = isSenderRendered(notice.sender(), direction);
|
||||||
auto color = TimelineViewManager::getUserColor(notice.sender());
|
|
||||||
|
|
||||||
updateLastSender(notice.sender(), direction);
|
updateLastSender(notice.sender(), direction);
|
||||||
|
|
||||||
return createTimelineItem(notice, color, with_sender);
|
return createTimelineItem(notice, with_sender);
|
||||||
} else if (msg_type == events::MessageEventType::Image) {
|
} else if (msg_type == events::MessageEventType::Image) {
|
||||||
events::MessageEvent<msgs::Image> img;
|
events::MessageEvent<msgs::Image> img;
|
||||||
|
|
||||||
@ -266,11 +270,10 @@ TimelineView::parseMessageEvent(const QJsonObject &event, TimelineDirection dire
|
|||||||
eventIds_[img.eventId()] = true;
|
eventIds_[img.eventId()] = true;
|
||||||
|
|
||||||
auto with_sender = isSenderRendered(img.sender(), direction);
|
auto with_sender = isSenderRendered(img.sender(), direction);
|
||||||
auto color = TimelineViewManager::getUserColor(img.sender());
|
|
||||||
|
|
||||||
updateLastSender(img.sender(), direction);
|
updateLastSender(img.sender(), direction);
|
||||||
|
|
||||||
return createTimelineItem(img, color, with_sender);
|
return createTimelineItem(img, with_sender);
|
||||||
} else if (msg_type == events::MessageEventType::Unknown) {
|
} else if (msg_type == events::MessageEventType::Unknown) {
|
||||||
qWarning() << "Unknown message type" << event;
|
qWarning() << "Unknown message type" << event;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
@ -344,9 +347,15 @@ TimelineView::init()
|
|||||||
paginationTimer_ = new QTimer(this);
|
paginationTimer_ = new QTimer(this);
|
||||||
connect(paginationTimer_, &QTimer::timeout, this, &TimelineView::fetchHistory);
|
connect(paginationTimer_, &QTimer::timeout, this, &TimelineView::fetchHistory);
|
||||||
|
|
||||||
connect(client_.data(), &MatrixClient::messagesRetrieved, this, &TimelineView::addBackwardsEvents);
|
connect(client_.data(),
|
||||||
|
&MatrixClient::messagesRetrieved,
|
||||||
|
this,
|
||||||
|
&TimelineView::addBackwardsEvents);
|
||||||
|
|
||||||
connect(scroll_area_->verticalScrollBar(), SIGNAL(valueChanged(int)), this, SLOT(sliderMoved(int)));
|
connect(scroll_area_->verticalScrollBar(),
|
||||||
|
SIGNAL(valueChanged(int)),
|
||||||
|
this,
|
||||||
|
SLOT(sliderMoved(int)));
|
||||||
connect(scroll_area_->verticalScrollBar(),
|
connect(scroll_area_->verticalScrollBar(),
|
||||||
SIGNAL(rangeChanged(int, int)),
|
SIGNAL(rangeChanged(int, int)),
|
||||||
this,
|
this,
|
||||||
@ -372,32 +381,25 @@ TimelineView::isSenderRendered(const QString &user_id, TimelineDirection directi
|
|||||||
}
|
}
|
||||||
|
|
||||||
TimelineItem *
|
TimelineItem *
|
||||||
TimelineView::createTimelineItem(const events::MessageEvent<msgs::Image> &event, const QString &color, bool with_sender)
|
TimelineView::createTimelineItem(const events::MessageEvent<msgs::Image> &event, bool with_sender)
|
||||||
{
|
{
|
||||||
auto image = new ImageItem(client_, event);
|
auto image = new ImageItem(client_, event);
|
||||||
|
auto item = new TimelineItem(image, event, with_sender, scroll_widget_);
|
||||||
|
|
||||||
if (with_sender) {
|
|
||||||
auto item = new TimelineItem(image, event, color, scroll_widget_);
|
|
||||||
return item;
|
|
||||||
}
|
|
||||||
|
|
||||||
auto item = new TimelineItem(image, event, scroll_widget_);
|
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
TimelineItem *
|
TimelineItem *
|
||||||
TimelineView::createTimelineItem(const events::MessageEvent<msgs::Notice> &event,
|
TimelineView::createTimelineItem(const events::MessageEvent<msgs::Notice> &event, bool with_sender)
|
||||||
const QString &color,
|
|
||||||
bool with_sender)
|
|
||||||
{
|
{
|
||||||
TimelineItem *item = new TimelineItem(event, with_sender, color, scroll_widget_);
|
TimelineItem *item = new TimelineItem(event, with_sender, scroll_widget_);
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
TimelineItem *
|
TimelineItem *
|
||||||
TimelineView::createTimelineItem(const events::MessageEvent<msgs::Text> &event, const QString &color, bool with_sender)
|
TimelineView::createTimelineItem(const events::MessageEvent<msgs::Text> &event, bool with_sender)
|
||||||
{
|
{
|
||||||
TimelineItem *item = new TimelineItem(event, with_sender, color, scroll_widget_);
|
TimelineItem *item = new TimelineItem(event, with_sender, scroll_widget_);
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -422,7 +424,8 @@ TimelineView::updatePendingMessage(int txn_id, QString event_id)
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
TimelineView::isPendingMessage(const events::MessageEvent<msgs::Text> &e, const QString &local_userid)
|
TimelineView::isPendingMessage(const events::MessageEvent<msgs::Text> &e,
|
||||||
|
const QString &local_userid)
|
||||||
{
|
{
|
||||||
if (e.sender() != local_userid)
|
if (e.sender() != local_userid)
|
||||||
return false;
|
return false;
|
||||||
@ -455,12 +458,11 @@ TimelineView::addUserTextMessage(const QString &body, int txn_id)
|
|||||||
auto user_id = settings.value("auth/user_id").toString();
|
auto user_id = settings.value("auth/user_id").toString();
|
||||||
|
|
||||||
auto with_sender = lastSender_ != user_id;
|
auto with_sender = lastSender_ != user_id;
|
||||||
auto color = TimelineViewManager::getUserColor(user_id);
|
|
||||||
|
|
||||||
TimelineItem *view_item;
|
TimelineItem *view_item;
|
||||||
|
|
||||||
if (with_sender)
|
if (with_sender)
|
||||||
view_item = new TimelineItem(user_id, color, body, scroll_widget_);
|
view_item = new TimelineItem(user_id, body, scroll_widget_);
|
||||||
else
|
else
|
||||||
view_item = new TimelineItem(body, scroll_widget_);
|
view_item = new TimelineItem(body, scroll_widget_);
|
||||||
|
|
||||||
|
@ -66,8 +66,6 @@ TimelineViewManager::sendTextMessage(const QString &msg)
|
|||||||
void
|
void
|
||||||
TimelineViewManager::clearAll()
|
TimelineViewManager::clearAll()
|
||||||
{
|
{
|
||||||
NICK_COLORS.clear();
|
|
||||||
|
|
||||||
for (auto view : views_)
|
for (auto view : views_)
|
||||||
removeWidget(view.data());
|
removeWidget(view.data());
|
||||||
|
|
||||||
@ -155,7 +153,6 @@ TimelineViewManager::setHistoryView(const QString &room_id)
|
|||||||
view->scrollDown();
|
view->scrollDown();
|
||||||
}
|
}
|
||||||
|
|
||||||
QMap<QString, QString> TimelineViewManager::NICK_COLORS;
|
|
||||||
QMap<QString, QString> TimelineViewManager::DISPLAY_NAMES;
|
QMap<QString, QString> TimelineViewManager::DISPLAY_NAMES;
|
||||||
|
|
||||||
QString
|
QString
|
||||||
@ -216,19 +213,6 @@ TimelineViewManager::chooseRandomColor()
|
|||||||
return color.name();
|
return color.name();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString
|
|
||||||
TimelineViewManager::getUserColor(const QString &userid)
|
|
||||||
{
|
|
||||||
auto color = NICK_COLORS.value(userid);
|
|
||||||
|
|
||||||
if (color.isEmpty()) {
|
|
||||||
color = chooseRandomColor();
|
|
||||||
NICK_COLORS.insert(userid, color);
|
|
||||||
}
|
|
||||||
|
|
||||||
return color;
|
|
||||||
}
|
|
||||||
|
|
||||||
QString
|
QString
|
||||||
TimelineViewManager::displayName(const QString &userid)
|
TimelineViewManager::displayName(const QString &userid)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user