From 233cc412accf768188992d39918a9a97b28ccdac Mon Sep 17 00:00:00 2001 From: Diadlo Date: Sat, 30 Jul 2016 16:14:18 +0300 Subject: [PATCH 1/2] refactor(filetransferwidget): Added ability to check activity --- src/chatlog/content/filetransferwidget.cpp | 8 ++++++++ src/chatlog/content/filetransferwidget.h | 3 +++ 2 files changed, 11 insertions(+) diff --git a/src/chatlog/content/filetransferwidget.cpp b/src/chatlog/content/filetransferwidget.cpp index 702763786..fade6857e 100644 --- a/src/chatlog/content/filetransferwidget.cpp +++ b/src/chatlog/content/filetransferwidget.cpp @@ -47,6 +47,7 @@ FileTransferWidget::FileTransferWidget(QWidget *parent, ToxFile file) , lastTick(QTime::currentTime()) , backgroundColor(Style::getColor(Style::LightGrey)) , buttonColor(Style::getColor(Style::Yellow)) + , active(true) { ui->setupUi(this); @@ -132,6 +133,11 @@ void FileTransferWidget::autoAcceptTransfer(const QString &path) qWarning() << "Cannot write to " << filepath; } +bool FileTransferWidget::isActive() const +{ + return active; +} + void FileTransferWidget::acceptTransfer(const QString &filepath) { if (filepath.isEmpty()) @@ -292,6 +298,7 @@ void FileTransferWidget::onFileTransferCancelled(ToxFile file) return; fileInfo = file; + active = false; setBackgroundColor(Style::getColor(Style::Red), true); @@ -347,6 +354,7 @@ void FileTransferWidget::onFileTransferFinished(ToxFile file) return; fileInfo = file; + active = false; setBackgroundColor(Style::getColor(Style::Green), true); diff --git a/src/chatlog/content/filetransferwidget.h b/src/chatlog/content/filetransferwidget.h index 3f8ba4bbf..26e609cc6 100644 --- a/src/chatlog/content/filetransferwidget.h +++ b/src/chatlog/content/filetransferwidget.h @@ -42,6 +42,7 @@ public: explicit FileTransferWidget(QWidget *parent, ToxFile file); virtual ~FileTransferWidget(); void autoAcceptTransfer(const QString& path); + bool isActive() const; protected slots: void onFileTransferInfo(ToxFile file); @@ -88,6 +89,8 @@ private: static const uint8_t TRANSFER_ROLLING_AVG_COUNT = 4; uint8_t meanIndex = 0; qreal meanData[TRANSFER_ROLLING_AVG_COUNT] = {0.0}; + + bool active; }; #endif // FILETRANSFERWIDGET_H From abf7b42324f85c00ca1105ac11a8c989e8488aa2 Mon Sep 17 00:00:00 2001 From: Diadlo Date: Sat, 30 Jul 2016 16:15:52 +0300 Subject: [PATCH 2/2] fix(chatlog): Don't delete active transfer widget Fix #3275. --- src/chatlog/chatlog.cpp | 32 +++++++++++++++++++++++++++++++- src/chatlog/chatlog.h | 1 + 2 files changed, 32 insertions(+), 1 deletion(-) diff --git a/src/chatlog/chatlog.cpp b/src/chatlog/chatlog.cpp index 005ca154d..3cf83a46c 100644 --- a/src/chatlog/chatlog.cpp +++ b/src/chatlog/chatlog.cpp @@ -20,6 +20,8 @@ #include "chatlog.h" #include "chatmessage.h" #include "chatlinecontent.h" +#include "chatlinecontentproxy.h" +#include "content/filetransferwidget.h" #include "src/widget/translator.h" #include @@ -560,11 +562,20 @@ void ChatLog::clear() { clearSelection(); + QVector savedLines; + for (ChatLine::Ptr l : lines) - l->removeFromScene(); + { + if (isActiveFileTransfer(l)) + savedLines.push_back(l); + else + l->removeFromScene(); + } lines.clear(); visibleLines.clear(); + for (ChatLine::Ptr l : savedLines) + insertChatlineAtBottom(l); updateSceneRect(); } @@ -850,3 +861,22 @@ void ChatLog::retranslateUi() copyAction->setText(tr("Copy")); selectAllAction->setText(tr("Select all")); } + +bool ChatLog::isActiveFileTransfer(ChatLine::Ptr l) +{ + int count = l->getColumnCount(); + for (int i = 0; i < count; i++) + { + ChatLineContent *content = l->getContent(i); + ChatLineContentProxy *proxy = dynamic_cast(content); + if (!proxy) + continue; + + QWidget *widget = proxy->getWidget(); + FileTransferWidget *transferWidget = dynamic_cast(widget); + if (transferWidget && transferWidget->isActive()) + return true; + } + + return false; +} diff --git a/src/chatlog/chatlog.h b/src/chatlog/chatlog.h index d09848b11..a1072876c 100644 --- a/src/chatlog/chatlog.h +++ b/src/chatlog/chatlog.h @@ -106,6 +106,7 @@ private slots: private: void retranslateUi(); + bool isActiveFileTransfer(ChatLine::Ptr l); private: enum SelectionMode {