1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-01-23 21:14:33 +00:00

Merge pull request #11302 from Chocobo1/deletedialog

Revise DeletionConfirmationDialog class
This commit is contained in:
Mike Tzou 2019-10-01 12:50:10 +08:00 committed by GitHub
commit a9e6ef183b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 126 additions and 70 deletions

View File

@ -74,6 +74,7 @@ categoryfilterproxymodel.cpp
categoryfilterwidget.cpp categoryfilterwidget.cpp
cookiesdialog.cpp cookiesdialog.cpp
cookiesmodel.cpp cookiesmodel.cpp
deletionconfirmationdialog.cpp
downloadfromurldialog.cpp downloadfromurldialog.cpp
executionlogwidget.cpp executionlogwidget.cpp
fspathedit.cpp fspathedit.cpp

View File

@ -0,0 +1,81 @@
/*
* Bittorrent Client using Qt and libtorrent.
* Copyright (C) 2006 Christophe Dumez <chris@qbittorrent.org>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* In addition, as a special exception, the copyright holders give permission to
* link this program with the OpenSSL project's "OpenSSL" library (or with
* modified versions of it that use the same license as the "OpenSSL" library),
* and distribute the linked executables. You must obey the GNU General Public
* License in all respects for all of the code used other than "OpenSSL". If you
* modify file(s), you may extend this exception to your version of the file(s),
* but you are not obligated to do so. If you do not wish to do so, delete this
* exception statement from your version.
*/
#include "deletionconfirmationdialog.h"
#include <QPushButton>
#include "base/preferences.h"
#include "uithememanager.h"
#include "utils.h"
DeletionConfirmationDialog::DeletionConfirmationDialog(QWidget *parent, const int size, const QString &name, const bool defaultDeleteFiles)
: QDialog(parent)
, m_ui(new Ui::DeletionConfirmationDialog)
{
m_ui->setupUi(this);
if (size == 1)
m_ui->label->setText(tr("Are you sure you want to delete '%1' from the transfer list?", "Are you sure you want to delete 'ubuntu-linux-iso' from the transfer list?").arg(name.toHtmlEscaped()));
else
m_ui->label->setText(tr("Are you sure you want to delete these %1 torrents from the transfer list?", "Are you sure you want to delete these 5 torrents from the transfer list?").arg(QString::number(size)));
// Icons
const QSize iconSize = Utils::Gui::largeIconSize();
m_ui->labelWarning->setPixmap(UIThemeManager::instance()->getIcon("dialog-warning").pixmap(iconSize));
m_ui->labelWarning->setFixedWidth(iconSize.width());
m_ui->rememberBtn->setIcon(UIThemeManager::instance()->getIcon("object-locked"));
m_ui->rememberBtn->setIconSize(Utils::Gui::mediumIconSize());
m_ui->checkPermDelete->setChecked(defaultDeleteFiles || Preferences::instance()->deleteTorrentFilesAsDefault());
connect(m_ui->checkPermDelete, &QCheckBox::clicked, this, &DeletionConfirmationDialog::updateRememberButtonState);
m_ui->buttonBox->button(QDialogButtonBox::Cancel)->setFocus();
Utils::Gui::resize(this);
}
DeletionConfirmationDialog::~DeletionConfirmationDialog()
{
delete m_ui;
}
bool DeletionConfirmationDialog::isDeleteFileSelected() const
{
return m_ui->checkPermDelete->isChecked();
}
void DeletionConfirmationDialog::updateRememberButtonState()
{
m_ui->rememberBtn->setEnabled(m_ui->checkPermDelete->isChecked() != Preferences::instance()->deleteTorrentFilesAsDefault());
}
void DeletionConfirmationDialog::on_rememberBtn_clicked()
{
Preferences::instance()->setDeleteTorrentFilesAsDefault(m_ui->checkPermDelete->isChecked());
m_ui->rememberBtn->setEnabled(false);
}

View File

@ -30,72 +30,27 @@
#define DELETIONCONFIRMATIONDIALOG_H #define DELETIONCONFIRMATIONDIALOG_H
#include <QDialog> #include <QDialog>
#include <QPushButton>
#include "base/preferences.h"
#include "ui_deletionconfirmationdialog.h" #include "ui_deletionconfirmationdialog.h"
#include "uithememanager.h"
#include "utils.h" namespace Ui
{
class DeletionConfirmationDialog;
}
class DeletionConfirmationDialog : public QDialog class DeletionConfirmationDialog : public QDialog
{ {
Q_OBJECT Q_OBJECT
public: public:
DeletionConfirmationDialog(QWidget *parent, const int &size, const QString &name, bool defaultDeleteFiles) DeletionConfirmationDialog(QWidget *parent, int size, const QString &name, bool defaultDeleteFiles);
: QDialog(parent) ~DeletionConfirmationDialog();
, m_ui(new Ui::DeletionConfirmationDialog)
{
m_ui->setupUi(this);
if (size == 1)
m_ui->label->setText(tr("Are you sure you want to delete '%1' from the transfer list?", "Are you sure you want to delete 'ubuntu-linux-iso' from the transfer list?").arg(name.toHtmlEscaped()));
else
m_ui->label->setText(tr("Are you sure you want to delete these %1 torrents from the transfer list?", "Are you sure you want to delete these 5 torrents from the transfer list?").arg(QString::number(size)));
// Icons
const QSize iconSize = Utils::Gui::largeIconSize();
m_ui->labelWarning->setPixmap(UIThemeManager::instance()->getIcon("dialog-warning").pixmap(iconSize));
m_ui->labelWarning->setFixedWidth(iconSize.width());
m_ui->rememberBtn->setIcon(UIThemeManager::instance()->getIcon("object-locked"));
m_ui->rememberBtn->setIconSize(Utils::Gui::mediumIconSize());
m_ui->checkPermDelete->setChecked(defaultDeleteFiles || Preferences::instance()->deleteTorrentFilesAsDefault()); bool isDeleteFileSelected() const;
connect(m_ui->checkPermDelete, &QCheckBox::clicked, this, &DeletionConfirmationDialog::updateRememberButtonState);
m_ui->buttonBox->button(QDialogButtonBox::Cancel)->setFocus();
Utils::Gui::resize(this);
}
~DeletionConfirmationDialog()
{
delete m_ui;
}
bool shouldDeleteLocalFiles() const
{
return m_ui->checkPermDelete->isChecked();
}
static bool askForDeletionConfirmation(QWidget *parent, bool &deleteLocalFiles, const int &size, const QString &name)
{
DeletionConfirmationDialog dlg(parent, size, name, deleteLocalFiles);
if (dlg.exec() == QDialog::Accepted) {
deleteLocalFiles = dlg.shouldDeleteLocalFiles();
return true;
}
return false;
}
private slots: private slots:
void updateRememberButtonState() void updateRememberButtonState();
{ void on_rememberBtn_clicked();
m_ui->rememberBtn->setEnabled(m_ui->checkPermDelete->isChecked() != Preferences::instance()->deleteTorrentFilesAsDefault());
}
void on_rememberBtn_clicked()
{
Preferences::instance()->setDeleteTorrentFilesAsDefault(m_ui->checkPermDelete->isChecked());
m_ui->rememberBtn->setEnabled(false);
}
private: private:
Ui::DeletionConfirmationDialog *m_ui; Ui::DeletionConfirmationDialog *m_ui;

View File

@ -79,6 +79,7 @@ SOURCES += \
$$PWD/categoryfilterwidget.cpp \ $$PWD/categoryfilterwidget.cpp \
$$PWD/cookiesdialog.cpp \ $$PWD/cookiesdialog.cpp \
$$PWD/cookiesmodel.cpp \ $$PWD/cookiesmodel.cpp \
$$PWD/deletionconfirmationdialog.cpp \
$$PWD/downloadfromurldialog.cpp \ $$PWD/downloadfromurldialog.cpp \
$$PWD/executionlogwidget.cpp \ $$PWD/executionlogwidget.cpp \
$$PWD/fspathedit.cpp \ $$PWD/fspathedit.cpp \

View File

@ -96,6 +96,14 @@ namespace
return false; return false;
} }
void removeTorrents(const QVector<BitTorrent::TorrentHandle *> &torrents, const bool isDeleteFileSelected)
{
auto *session = BitTorrent::Session::instance();
const DeleteOption deleteOption = isDeleteFileSelected ? TorrentAndFiles : Torrent;
for (const BitTorrent::TorrentHandle *torrent : torrents)
session->deleteTorrent(torrent->hash(), deleteOption);
}
} }
TransferListWidget::TransferListWidget(QWidget *parent, MainWindow *mainWindow) TransferListWidget::TransferListWidget(QWidget *parent, MainWindow *mainWindow)
@ -363,19 +371,25 @@ void TransferListWidget::permDeleteSelectedTorrents()
deleteSelectedTorrents(true); deleteSelectedTorrents(true);
} }
void TransferListWidget::deleteSelectedTorrents(bool deleteLocalFiles) void TransferListWidget::deleteSelectedTorrents(const bool deleteLocalFiles)
{ {
if (m_mainWindow->currentTabWidget() != this) return; if (m_mainWindow->currentTabWidget() != this) return;
const QVector<BitTorrent::TorrentHandle *> torrents = getSelectedTorrents(); const QVector<BitTorrent::TorrentHandle *> torrents = getSelectedTorrents();
if (torrents.empty()) return; if (torrents.empty()) return;
if (Preferences::instance()->confirmTorrentDeletion() if (Preferences::instance()->confirmTorrentDeletion()) {
&& !DeletionConfirmationDialog::askForDeletionConfirmation(this, deleteLocalFiles, torrents.size(), torrents[0]->name())) auto *dialog = new DeletionConfirmationDialog(this, torrents.size(), torrents[0]->name(), deleteLocalFiles);
return; dialog->setAttribute(Qt::WA_DeleteOnClose);
const DeleteOption deleteOption = deleteLocalFiles ? TorrentAndFiles : Torrent; connect(dialog, &DeletionConfirmationDialog::accepted, this, [dialog, torrents]()
for (const BitTorrent::TorrentHandle *torrent : torrents) {
BitTorrent::Session::instance()->deleteTorrent(torrent->hash(), deleteOption); removeTorrents(torrents, dialog->isDeleteFileSelected());
});
dialog->open();
}
else {
removeTorrents(torrents, deleteLocalFiles);
}
} }
void TransferListWidget::deleteVisibleTorrents() void TransferListWidget::deleteVisibleTorrents()
@ -386,14 +400,18 @@ void TransferListWidget::deleteVisibleTorrents()
for (int i = 0; i < m_sortFilterModel->rowCount(); ++i) for (int i = 0; i < m_sortFilterModel->rowCount(); ++i)
torrents << m_listModel->torrentHandle(mapToSource(m_sortFilterModel->index(i, 0))); torrents << m_listModel->torrentHandle(mapToSource(m_sortFilterModel->index(i, 0)));
bool deleteLocalFiles = false; if (Preferences::instance()->confirmTorrentDeletion()) {
if (Preferences::instance()->confirmTorrentDeletion() auto *dialog = new DeletionConfirmationDialog(this, torrents.size(), torrents[0]->name(), false);
&& !DeletionConfirmationDialog::askForDeletionConfirmation(this, deleteLocalFiles, torrents.size(), torrents[0]->name())) dialog->setAttribute(Qt::WA_DeleteOnClose);
return; connect(dialog, &DeletionConfirmationDialog::accepted, this, [dialog, torrents]()
{
const DeleteOption deleteOption = deleteLocalFiles ? TorrentAndFiles : Torrent; removeTorrents(torrents, dialog->isDeleteFileSelected());
for (const BitTorrent::TorrentHandle *torrent : asConst(torrents)) });
BitTorrent::Session::instance()->deleteTorrent(torrent->hash(), deleteOption); dialog->open();
}
else {
removeTorrents(torrents, false);
}
} }
void TransferListWidget::increaseQueuePosSelectedTorrents() void TransferListWidget::increaseQueuePosSelectedTorrents()