mirror of
https://github.com/Chatterino/chatterino2.git
synced 2024-11-21 22:24:07 +01:00
added wip effect for (dis/re)connected messages
This commit is contained in:
parent
96328a5e25
commit
fc93d7b738
9 changed files with 172 additions and 22 deletions
|
@ -22,11 +22,12 @@ enum class MessageFlag : uint16_t {
|
||||||
Disabled = (1 << 5),
|
Disabled = (1 << 5),
|
||||||
DisableCompactEmotes = (1 << 6),
|
DisableCompactEmotes = (1 << 6),
|
||||||
Collapsed = (1 << 7),
|
Collapsed = (1 << 7),
|
||||||
DisconnectedMessage = (1 << 8),
|
ConnectedMessage = (1 << 8),
|
||||||
Untimeout = (1 << 9),
|
DisconnectedMessage = (1 << 9),
|
||||||
PubSub = (1 << 10),
|
Untimeout = (1 << 10),
|
||||||
Subscription = (1 << 11),
|
PubSub = (1 << 11),
|
||||||
Notification = (1 << 12),
|
Subscription = (1 << 12),
|
||||||
|
Notification = (1 << 13),
|
||||||
};
|
};
|
||||||
using MessageFlags = FlagsEnum<MessageFlag>;
|
using MessageFlags = FlagsEnum<MessageFlag>;
|
||||||
|
|
||||||
|
|
|
@ -73,6 +73,23 @@ MessageElement *MessageElement::updateLink()
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Empty
|
||||||
|
EmptyElement::EmptyElement()
|
||||||
|
: MessageElement(MessageElementFlag::None)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void EmptyElement::addToContainer(MessageLayoutContainer &container,
|
||||||
|
MessageElementFlags flags)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
EmptyElement &EmptyElement::instance()
|
||||||
|
{
|
||||||
|
static EmptyElement instance;
|
||||||
|
return instance;
|
||||||
|
}
|
||||||
|
|
||||||
// IMAGE
|
// IMAGE
|
||||||
ImageElement::ImageElement(ImagePtr image, MessageElementFlags flags)
|
ImageElement::ImageElement(ImagePtr image, MessageElementFlags flags)
|
||||||
: MessageElement(flags)
|
: MessageElement(flags)
|
||||||
|
|
|
@ -148,6 +148,21 @@ private:
|
||||||
MessageElementFlags flags_;
|
MessageElementFlags flags_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// used when layout element doesn't have a creator
|
||||||
|
class EmptyElement : public MessageElement
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
EmptyElement();
|
||||||
|
|
||||||
|
void addToContainer(MessageLayoutContainer &container,
|
||||||
|
MessageElementFlags flags) override;
|
||||||
|
|
||||||
|
static EmptyElement &instance();
|
||||||
|
|
||||||
|
private:
|
||||||
|
ImagePtr image_;
|
||||||
|
};
|
||||||
|
|
||||||
// contains a simple image
|
// contains a simple image
|
||||||
class ImageElement : public MessageElement
|
class ImageElement : public MessageElement
|
||||||
{
|
{
|
||||||
|
|
|
@ -103,6 +103,9 @@ void MessageLayout::actuallyLayout(int width, MessageElementFlags _flags)
|
||||||
{
|
{
|
||||||
this->layoutCount_++;
|
this->layoutCount_++;
|
||||||
|
|
||||||
|
const auto addTest = this->message_->flags.hasAny(
|
||||||
|
{MessageFlag::DisconnectedMessage, MessageFlag::ConnectedMessage});
|
||||||
|
|
||||||
auto messageFlags = this->message_->flags;
|
auto messageFlags = this->message_->flags;
|
||||||
|
|
||||||
if (this->flags.has(MessageLayoutFlag::Expanded) ||
|
if (this->flags.has(MessageLayoutFlag::Expanded) ||
|
||||||
|
@ -114,11 +117,27 @@ void MessageLayout::actuallyLayout(int width, MessageElementFlags _flags)
|
||||||
|
|
||||||
this->container_->begin(width, this->scale_, messageFlags);
|
this->container_->begin(width, this->scale_, messageFlags);
|
||||||
|
|
||||||
|
if (addTest)
|
||||||
|
{
|
||||||
|
this->container_->addElementNoLineBreak(new TestLayoutElement(
|
||||||
|
EmptyElement::instance(), QSize(width, this->scale_ * 6),
|
||||||
|
getTheme()->messages.backgrounds.regular, false));
|
||||||
|
this->container_->breakLine();
|
||||||
|
}
|
||||||
|
|
||||||
for (const auto &element : this->message_->elements)
|
for (const auto &element : this->message_->elements)
|
||||||
{
|
{
|
||||||
element->addToContainer(*this->container_, _flags);
|
element->addToContainer(*this->container_, _flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (addTest)
|
||||||
|
{
|
||||||
|
this->container_->breakLine();
|
||||||
|
this->container_->addElement(new TestLayoutElement(
|
||||||
|
EmptyElement::instance(), QSize(width, this->scale_ * 6),
|
||||||
|
getTheme()->messages.backgrounds.regular, true));
|
||||||
|
}
|
||||||
|
|
||||||
if (this->height_ != this->container_->getHeight())
|
if (this->height_ != this->container_->getHeight())
|
||||||
{
|
{
|
||||||
this->deleteBuffer();
|
this->deleteBuffer();
|
||||||
|
@ -179,6 +198,11 @@ void MessageLayout::paint(QPainter &painter, int width, int y, int messageIndex,
|
||||||
{
|
{
|
||||||
painter.fillRect(0, y, pixmap->width(), pixmap->height(),
|
painter.fillRect(0, y, pixmap->width(), pixmap->height(),
|
||||||
app->themes->messages.disabled);
|
app->themes->messages.disabled);
|
||||||
|
// painter.fillRect(0, y, pixmap->width(), pixmap->height(),
|
||||||
|
// QBrush(QColor(64, 64, 64, 64)));
|
||||||
|
painter.fillRect(0, y, pixmap->width(), pixmap->height(),
|
||||||
|
QBrush(QColor(255, 0, 0, 63), Qt::BDiagPattern));
|
||||||
|
// app->themes->messages.disabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
// draw selection
|
// draw selection
|
||||||
|
|
|
@ -157,7 +157,7 @@ void MessageLayoutContainer::breakLine()
|
||||||
int yExtra = 0;
|
int yExtra = 0;
|
||||||
if (isCompactEmote)
|
if (isCompactEmote)
|
||||||
{
|
{
|
||||||
yExtra = (COMPACT_EMOTES_OFFSET / 2) * this->scale_;
|
// yExtra = (COMPACT_EMOTES_OFFSET / 2) * this->scale_;
|
||||||
}
|
}
|
||||||
|
|
||||||
// if (element->getCreator().getFlags() &
|
// if (element->getCreator().getFlags() &
|
||||||
|
@ -165,7 +165,8 @@ void MessageLayoutContainer::breakLine()
|
||||||
// {
|
// {
|
||||||
if (element->getRect().height() < this->textLineHeight_)
|
if (element->getRect().height() < this->textLineHeight_)
|
||||||
{
|
{
|
||||||
yExtra -= (this->textLineHeight_ - element->getRect().height()) / 2;
|
// yExtra -= (this->textLineHeight_ - element->getRect().height()) /
|
||||||
|
// 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
element->setPosition(
|
element->setPosition(
|
||||||
|
|
|
@ -366,4 +366,72 @@ int TextIconLayoutElement::getXFromIndex(int index)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TestLayoutElement
|
||||||
|
TestLayoutElement::TestLayoutElement(MessageElement &element, const QSize &size,
|
||||||
|
const QColor &background, bool end)
|
||||||
|
: MessageLayoutElement(element, size)
|
||||||
|
, size_(size)
|
||||||
|
, background_(background)
|
||||||
|
, end_(end)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestLayoutElement::addCopyTextToString(QString &str, int from,
|
||||||
|
int to) const
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
int TestLayoutElement::getSelectionIndexCount() const
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestLayoutElement::paint(QPainter &painter)
|
||||||
|
{
|
||||||
|
const auto dy = this->getRect().y();
|
||||||
|
const auto color = end_ ? background_ : QColor(0, 0, 0, 127);
|
||||||
|
|
||||||
|
// make zig zag
|
||||||
|
auto polygon = QPolygon();
|
||||||
|
for (auto x = size_.height() / -2; x < size_.width() + 16;
|
||||||
|
x += size_.height())
|
||||||
|
{
|
||||||
|
polygon.push_back({x, dy + 0});
|
||||||
|
polygon.push_back({x + size_.height(), dy + size_.height()});
|
||||||
|
x += size_.height();
|
||||||
|
polygon.push_back({x, dy + size_.height()});
|
||||||
|
polygon.push_back({x + size_.height(), dy + 0});
|
||||||
|
}
|
||||||
|
|
||||||
|
// finish polygon
|
||||||
|
polygon.push_back({size_.width(), 1000});
|
||||||
|
polygon.push_back({0, 1000});
|
||||||
|
|
||||||
|
// finish polygon
|
||||||
|
polygon.push_back({size_.width(), 1000});
|
||||||
|
polygon.push_back({0, 1000});
|
||||||
|
|
||||||
|
// turn into path
|
||||||
|
auto path = QPainterPath();
|
||||||
|
path.addPolygon(polygon);
|
||||||
|
|
||||||
|
// draw
|
||||||
|
painter.fillPath(path, color);
|
||||||
|
painter.strokePath(path, QColor(127, 127, 127, 127));
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestLayoutElement::paintAnimated(QPainter &painter, int yOffset)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
int TestLayoutElement::getMouseOverIndex(const QPoint &abs) const
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int TestLayoutElement::getXFromIndex(int index)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace chatterino
|
} // namespace chatterino
|
||||||
|
|
|
@ -125,4 +125,25 @@ private:
|
||||||
QString line2;
|
QString line2;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class TestLayoutElement : public MessageLayoutElement
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
TestLayoutElement(MessageElement &creator, const QSize &size,
|
||||||
|
const QColor &background, bool end);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void addCopyTextToString(QString &str, int from = 0,
|
||||||
|
int to = INT_MAX) const override;
|
||||||
|
int getSelectionIndexCount() const override;
|
||||||
|
void paint(QPainter &painter) override;
|
||||||
|
void paintAnimated(QPainter &painter, int yOffset) override;
|
||||||
|
int getMouseOverIndex(const QPoint &abs) const override;
|
||||||
|
int getXFromIndex(int index) override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
QSize size_;
|
||||||
|
QColor background_;
|
||||||
|
bool end_;
|
||||||
|
};
|
||||||
|
|
||||||
} // namespace chatterino
|
} // namespace chatterino
|
||||||
|
|
|
@ -231,8 +231,11 @@ void AbstractIrcServer::onConnected()
|
||||||
{
|
{
|
||||||
std::lock_guard<std::mutex> lock(this->channelMutex);
|
std::lock_guard<std::mutex> lock(this->channelMutex);
|
||||||
|
|
||||||
auto connected = makeSystemMessage("connected to chat");
|
auto connected = makeSystemMessage("connected");
|
||||||
auto reconnected = makeSystemMessage("reconnected to chat");
|
connected->flags.set(MessageFlag::ConnectedMessage);
|
||||||
|
connected->flags.set(MessageFlag::Centered);
|
||||||
|
auto reconnected = makeSystemMessage("reconnected");
|
||||||
|
reconnected->flags.set(MessageFlag::ConnectedMessage);
|
||||||
|
|
||||||
for (std::weak_ptr<Channel> &weak : this->channels.values())
|
for (std::weak_ptr<Channel> &weak : this->channels.values())
|
||||||
{
|
{
|
||||||
|
@ -244,14 +247,13 @@ void AbstractIrcServer::onConnected()
|
||||||
|
|
||||||
LimitedQueueSnapshot<MessagePtr> snapshot = chan->getMessageSnapshot();
|
LimitedQueueSnapshot<MessagePtr> snapshot = chan->getMessageSnapshot();
|
||||||
|
|
||||||
bool replaceMessage = snapshot.size() > 0 &&
|
bool replaceMessage =
|
||||||
snapshot[snapshot.size() - 1]->flags.has(
|
snapshot.size() > 0 && snapshot[snapshot.size() - 1]->flags.has(
|
||||||
MessageFlag::DisconnectedMessage);
|
MessageFlag::DisconnectedMessage);
|
||||||
|
|
||||||
if (replaceMessage)
|
if (replaceMessage)
|
||||||
{
|
{
|
||||||
chan->replaceMessage(snapshot[snapshot.size() - 1],
|
chan->replaceMessage(snapshot[snapshot.size() - 1], reconnected);
|
||||||
reconnected);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -265,7 +267,7 @@ void AbstractIrcServer::onDisconnected()
|
||||||
{
|
{
|
||||||
std::lock_guard<std::mutex> lock(this->channelMutex);
|
std::lock_guard<std::mutex> lock(this->channelMutex);
|
||||||
|
|
||||||
MessageBuilder b(systemMessage, "disconnected from chat");
|
MessageBuilder b(systemMessage, "disconnected");
|
||||||
b->flags.set(MessageFlag::DisconnectedMessage);
|
b->flags.set(MessageFlag::DisconnectedMessage);
|
||||||
auto disconnected = b.release();
|
auto disconnected = b.release();
|
||||||
|
|
||||||
|
|
|
@ -264,17 +264,18 @@ void ChannelView::updatePauseTimer()
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/// Get the maximum pause
|
/// Get the maximum pause
|
||||||
auto max = std::max_element(
|
auto pauseEnd =
|
||||||
this->pauses_.begin(), this->pauses_.end(),
|
std::max_element(
|
||||||
[](auto &&a, auto &&b) { return a.second > b.second; })
|
this->pauses_.begin(), this->pauses_.end(),
|
||||||
->second.get();
|
[](auto &&a, auto &&b) { return a.second > b.second; })
|
||||||
|
->second.get();
|
||||||
|
|
||||||
if (max != this->pauseEnd_)
|
if (pauseEnd != this->pauseEnd_)
|
||||||
{
|
{
|
||||||
/// Start the timer
|
/// Start the timer
|
||||||
this->pauseEnd_ = max;
|
this->pauseEnd_ = pauseEnd;
|
||||||
this->pauseTimer_.start(
|
this->pauseTimer_.start(
|
||||||
duration_cast<milliseconds>(max - SteadyClock::now()));
|
duration_cast<milliseconds>(pauseEnd - SteadyClock::now()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue