mirror of
https://github.com/qbittorrent/qBittorrent
synced 2025-08-14 02:27:09 -07:00
Fix setting custom download location for watched folder
This commit is contained in:
parent
bc92f156c1
commit
ed7fb20758
2 changed files with 27 additions and 57 deletions
|
@ -28,6 +28,7 @@
|
||||||
* Contact : hammered999@gmail.com
|
* Contact : hammered999@gmail.com
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <QDebug>
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
#include <QComboBox>
|
#include <QComboBox>
|
||||||
#include <QFileDialog>
|
#include <QFileDialog>
|
||||||
|
@ -45,8 +46,6 @@ ScanFoldersDelegate::ScanFoldersDelegate(QObject *parent, QTreeView *foldersView
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
ScanFoldersDelegate::~ScanFoldersDelegate() {}
|
|
||||||
|
|
||||||
void ScanFoldersDelegate::paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const
|
void ScanFoldersDelegate::paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const
|
||||||
{
|
{
|
||||||
painter->save();
|
painter->save();
|
||||||
|
@ -98,6 +97,7 @@ QWidget *ScanFoldersDelegate::createEditor(QWidget *parent, const QStyleOptionVi
|
||||||
if (index.column() != ScanFoldersModel::DOWNLOAD) return 0;
|
if (index.column() != ScanFoldersModel::DOWNLOAD) return 0;
|
||||||
|
|
||||||
QComboBox* editor = new QComboBox(parent);
|
QComboBox* editor = new QComboBox(parent);
|
||||||
|
|
||||||
editor->setFocusPolicy(Qt::StrongFocus);
|
editor->setFocusPolicy(Qt::StrongFocus);
|
||||||
editor->addItem(tr("Watch Folder"));
|
editor->addItem(tr("Watch Folder"));
|
||||||
editor->addItem(tr("Default Folder"));
|
editor->addItem(tr("Default Folder"));
|
||||||
|
@ -111,19 +111,35 @@ QWidget *ScanFoldersDelegate::createEditor(QWidget *parent, const QStyleOptionVi
|
||||||
return editor;
|
return editor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ScanFoldersDelegate::comboboxIndexChanged(int index)
|
||||||
|
{
|
||||||
|
if (index == ScanFoldersModel::CUSTOM_LOCATION) {
|
||||||
|
QWidget *w = static_cast<QWidget *>(sender());
|
||||||
|
if (w && w->parentWidget())
|
||||||
|
w->parentWidget()->setFocus();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void ScanFoldersDelegate::setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const
|
void ScanFoldersDelegate::setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const
|
||||||
{
|
{
|
||||||
QComboBox *combobox = static_cast<QComboBox*>(editor);
|
QComboBox *combobox = static_cast<QComboBox*>(editor);
|
||||||
int value = combobox->currentIndex();
|
int value = combobox->currentIndex();
|
||||||
|
|
||||||
switch(value) {
|
switch (value) {
|
||||||
case ScanFoldersModel::DOWNLOAD_IN_WATCH_FOLDER:
|
case ScanFoldersModel::DOWNLOAD_IN_WATCH_FOLDER:
|
||||||
case ScanFoldersModel::DEFAULT_LOCATION:
|
case ScanFoldersModel::DEFAULT_LOCATION:
|
||||||
model->setData(index, value, Qt::DisplayRole);
|
model->setData(index, value, Qt::DisplayRole);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 4: // '4' is the index of the item after the separator in the QComboBox menu
|
case ScanFoldersModel::CUSTOM_LOCATION:
|
||||||
model->setData(index, combobox->currentText(), Qt::UserRole);
|
model->setData(
|
||||||
|
index,
|
||||||
|
QFileDialog::getExistingDirectory(
|
||||||
|
0, tr("Choose save path"),
|
||||||
|
index.data().toInt() == ScanFoldersModel::CUSTOM_LOCATION ?
|
||||||
|
index.data(Qt::UserRole).toString() :
|
||||||
|
Preferences::instance()->getSavePath()),
|
||||||
|
Qt::UserRole);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -136,48 +152,3 @@ void ScanFoldersDelegate::updateEditorGeometry(QWidget *editor, const QStyleOpti
|
||||||
qDebug("UpdateEditor Geometry called");
|
qDebug("UpdateEditor Geometry called");
|
||||||
editor->setGeometry(option.rect);
|
editor->setGeometry(option.rect);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ScanFoldersDelegate::comboboxIndexChanged(int index)
|
|
||||||
{
|
|
||||||
if (index < 2)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (index == 2) {
|
|
||||||
QString path;
|
|
||||||
QString newPath;
|
|
||||||
QModelIndexList selIndex = m_folderView->selectionModel()->selectedRows(1);
|
|
||||||
|
|
||||||
if (selIndex.isEmpty())
|
|
||||||
return;
|
|
||||||
|
|
||||||
ScanFoldersModel::PathType type = static_cast<ScanFoldersModel::PathType>(selIndex.at(0).data().toInt());
|
|
||||||
|
|
||||||
if (type == ScanFoldersModel::CUSTOM_LOCATION)
|
|
||||||
path = selIndex.at(0).data(Qt::UserRole).toString();
|
|
||||||
else
|
|
||||||
path = Preferences::instance()->getSavePath();
|
|
||||||
|
|
||||||
newPath = QFileDialog::getExistingDirectory(0, tr("Choose save path"), path);
|
|
||||||
QComboBox *combobox = static_cast<QComboBox*>(sender());
|
|
||||||
disconnect(combobox, SIGNAL(currentIndexChanged(int)), this, SLOT(comboboxIndexChanged(int)));
|
|
||||||
|
|
||||||
if (!newPath.isEmpty()) {
|
|
||||||
if (combobox->count() != 5) {
|
|
||||||
combobox->insertSeparator(3);
|
|
||||||
combobox->addItem(newPath);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
combobox->setItemText(4, newPath);
|
|
||||||
}
|
|
||||||
combobox->setCurrentIndex(4);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if (type == ScanFoldersModel::CUSTOM_LOCATION)
|
|
||||||
combobox->setCurrentIndex(4);
|
|
||||||
else
|
|
||||||
combobox->setCurrentIndex(type);
|
|
||||||
}
|
|
||||||
|
|
||||||
connect(combobox, SIGNAL(currentIndexChanged(int)), this, SLOT(comboboxIndexChanged(int)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -46,18 +46,17 @@ class ScanFoldersDelegate : public QItemDelegate
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ScanFoldersDelegate(QObject *parent, QTreeView *foldersView);
|
ScanFoldersDelegate(QObject *parent, QTreeView *foldersView);
|
||||||
~ScanFoldersDelegate();
|
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void comboboxIndexChanged(int index);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const;
|
||||||
|
void updateEditorGeometry(QWidget *editor, const QStyleOptionViewItem &option, const QModelIndex &) const;
|
||||||
void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const;
|
void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const;
|
||||||
void setEditorData(QWidget *editor, const QModelIndex &index) const;
|
void setEditorData(QWidget *editor, const QModelIndex &index) const;
|
||||||
QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &, const QModelIndex &index) const;
|
QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &, const QModelIndex &index) const;
|
||||||
|
|
||||||
public slots:
|
|
||||||
void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const;
|
|
||||||
void updateEditorGeometry(QWidget *editor, const QStyleOptionViewItem &option, const QModelIndex &) const;
|
|
||||||
void comboboxIndexChanged(int index);
|
|
||||||
|
|
||||||
private:
|
|
||||||
QTreeView *m_folderView;
|
QTreeView *m_folderView;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue