mirror of https://github.com/procxx/kepka.git
fixed entities update, version 0.8.55 stable
This commit is contained in:
parent
fef40bb59f
commit
ad089cb8da
|
@ -699,13 +699,33 @@ namespace App {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void checkEntitiesUpdate(const MTPDmessage &m) {
|
||||||
|
if (HistoryItem *existing = App::histItemById(m.vid.v)) {
|
||||||
|
bool hasLinks = m.has_entities() && !m.ventities.c_vector().v.isEmpty();
|
||||||
|
if ((hasLinks && !existing->hasTextLinks()) || (!hasLinks && existing->textHasLinks())) {
|
||||||
|
existing->setText(qs(m.vmessage), m.has_entities() ? linksFromMTP(m.ventities.c_vector().v) : LinksInText());
|
||||||
|
existing->initDimensions(0);
|
||||||
|
if (App::main()) App::main()->itemResized(existing);
|
||||||
|
if (existing->hasTextLinks()) {
|
||||||
|
existing->history()->addToOverview(existing, OverviewLinks);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void feedMsgs(const MTPVector<MTPMessage> &msgs, int msgsState) {
|
void feedMsgs(const MTPVector<MTPMessage> &msgs, int msgsState) {
|
||||||
const QVector<MTPMessage> &v(msgs.c_vector().v);
|
const QVector<MTPMessage> &v(msgs.c_vector().v);
|
||||||
QMap<int32, int32> msgsIds;
|
QMap<int32, int32> msgsIds;
|
||||||
for (int32 i = 0, l = v.size(); i < l; ++i) {
|
for (int32 i = 0, l = v.size(); i < l; ++i) {
|
||||||
const MTPMessage &msg(v.at(i));
|
const MTPMessage &msg(v.at(i));
|
||||||
switch (msg.type()) {
|
switch (msg.type()) {
|
||||||
case mtpc_message: msgsIds.insert(msg.c_message().vid.v, i); break;
|
case mtpc_message: {
|
||||||
|
const MTPDmessage &d(msg.c_message());
|
||||||
|
msgsIds.insert(d.vid.v, i);
|
||||||
|
if (msgsState == 1) { // new message, index my forwarded messages to links overview
|
||||||
|
checkEntitiesUpdate(d);
|
||||||
|
}
|
||||||
|
} break;
|
||||||
case mtpc_messageEmpty: msgsIds.insert(msg.c_messageEmpty().vid.v, i); break;
|
case mtpc_messageEmpty: msgsIds.insert(msg.c_messageEmpty().vid.v, i); break;
|
||||||
case mtpc_messageService: msgsIds.insert(msg.c_messageService().vid.v, i); break;
|
case mtpc_messageService: msgsIds.insert(msg.c_messageService().vid.v, i); break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -118,6 +118,7 @@ namespace App {
|
||||||
void feedParticipants(const MTPChatParticipants &p, bool requestBotInfos, bool emitPeerUpdated = true);
|
void feedParticipants(const MTPChatParticipants &p, bool requestBotInfos, bool emitPeerUpdated = true);
|
||||||
void feedParticipantAdd(const MTPDupdateChatParticipantAdd &d, bool emitPeerUpdated = true);
|
void feedParticipantAdd(const MTPDupdateChatParticipantAdd &d, bool emitPeerUpdated = true);
|
||||||
void feedParticipantDelete(const MTPDupdateChatParticipantDelete &d, bool emitPeerUpdated = true);
|
void feedParticipantDelete(const MTPDupdateChatParticipantDelete &d, bool emitPeerUpdated = true);
|
||||||
|
void checkEntitiesUpdate(const MTPDmessage &m);
|
||||||
void feedMsgs(const MTPVector<MTPMessage> &msgs, int msgsState = 0); // 2 - new read message, 1 - new unread message, 0 - not new message, -1 - searched message
|
void feedMsgs(const MTPVector<MTPMessage> &msgs, int msgsState = 0); // 2 - new read message, 1 - new unread message, 0 - not new message, -1 - searched message
|
||||||
void feedWereRead(const QVector<MTPint> &msgsIds);
|
void feedWereRead(const QVector<MTPint> &msgsIds);
|
||||||
void feedInboxRead(const PeerId &peer, int32 upTo);
|
void feedInboxRead(const PeerId &peer, int32 upTo);
|
||||||
|
|
|
@ -644,24 +644,14 @@ HistoryItem *History::createItem(HistoryBlock *block, const MTPmessage &msg, boo
|
||||||
}
|
}
|
||||||
|
|
||||||
const MTPMessageMedia *media = 0;
|
const MTPMessageMedia *media = 0;
|
||||||
const QVector<MTPMessageEntity> *entities = 0;
|
|
||||||
switch (msg.type()) {
|
switch (msg.type()) {
|
||||||
case mtpc_message:
|
case mtpc_message:
|
||||||
media = msg.c_message().has_media() ? (&msg.c_message().vmedia) : 0;
|
media = msg.c_message().has_media() ? (&msg.c_message().vmedia) : 0;
|
||||||
entities = msg.c_message().has_entities() ? (&msg.c_message().ventities.c_vector().v) : 0;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (media) {
|
if (media) {
|
||||||
existing->updateMedia(*media);
|
existing->updateMedia(*media);
|
||||||
}
|
}
|
||||||
if (entities && !existing->hasTextLinks()) { // index forwarded messages to links overview
|
|
||||||
existing->setText(qs(msg.c_message().vmessage), linksFromMTP(*entities));
|
|
||||||
existing->initDimensions(0);
|
|
||||||
if (App::main()) App::main()->itemResized(existing);
|
|
||||||
if (existing->hasTextLinks()) {
|
|
||||||
existing->history()->addToOverview(existing, OverviewLinks);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return (returnExisting || regged) ? existing : 0;
|
return (returnExisting || regged) ? existing : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5249,7 +5239,6 @@ HistoryMessage::HistoryMessage(History *history, HistoryBlock *block, const MTPD
|
||||||
, _textHeight(0)
|
, _textHeight(0)
|
||||||
, _media(0)
|
, _media(0)
|
||||||
{
|
{
|
||||||
//if (msg.has_entities()) msg.ventities.c_vector().v.size()
|
|
||||||
QString text(textClean(qs(msg.vmessage)));
|
QString text(textClean(qs(msg.vmessage)));
|
||||||
initTime();
|
initTime();
|
||||||
initMedia(msg.has_media() ? (&msg.vmedia) : 0, text);
|
initMedia(msg.has_media() ? (&msg.vmedia) : 0, text);
|
||||||
|
@ -5494,6 +5483,10 @@ void HistoryMessage::getTextWithLinks(QString &text, LinksInText &links) {
|
||||||
text = _text.original();
|
text = _text.original();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool HistoryMessage::textHasLinks() {
|
||||||
|
return _text.hasLinks();
|
||||||
|
}
|
||||||
|
|
||||||
void HistoryMessage::draw(QPainter &p, uint32 selection) const {
|
void HistoryMessage::draw(QPainter &p, uint32 selection) const {
|
||||||
textstyleSet(&(out() ? st::outTextStyle : st::inTextStyle));
|
textstyleSet(&(out() ? st::outTextStyle : st::inTextStyle));
|
||||||
|
|
||||||
|
|
|
@ -786,6 +786,9 @@ public:
|
||||||
}
|
}
|
||||||
virtual void getTextWithLinks(QString &text, LinksInText &links) {
|
virtual void getTextWithLinks(QString &text, LinksInText &links) {
|
||||||
}
|
}
|
||||||
|
virtual bool textHasLinks() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
virtual QString time() const {
|
virtual QString time() const {
|
||||||
return QString();
|
return QString();
|
||||||
}
|
}
|
||||||
|
@ -1339,6 +1342,7 @@ public:
|
||||||
void setMedia(const MTPMessageMedia *media);
|
void setMedia(const MTPMessageMedia *media);
|
||||||
void setText(const QString &text, const LinksInText &links);
|
void setText(const QString &text, const LinksInText &links);
|
||||||
void getTextWithLinks(QString &text, LinksInText &links);
|
void getTextWithLinks(QString &text, LinksInText &links);
|
||||||
|
bool textHasLinks();
|
||||||
|
|
||||||
QString time() const {
|
QString time() const {
|
||||||
return _time;
|
return _time;
|
||||||
|
|
|
@ -3414,14 +3414,14 @@ void MainWidget::handleUpdates(const MTPUpdates &updates, uint64 randomId) {
|
||||||
const MTPDupdateShortSentMessage &d(updates.c_updateShortSentMessage());
|
const MTPDupdateShortSentMessage &d(updates.c_updateShortSentMessage());
|
||||||
HistoryItem *item = 0;
|
HistoryItem *item = 0;
|
||||||
if (randomId) {
|
if (randomId) {
|
||||||
QString text = d.has_entities() ? App::histSentTextByItem(randomId) : QString();
|
QString text = App::histSentTextByItem(randomId);
|
||||||
feedUpdate(MTP_updateMessageID(d.vid, MTP_long(randomId))); // ignore real date
|
feedUpdate(MTP_updateMessageID(d.vid, MTP_long(randomId))); // ignore real date
|
||||||
if (!text.isEmpty()) {
|
if (!text.isEmpty()) {
|
||||||
LinksInText links(linksFromMTP(d.ventities.c_vector().v));
|
bool hasLinks = d.has_entities() && !d.ventities.c_vector().v.isEmpty();
|
||||||
item = App::histItemById(d.vid.v);
|
item = App::histItemById(d.vid.v);
|
||||||
if (item && !links.isEmpty()) {
|
if (item && ((hasLinks && !item->hasTextLinks()) || (!hasLinks && item->textHasLinks()))) {
|
||||||
bool was = item->hasTextLinks();
|
bool was = item->hasTextLinks();
|
||||||
item->setText(text, links);
|
item->setText(text, d.has_entities() ? linksFromMTP(d.ventities.c_vector().v) : LinksInText());
|
||||||
item->initDimensions(0);
|
item->initDimensions(0);
|
||||||
itemResized(item);
|
itemResized(item);
|
||||||
if (!was && item->hasTextLinks()) {
|
if (!was && item->hasTextLinks()) {
|
||||||
|
@ -3462,6 +3462,10 @@ void MainWidget::feedUpdate(const MTPUpdate &update) {
|
||||||
_byPtsUpdate.insert(ptsKey(SkippedUpdate), update);
|
_byPtsUpdate.insert(ptsKey(SkippedUpdate), update);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (d.vmessage.type() == mtpc_message) { // index forwarded messages to links overview
|
||||||
|
App::checkEntitiesUpdate(d.vmessage.c_message());
|
||||||
|
}
|
||||||
|
|
||||||
HistoryItem *item = App::histories().addToBack(d.vmessage);
|
HistoryItem *item = App::histories().addToBack(d.vmessage);
|
||||||
if (item) {
|
if (item) {
|
||||||
history.peerMessagesUpdated(item->history()->peer->id);
|
history.peerMessagesUpdated(item->history()->peer->id);
|
||||||
|
|
Loading…
Reference in New Issue