mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-23 13:04:23 +00:00
Merge pull request #4675 from Chocobo1/hide_zeros
Hide zero & infinity values
This commit is contained in:
commit
30819b3cbc
@ -273,6 +273,26 @@ void Preferences::setAlternatingRowColors(bool b)
|
|||||||
setValue("Preferences/General/AlternatingRowColors", b);
|
setValue("Preferences/General/AlternatingRowColors", b);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Preferences::getHideZeroValues() const
|
||||||
|
{
|
||||||
|
return value("Preferences/General/HideZeroValues", false).toBool();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Preferences::setHideZeroValues(bool b)
|
||||||
|
{
|
||||||
|
setValue("Preferences/General/HideZeroValues", b);
|
||||||
|
}
|
||||||
|
|
||||||
|
int Preferences::getHideZeroComboValues() const
|
||||||
|
{
|
||||||
|
return value("Preferences/General/HideZeroComboValues", 0).toInt();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Preferences::setHideZeroComboValues(int n)
|
||||||
|
{
|
||||||
|
setValue("Preferences/General/HideZeroComboValues", n);
|
||||||
|
}
|
||||||
|
|
||||||
bool Preferences::useRandomPort() const
|
bool Preferences::useRandomPort() const
|
||||||
{
|
{
|
||||||
return value("Preferences/General/UseRandomPort", false).toBool();
|
return value("Preferences/General/UseRandomPort", false).toBool();
|
||||||
|
@ -132,6 +132,10 @@ public:
|
|||||||
void showSpeedInTitleBar(bool show);
|
void showSpeedInTitleBar(bool show);
|
||||||
bool useAlternatingRowColors() const;
|
bool useAlternatingRowColors() const;
|
||||||
void setAlternatingRowColors(bool b);
|
void setAlternatingRowColors(bool b);
|
||||||
|
bool getHideZeroValues() const;
|
||||||
|
void setHideZeroValues(bool b);
|
||||||
|
int getHideZeroComboValues() const;
|
||||||
|
void setHideZeroComboValues(int n);
|
||||||
bool useRandomPort() const;
|
bool useRandomPort() const;
|
||||||
void setRandomPort(bool b);
|
void setRandomPort(bool b);
|
||||||
bool systrayIntegration() const;
|
bool systrayIntegration() const;
|
||||||
|
@ -163,7 +163,7 @@
|
|||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>480</width>
|
<width>480</width>
|
||||||
<height>672</height>
|
<height>702</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_9">
|
<layout class="QVBoxLayout" name="verticalLayout_9">
|
||||||
@ -257,6 +257,44 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item>
|
||||||
|
<layout class="QHBoxLayout" name="horizontalLayout">
|
||||||
|
<item>
|
||||||
|
<widget class="QCheckBox" name="checkHideZero">
|
||||||
|
<property name="text">
|
||||||
|
<string>Hide zero and infinity values</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QComboBox" name="comboHideZero">
|
||||||
|
<item>
|
||||||
|
<property name="text">
|
||||||
|
<string>Always</string>
|
||||||
|
</property>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<property name="text">
|
||||||
|
<string>Paused torrents only</string>
|
||||||
|
</property>
|
||||||
|
</item>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<spacer name="horizontalSpacer_10">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>0</width>
|
||||||
|
<height>0</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
</spacer>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QGroupBox" name="groupBox_7">
|
<widget class="QGroupBox" name="groupBox_7">
|
||||||
<property name="font">
|
<property name="font">
|
||||||
|
@ -141,6 +141,8 @@ options_imp::options_imp(QWidget *parent)
|
|||||||
connect(comboI18n, SIGNAL(currentIndexChanged(int)), this, SLOT(enableApplyButton()));
|
connect(comboI18n, SIGNAL(currentIndexChanged(int)), this, SLOT(enableApplyButton()));
|
||||||
connect(confirmDeletion, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
connect(confirmDeletion, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
||||||
connect(checkAltRowColors, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
connect(checkAltRowColors, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
||||||
|
connect(checkHideZero, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
||||||
|
connect(comboHideZero, SIGNAL(currentIndexChanged(int)), this, SLOT(enableApplyButton()));
|
||||||
connect(checkShowSystray, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
connect(checkShowSystray, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
||||||
connect(checkCloseToSystray, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
connect(checkCloseToSystray, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
||||||
connect(checkMinimizeToSysTray, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
connect(checkMinimizeToSysTray, SIGNAL(toggled(bool)), this, SLOT(enableApplyButton()));
|
||||||
@ -392,6 +394,8 @@ void options_imp::saveOptions()
|
|||||||
pref->setLocale(locale);
|
pref->setLocale(locale);
|
||||||
pref->setConfirmTorrentDeletion(confirmDeletion->isChecked());
|
pref->setConfirmTorrentDeletion(confirmDeletion->isChecked());
|
||||||
pref->setAlternatingRowColors(checkAltRowColors->isChecked());
|
pref->setAlternatingRowColors(checkAltRowColors->isChecked());
|
||||||
|
pref->setHideZeroValues(checkHideZero->isChecked());
|
||||||
|
pref->setHideZeroComboValues(comboHideZero->currentIndex());
|
||||||
pref->setSystrayIntegration(systrayIntegration());
|
pref->setSystrayIntegration(systrayIntegration());
|
||||||
pref->setTrayIconStyle(TrayIcon::Style(comboTrayIcon->currentIndex()));
|
pref->setTrayIconStyle(TrayIcon::Style(comboTrayIcon->currentIndex()));
|
||||||
pref->setCloseToTray(closeToTray());
|
pref->setCloseToTray(closeToTray());
|
||||||
@ -572,6 +576,8 @@ void options_imp::loadOptions()
|
|||||||
setLocale(pref->getLocale());
|
setLocale(pref->getLocale());
|
||||||
confirmDeletion->setChecked(pref->confirmTorrentDeletion());
|
confirmDeletion->setChecked(pref->confirmTorrentDeletion());
|
||||||
checkAltRowColors->setChecked(pref->useAlternatingRowColors());
|
checkAltRowColors->setChecked(pref->useAlternatingRowColors());
|
||||||
|
checkHideZero->setChecked(pref->getHideZeroValues());
|
||||||
|
comboHideZero->setCurrentIndex(pref->getHideZeroComboValues());
|
||||||
|
|
||||||
checkShowSplash->setChecked(!pref->isSplashScreenDisabled());
|
checkShowSplash->setChecked(!pref->isSplashScreenDisabled());
|
||||||
checkStartMinimized->setChecked(pref->startMinimized());
|
checkStartMinimized->setChecked(pref->startMinimized());
|
||||||
|
@ -185,9 +185,9 @@ QVariant TorrentModel::data(const QModelIndex &index, int role) const
|
|||||||
case TR_STATUS:
|
case TR_STATUS:
|
||||||
return static_cast<int>(torrent->state());
|
return static_cast<int>(torrent->state());
|
||||||
case TR_SEEDS:
|
case TR_SEEDS:
|
||||||
return (role == Qt::DisplayRole) ? torrent->seedsCount() : torrent->completeCount();
|
return (role == Qt::DisplayRole) ? torrent->seedsCount() : torrent->totalSeedsCount();
|
||||||
case TR_PEERS:
|
case TR_PEERS:
|
||||||
return (role == Qt::DisplayRole) ? (torrent->peersCount() - torrent->seedsCount()) : torrent->incompleteCount();
|
return (role == Qt::DisplayRole) ? torrent->leechsCount() : torrent->totalLeechersCount();
|
||||||
case TR_DLSPEED:
|
case TR_DLSPEED:
|
||||||
return torrent->downloadPayloadRate();
|
return torrent->downloadPayloadRate();
|
||||||
case TR_UPSPEED:
|
case TR_UPSPEED:
|
||||||
|
@ -39,6 +39,8 @@
|
|||||||
#include "torrentmodel.h"
|
#include "torrentmodel.h"
|
||||||
#include "base/bittorrent/session.h"
|
#include "base/bittorrent/session.h"
|
||||||
#include "base/bittorrent/torrenthandle.h"
|
#include "base/bittorrent/torrenthandle.h"
|
||||||
|
#include "base/types.h"
|
||||||
|
#include "base/preferences.h"
|
||||||
#include "base/unicodestrings.h"
|
#include "base/unicodestrings.h"
|
||||||
|
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
@ -49,14 +51,25 @@
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
TransferListDelegate::TransferListDelegate(QObject *parent) : QItemDelegate(parent) {}
|
TransferListDelegate::TransferListDelegate(QObject *parent)
|
||||||
|
: QItemDelegate(parent)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
TransferListDelegate::~TransferListDelegate() {}
|
void TransferListDelegate::paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const
|
||||||
|
{
|
||||||
void TransferListDelegate::paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const {
|
|
||||||
QStyleOptionViewItemV2 opt = QItemDelegate::setOptions(index, option);
|
|
||||||
painter->save();
|
painter->save();
|
||||||
switch(index.column()) {
|
bool isHideState = true;
|
||||||
|
if (Preferences::instance()->getHideZeroComboValues() == 1) { // paused torrents only
|
||||||
|
QModelIndex stateIndex = index.sibling(index.row(), TorrentModel::TR_STATUS);
|
||||||
|
if (stateIndex.data().toInt() != BitTorrent::TorrentState::PausedDownloading)
|
||||||
|
isHideState = false;
|
||||||
|
}
|
||||||
|
const bool hideValues = Preferences::instance()->getHideZeroValues() & isHideState;
|
||||||
|
|
||||||
|
QStyleOptionViewItemV2 opt = QItemDelegate::setOptions(index, option);
|
||||||
|
QItemDelegate::drawBackground(painter, opt, index);
|
||||||
|
switch (index.column()) {
|
||||||
case TorrentModel::TR_AMOUNT_DOWNLOADED:
|
case TorrentModel::TR_AMOUNT_DOWNLOADED:
|
||||||
case TorrentModel::TR_AMOUNT_UPLOADED:
|
case TorrentModel::TR_AMOUNT_UPLOADED:
|
||||||
case TorrentModel::TR_AMOUNT_DOWNLOADED_SESSION:
|
case TorrentModel::TR_AMOUNT_DOWNLOADED_SESSION:
|
||||||
@ -65,144 +78,92 @@ void TransferListDelegate::paint(QPainter * painter, const QStyleOptionViewItem
|
|||||||
case TorrentModel::TR_COMPLETED:
|
case TorrentModel::TR_COMPLETED:
|
||||||
case TorrentModel::TR_SIZE:
|
case TorrentModel::TR_SIZE:
|
||||||
case TorrentModel::TR_TOTAL_SIZE: {
|
case TorrentModel::TR_TOTAL_SIZE: {
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
qlonglong size = index.data().toLongLong();
|
||||||
|
if (hideValues && !size)
|
||||||
|
break;
|
||||||
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
||||||
QItemDelegate::drawDisplay(painter, opt, option.rect, Utils::Misc::friendlyUnit(index.data().toLongLong()));
|
QItemDelegate::drawDisplay(painter, opt, option.rect, Utils::Misc::friendlyUnit(size));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TorrentModel::TR_ETA: {
|
case TorrentModel::TR_ETA: {
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
|
||||||
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
||||||
QItemDelegate::drawDisplay(painter, opt, option.rect, Utils::Misc::userFriendlyDuration(index.data().toLongLong()));
|
QItemDelegate::drawDisplay(painter, opt, option.rect, Utils::Misc::userFriendlyDuration(index.data().toLongLong()));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TorrentModel::TR_SEEDS:
|
case TorrentModel::TR_SEEDS:
|
||||||
case TorrentModel::TR_PEERS: {
|
case TorrentModel::TR_PEERS: {
|
||||||
QString display = QString::number(index.data().toLongLong());
|
qlonglong value = index.data().toLongLong();
|
||||||
qlonglong total = index.data(Qt::UserRole).toLongLong();
|
qlonglong total = index.data(Qt::UserRole).toLongLong();
|
||||||
if (total > 0) {
|
if (hideValues && (!value && !total))
|
||||||
// Scrape was successful, we have total values
|
break;
|
||||||
display += " ("+QString::number(total)+")";
|
QString display = QString::number(value) + " (" + QString::number(total) + ")";
|
||||||
}
|
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
|
||||||
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
||||||
QItemDelegate::drawDisplay(painter, opt, opt.rect, display);
|
QItemDelegate::drawDisplay(painter, opt, opt.rect, display);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TorrentModel::TR_STATUS: {
|
case TorrentModel::TR_STATUS: {
|
||||||
const int state = index.data().toInt();
|
const int state = index.data().toInt();
|
||||||
QString display;
|
QString display = getStatusString(state);
|
||||||
switch(state) {
|
|
||||||
case BitTorrent::TorrentState::Downloading:
|
|
||||||
display = tr("Downloading");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::StalledDownloading:
|
|
||||||
display = tr("Stalled", "Torrent is waiting for download to begin");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::DownloadingMetadata:
|
|
||||||
display = tr("Downloading metadata", "used when loading a magnet link");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::ForcedDownloading:
|
|
||||||
display = tr("[F] Downloading", "used when the torrent is forced started. You probably shouldn't translate the F.");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::Allocating:
|
|
||||||
display = tr("Allocating", "qBittorrent is allocating the files on disk");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::Uploading:
|
|
||||||
case BitTorrent::TorrentState::StalledUploading:
|
|
||||||
display = tr("Seeding", "Torrent is complete and in upload-only mode");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::ForcedUploading:
|
|
||||||
display = tr("[F] Seeding", "used when the torrent is forced started. You probably shouldn't translate the F.");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::QueuedDownloading:
|
|
||||||
case BitTorrent::TorrentState::QueuedUploading:
|
|
||||||
display = tr("Queued", "i.e. torrent is queued");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::CheckingDownloading:
|
|
||||||
case BitTorrent::TorrentState::CheckingUploading:
|
|
||||||
display = tr("Checking", "Torrent local data is being checked");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::QueuedForChecking:
|
|
||||||
display = tr("Queued for checking", "i.e. torrent is queued for hash checking");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::CheckingResumeData:
|
|
||||||
display = tr("Checking resume data", "used when loading the torrents from disk after qbt is launched. It checks the correctness of the .fastresume file. Normally it is completed in a fraction of a second, unless loading many many torrents.");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::PausedDownloading:
|
|
||||||
display = tr("Paused");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::PausedUploading:
|
|
||||||
display = tr("Completed");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::MissingFiles:
|
|
||||||
display = tr("Missing Files");
|
|
||||||
break;
|
|
||||||
case BitTorrent::TorrentState::Error:
|
|
||||||
display = tr("Errored", "torrent status, the torrent has an error");
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
display = "";
|
|
||||||
}
|
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
|
||||||
QItemDelegate::drawDisplay(painter, opt, opt.rect, display);
|
QItemDelegate::drawDisplay(painter, opt, opt.rect, display);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TorrentModel::TR_UPSPEED:
|
case TorrentModel::TR_UPSPEED:
|
||||||
case TorrentModel::TR_DLSPEED: {
|
case TorrentModel::TR_DLSPEED: {
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
|
||||||
const qulonglong speed = index.data().toULongLong();
|
const qulonglong speed = index.data().toULongLong();
|
||||||
|
if (hideValues && !speed)
|
||||||
|
break;
|
||||||
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
||||||
QItemDelegate::drawDisplay(painter, opt, opt.rect, Utils::Misc::friendlyUnit(speed, true));
|
QItemDelegate::drawDisplay(painter, opt, opt.rect, Utils::Misc::friendlyUnit(speed, true));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TorrentModel::TR_UPLIMIT:
|
case TorrentModel::TR_UPLIMIT:
|
||||||
case TorrentModel::TR_DLLIMIT: {
|
case TorrentModel::TR_DLLIMIT: {
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
|
||||||
const qlonglong limit = index.data().toLongLong();
|
const qlonglong limit = index.data().toLongLong();
|
||||||
|
if (hideValues && !limit)
|
||||||
|
break;
|
||||||
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
||||||
QItemDelegate::drawDisplay(painter, opt, opt.rect, limit > 0 ? Utils::Misc::friendlyUnit(limit, true) : QString::fromUtf8(C_INFINITY));
|
QItemDelegate::drawDisplay(painter, opt, opt.rect, limit > 0 ? Utils::Misc::friendlyUnit(limit, true) : QString::fromUtf8(C_INFINITY));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TorrentModel::TR_TIME_ELAPSED: {
|
case TorrentModel::TR_TIME_ELAPSED: {
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
qlonglong elapsedTime = index.data().toLongLong();
|
||||||
qlonglong seeding_time = index.data(Qt::UserRole).toLongLong();
|
qlonglong seedingTime = index.data(Qt::UserRole).toLongLong();
|
||||||
QString txt;
|
QString txt;
|
||||||
if (seeding_time > 0)
|
if (seedingTime > 0)
|
||||||
txt += tr("%1 (seeded for %2)", "e.g. 4m39s (seeded for 3m10s)")
|
txt += tr("%1 (seeded for %2)", "e.g. 4m39s (seeded for 3m10s)")
|
||||||
.arg(Utils::Misc::userFriendlyDuration(index.data().toLongLong()))
|
.arg(Utils::Misc::userFriendlyDuration(elapsedTime))
|
||||||
.arg(Utils::Misc::userFriendlyDuration(seeding_time));
|
.arg(Utils::Misc::userFriendlyDuration(seedingTime));
|
||||||
QItemDelegate::drawDisplay(painter, opt, opt.rect, txt);
|
QItemDelegate::drawDisplay(painter, opt, opt.rect, txt);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TorrentModel::TR_ADD_DATE:
|
case TorrentModel::TR_ADD_DATE:
|
||||||
case TorrentModel::TR_SEED_DATE:
|
case TorrentModel::TR_SEED_DATE:
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
|
||||||
QItemDelegate::drawDisplay(painter, opt, opt.rect, index.data().toDateTime().toLocalTime().toString(Qt::DefaultLocaleShortDate));
|
QItemDelegate::drawDisplay(painter, opt, opt.rect, index.data().toDateTime().toLocalTime().toString(Qt::DefaultLocaleShortDate));
|
||||||
break;
|
break;
|
||||||
case TorrentModel::TR_RATIO_LIMIT:
|
case TorrentModel::TR_RATIO_LIMIT:
|
||||||
case TorrentModel::TR_RATIO: {
|
case TorrentModel::TR_RATIO: {
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
|
||||||
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
|
||||||
const qreal ratio = index.data().toDouble();
|
const qreal ratio = index.data().toDouble();
|
||||||
QItemDelegate::drawDisplay(painter, opt, opt.rect,
|
if (hideValues && (ratio <= 0))
|
||||||
((ratio == -1) || (ratio > BitTorrent::TorrentHandle::MAX_RATIO)) ? QString::fromUtf8(C_INFINITY) : Utils::String::fromDouble(ratio, 2));
|
break;
|
||||||
|
QString str = ((ratio == -1) || (ratio > BitTorrent::TorrentHandle::MAX_RATIO)) ? QString::fromUtf8(C_INFINITY) : Utils::String::fromDouble(ratio, 2);
|
||||||
|
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
||||||
|
QItemDelegate::drawDisplay(painter, opt, opt.rect, str);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TorrentModel::TR_PRIORITY: {
|
case TorrentModel::TR_PRIORITY: {
|
||||||
const int priority = index.data().toInt();
|
const int priority = index.data().toInt();
|
||||||
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
||||||
if (priority > 0)
|
if (priority > 0) {
|
||||||
QItemDelegate::paint(painter, opt, index);
|
QItemDelegate::paint(painter, opt, index);
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
|
||||||
QItemDelegate::drawDisplay(painter, opt, opt.rect, "*");
|
QItemDelegate::drawDisplay(painter, opt, opt.rect, "*");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TorrentModel::TR_PROGRESS: {
|
case TorrentModel::TR_PROGRESS: {
|
||||||
QStyleOptionProgressBarV2 newopt;
|
QStyleOptionProgressBarV2 newopt;
|
||||||
qreal progress = index.data().toDouble()*100.;
|
qreal progress = index.data().toDouble() * 100.;
|
||||||
newopt.rect = opt.rect;
|
newopt.rect = opt.rect;
|
||||||
newopt.text = ((progress == 100.0) ? QString("100%") : Utils::String::fromDouble(progress, 1) + "%");
|
newopt.text = ((progress == 100.0) ? QString("100%") : Utils::String::fromDouble(progress, 1) + "%");
|
||||||
newopt.progress = (int)progress;
|
newopt.progress = (int)progress;
|
||||||
@ -224,17 +185,19 @@ void TransferListDelegate::paint(QPainter * painter, const QStyleOptionViewItem
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TorrentModel::TR_LAST_ACTIVITY: {
|
case TorrentModel::TR_LAST_ACTIVITY: {
|
||||||
|
qlonglong elapsed = index.data().toLongLong();
|
||||||
|
if (hideValues && ((elapsed < 0) || (elapsed >= MAX_ETA)))
|
||||||
|
break;
|
||||||
|
|
||||||
QString elapsedString;
|
QString elapsedString;
|
||||||
long long elapsed = index.data().toLongLong();
|
|
||||||
QItemDelegate::drawBackground(painter, opt, index);
|
|
||||||
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
|
||||||
if (elapsed == 0)
|
if (elapsed == 0)
|
||||||
// Show '< 1m ago' when elapsed time is 0
|
// Show '< 1m ago' when elapsed time is 0
|
||||||
elapsed = 1;
|
elapsed = 1;
|
||||||
if (elapsed < 0)
|
else if (elapsed < 0)
|
||||||
elapsedString = Utils::Misc::userFriendlyDuration(elapsed);
|
elapsedString = Utils::Misc::userFriendlyDuration(elapsed);
|
||||||
else
|
else
|
||||||
elapsedString = tr("%1 ago", "e.g.: 1h 20m ago").arg(Utils::Misc::userFriendlyDuration(elapsed));
|
elapsedString = tr("%1 ago", "e.g.: 1h 20m ago").arg(Utils::Misc::userFriendlyDuration(elapsed));
|
||||||
|
opt.displayAlignment = Qt::AlignRight | Qt::AlignVCenter;
|
||||||
QItemDelegate::drawDisplay(painter, opt, option.rect, elapsedString);
|
QItemDelegate::drawDisplay(painter, opt, option.rect, elapsedString);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -244,23 +207,84 @@ void TransferListDelegate::paint(QPainter * painter, const QStyleOptionViewItem
|
|||||||
painter->restore();
|
painter->restore();
|
||||||
}
|
}
|
||||||
|
|
||||||
QWidget* TransferListDelegate::createEditor(QWidget*, const QStyleOptionViewItem &, const QModelIndex &) const {
|
QWidget* TransferListDelegate::createEditor(QWidget*, const QStyleOptionViewItem &, const QModelIndex &) const
|
||||||
|
{
|
||||||
// No editor here
|
// No editor here
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
QSize TransferListDelegate::sizeHint(const QStyleOptionViewItem & option, const QModelIndex & index) const {
|
QSize TransferListDelegate::sizeHint(const QStyleOptionViewItem & option, const QModelIndex & index) const
|
||||||
QSize size = QItemDelegate::sizeHint(option, index);
|
{
|
||||||
|
static int iconHeight = -1;
|
||||||
static int icon_height = -1;
|
if (iconHeight == -1) {
|
||||||
if (icon_height == -1) {
|
|
||||||
QIcon icon(":/icons/skin/downloading.png");
|
QIcon icon(":/icons/skin/downloading.png");
|
||||||
QList<QSize> ic_sizes(icon.availableSizes());
|
QList<QSize> icSizes(icon.availableSizes());
|
||||||
icon_height = ic_sizes[0].height();
|
iconHeight = icSizes[0].height();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (size.height() < icon_height)
|
QSize size = QItemDelegate::sizeHint(option, index);
|
||||||
size.setHeight(icon_height);
|
if (size.height() < iconHeight)
|
||||||
|
size.setHeight(iconHeight);
|
||||||
|
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString TransferListDelegate::getStatusString(const int state) const
|
||||||
|
{
|
||||||
|
QString str;
|
||||||
|
|
||||||
|
switch (state) {
|
||||||
|
case BitTorrent::TorrentState::Downloading:
|
||||||
|
str = tr("Downloading");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::StalledDownloading:
|
||||||
|
str = tr("Stalled", "Torrent is waiting for download to begin");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::DownloadingMetadata:
|
||||||
|
str = tr("Downloading metadata", "used when loading a magnet link");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::ForcedDownloading:
|
||||||
|
str = tr("[F] Downloading", "used when the torrent is forced started. You probably shouldn't translate the F.");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::Allocating:
|
||||||
|
str = tr("Allocating", "qBittorrent is allocating the files on disk");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::Uploading:
|
||||||
|
case BitTorrent::TorrentState::StalledUploading:
|
||||||
|
str = tr("Seeding", "Torrent is complete and in upload-only mode");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::ForcedUploading:
|
||||||
|
str = tr("[F] Seeding", "used when the torrent is forced started. You probably shouldn't translate the F.");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::QueuedDownloading:
|
||||||
|
case BitTorrent::TorrentState::QueuedUploading:
|
||||||
|
str = tr("Queued", "i.e. torrent is queued");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::CheckingDownloading:
|
||||||
|
case BitTorrent::TorrentState::CheckingUploading:
|
||||||
|
str = tr("Checking", "Torrent local data is being checked");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::QueuedForChecking:
|
||||||
|
str = tr("Queued for checking", "i.e. torrent is queued for hash checking");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::CheckingResumeData:
|
||||||
|
str = tr("Checking resume data", "used when loading the torrents from disk after qbt is launched. It checks the correctness of the .fastresume file. Normally it is completed in a fraction of a second, unless loading many many torrents.");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::PausedDownloading:
|
||||||
|
str = tr("Paused");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::PausedUploading:
|
||||||
|
str = tr("Completed");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::MissingFiles:
|
||||||
|
str = tr("Missing Files");
|
||||||
|
break;
|
||||||
|
case BitTorrent::TorrentState::Error:
|
||||||
|
str = tr("Errored", "torrent status, the torrent has an error");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
str = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
return str;
|
||||||
|
}
|
||||||
|
@ -41,12 +41,12 @@ QT_END_NAMESPACE
|
|||||||
|
|
||||||
// Defines for download list list columns
|
// Defines for download list list columns
|
||||||
|
|
||||||
class TransferListDelegate: public QItemDelegate {
|
class TransferListDelegate: public QItemDelegate
|
||||||
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
TransferListDelegate(QObject *parent);
|
TransferListDelegate(QObject *parent);
|
||||||
~TransferListDelegate();
|
|
||||||
void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const;
|
void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const;
|
||||||
QWidget* createEditor(QWidget*, const QStyleOptionViewItem &, const QModelIndex &) const;
|
QWidget* createEditor(QWidget*, const QStyleOptionViewItem &, const QModelIndex &) const;
|
||||||
|
|
||||||
@ -56,6 +56,8 @@ public:
|
|||||||
// This happens because icon from the 'name' column is no longer drawn.
|
// This happens because icon from the 'name' column is no longer drawn.
|
||||||
QSize sizeHint(const QStyleOptionViewItem & option, const QModelIndex & index) const;
|
QSize sizeHint(const QStyleOptionViewItem & option, const QModelIndex & index) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
QString getStatusString(const int state) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // TRANSFERLISTDELEGATE_H
|
#endif // TRANSFERLISTDELEGATE_H
|
||||||
|
Loading…
x
Reference in New Issue
Block a user