Browse Source

- Fixed file priorities

adaptive-webui-19844
Christophe Dumez 15 years ago
parent
commit
f9da85ecfe
  1. 32
      src/PropListDelegate.h
  2. 32
      src/propertieswidget.cpp
  3. 1
      src/propertieswidget.h

32
src/PropListDelegate.h

@ -49,10 +49,10 @@ enum PropPriority {IGNORED=0, NORMAL=1, HIGH=2, MAXIMUM=7}; @@ -49,10 +49,10 @@ enum PropPriority {IGNORED=0, NORMAL=1, HIGH=2, MAXIMUM=7};
class PropListDelegate: public QItemDelegate {
Q_OBJECT
signals:
void filteredFilesChanged();
signals:
void filteredFilesChanged() const;
public:
public:
PropListDelegate(QObject *parent=0) : QItemDelegate(parent){
}
@ -60,7 +60,6 @@ class PropListDelegate: public QItemDelegate { @@ -60,7 +60,6 @@ class PropListDelegate: public QItemDelegate {
void paint(QPainter * painter, const QStyleOptionViewItem & option, const QModelIndex & index) const{
QStyleOptionViewItemV2 opt = QItemDelegate::setOptions(index, option);
QPalette::ColorGroup cg = option.state & QStyle::State_Enabled ? QPalette::Normal : QPalette::Disabled;
switch(index.column()){
case SIZE:
QItemDelegate::drawBackground(painter, opt, index);
@ -100,11 +99,11 @@ class PropListDelegate: public QItemDelegate { @@ -100,11 +99,11 @@ class PropListDelegate: public QItemDelegate {
newopt.currentText = tr("Normal", "Normal (priority)");
}
newopt.state |= QStyle::State_Enabled;
QApplication::style()->drawComplexControl(QStyle::CC_ComboBox, &newopt,
painter);
opt.palette.setColor(QPalette::Text, QColor("black"));
painter->setPen(opt.palette.color(cg, QPalette::Text));
painter->drawText(option.rect, Qt::AlignLeft, QString::fromUtf8(" ")+newopt.currentText);
newopt.subControls = QStyle::SC_All;
//painter->translate(QPoint(opt.rect.x()*-1,opt.rect.y()*-1));
//QApplication::style()->drawComplexControl(QStyle::CC_ComboBox, &newopt, painter);
//painter->translate(QPoint(opt.rect.x(),opt.rect.y()));
QApplication::style()->drawControl(QStyle::CE_ComboBoxLabel, &newopt, painter);
break;
}
default:
@ -154,11 +153,12 @@ class PropListDelegate: public QItemDelegate { @@ -154,11 +153,12 @@ class PropListDelegate: public QItemDelegate {
QFontMetrics fontMetrics(fnt);
const QString text = index.data(Qt::DisplayRole).toString();
QRect textRect = QRect(0, 0, 0, fontMetrics.lineSpacing() * (text.count(QLatin1Char('\n')) + 1));
textRect.setHeight(textRect.height()+10);
return textRect.size();
}
public slots:
void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) {
void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const {
QComboBox *combobox = static_cast<QComboBox*>(editor);
int value = combobox->currentIndex();
qDebug("Setting combobox value in index: %d", value);
@ -175,15 +175,15 @@ class PropListDelegate: public QItemDelegate { @@ -175,15 +175,15 @@ class PropListDelegate: public QItemDelegate {
}
break;
case 1:
// if(old_val != NORMAL){
// model->setData(index, QVariant(NORMAL));
// if(filteredFilesChanged != 0)
// *filteredFilesChanged = true;
// } else {
// if(old_val != NORMAL){
// model->setData(index, QVariant(NORMAL));
// if(filteredFilesChanged != 0)
// *filteredFilesChanged = true;
// } else {
model->setData(index, QVariant(HIGH));
model->setData(index, QVariant(NORMAL));
emit filteredFilesChanged();
// }
// }
break;
case 2:
if(old_val != HIGH){

32
src/propertieswidget.cpp

@ -522,7 +522,7 @@ void PropertiesWidget::ignoreSelection(){ @@ -522,7 +522,7 @@ void PropertiesWidget::ignoreSelection(){
if(index.column() == PRIORITY){
if(PropListModel->data(index) != QVariant(IGNORED)){
PropListModel->setData(index, QVariant(IGNORED));
transferList->updateTorrentSizeAndProgress(h.hash());
filteredFilesChanged();
setItemColor(index, "red");
}
}
@ -535,7 +535,7 @@ void PropertiesWidget::normalSelection(){ @@ -535,7 +535,7 @@ void PropertiesWidget::normalSelection(){
if(index.column() == PRIORITY){
if(PropListModel->data(index) != QVariant(NORMAL)){
PropListModel->setData(index, QVariant(NORMAL));
transferList->updateTorrentSizeAndProgress(h.hash());
filteredFilesChanged();
setItemColor(index, "green");
}
}
@ -548,7 +548,7 @@ void PropertiesWidget::highSelection(){ @@ -548,7 +548,7 @@ void PropertiesWidget::highSelection(){
if(index.column() == PRIORITY){
if(PropListModel->data(index) != QVariant(HIGH)){
PropListModel->setData(index, QVariant(HIGH));
transferList->updateTorrentSizeAndProgress(h.hash());
filteredFilesChanged();
setItemColor(index, "green");
}
}
@ -561,7 +561,7 @@ void PropertiesWidget::maximumSelection(){ @@ -561,7 +561,7 @@ void PropertiesWidget::maximumSelection(){
if(index.column() == PRIORITY){
if(PropListModel->data(index) != QVariant(MAXIMUM)){
PropListModel->setData(index, QVariant(MAXIMUM));
transferList->updateTorrentSizeAndProgress(h.hash());
filteredFilesChanged();
setItemColor(index, "green");
}
}
@ -727,6 +727,26 @@ void PropertiesWidget::setItemColor(QModelIndex index, QString color){ @@ -727,6 +727,26 @@ void PropertiesWidget::setItemColor(QModelIndex index, QString color){
}
}
bool PropertiesWidget::savePiecesPriorities() {
/*if(!changedFilteredfiles) return true;
if(allFiltered()) {
QMessageBox::warning(0, tr("Priorities error"), tr("Error, you can't filter all the files in a torrent."));
return false;
}*/
qDebug("Saving pieces priorities");
int *priorities = new int[h.get_torrent_info().num_files()];
getPriorities(PropListModel->invisibleRootItem(), priorities);
unsigned int nbFiles = h.get_torrent_info().num_files();
for(unsigned int i=0; i<nbFiles; ++i) {
h.file_priority(i, priorities[i]);
}
delete[] priorities;
TorrentPersistentData::saveFilesPriority(h);
return true;
}
void PropertiesWidget::on_changeSavePathButton_clicked() {
QString dir;
QDir saveDir(h.save_path());
@ -755,8 +775,10 @@ void PropertiesWidget::on_changeSavePathButton_clicked() { @@ -755,8 +775,10 @@ void PropertiesWidget::on_changeSavePathButton_clicked() {
}
void PropertiesWidget::filteredFilesChanged() {
if(h.is_valid())
if(h.is_valid()) {
savePiecesPriorities();
transferList->updateTorrentSizeAndProgress(h.hash());
}
}
void PropertiesWidget::addFilesToTree(torrent_file *root, QStandardItem *parent) {

1
src/propertieswidget.h

@ -75,6 +75,7 @@ protected: @@ -75,6 +75,7 @@ protected:
QPushButton* getButtonFromIndex(int index);
std::vector<int> loadFilesPriorities();
bool allFiltered() const;
bool savePiecesPriorities();
protected slots:
void loadTorrentInfos(QTorrentHandle &h);

Loading…
Cancel
Save