forked from qt-creator/qt-creator
ManageDefinitionsDialog: download exact url in sorted TableWidget
If TableWidget was sorted by user, position in QList of metadata and in View differs. Side effects: - QTableWidget sorted by first column by default - Connections are moved to Qt5 style Change-Id: I4a15e2cc9394431719ed1e2dd88f713af43c40d0 Reviewed-by: David Schulz <david.schulz@theqtcompany.com>
This commit is contained in:
committed by
David Schulz
parent
a9014e074d
commit
102e49ca37
@@ -37,8 +37,6 @@
|
||||
#include <QFileInfo>
|
||||
#include <QMessageBox>
|
||||
|
||||
#include <QDebug>
|
||||
|
||||
using namespace TextEditor;
|
||||
using namespace Internal;
|
||||
|
||||
@@ -47,30 +45,30 @@ ManageDefinitionsDialog::ManageDefinitionsDialog(
|
||||
const QString &path,
|
||||
QWidget *parent) :
|
||||
QDialog(parent),
|
||||
m_definitionsMetaData(metaDataList),
|
||||
m_path(path)
|
||||
{
|
||||
ui.setupUi(this);
|
||||
ui.definitionsTable->setHorizontalHeaderLabels(
|
||||
QStringList() << tr("Name") << tr("Installed") << tr("Available"));
|
||||
ui.definitionsTable->horizontalHeader()->setSectionResizeMode(0, QHeaderView::Stretch);
|
||||
ui.definitionsTable->sortItems(0);
|
||||
|
||||
setWindowTitle(tr("Download Definitions"));
|
||||
|
||||
populateDefinitionsWidget();
|
||||
populateDefinitionsWidget(metaDataList);
|
||||
|
||||
connect(ui.downloadButton, SIGNAL(clicked()), this, SLOT(downloadDefinitions()));
|
||||
connect(ui.allButton, SIGNAL(clicked()), this, SLOT(selectAll()));
|
||||
connect(ui.clearButton, SIGNAL(clicked()), this, SLOT(clearSelection()));
|
||||
connect(ui.invertButton, SIGNAL(clicked()), this, SLOT(invertSelection()));
|
||||
connect(ui.downloadButton, &QPushButton::clicked, this, &ManageDefinitionsDialog::downloadDefinitions);
|
||||
connect(ui.allButton, &QPushButton::clicked, this, &ManageDefinitionsDialog::selectAll);
|
||||
connect(ui.clearButton, &QPushButton::clicked, this, &ManageDefinitionsDialog::clearSelection);
|
||||
connect(ui.invertButton, &QPushButton::clicked, this, &ManageDefinitionsDialog::invertSelection);
|
||||
}
|
||||
|
||||
void ManageDefinitionsDialog::populateDefinitionsWidget()
|
||||
void ManageDefinitionsDialog::populateDefinitionsWidget(const QList<DefinitionMetaDataPtr> &definitionsMetaData)
|
||||
{
|
||||
const int size = m_definitionsMetaData.size();
|
||||
const int size = definitionsMetaData.size();
|
||||
ui.definitionsTable->setRowCount(size);
|
||||
for (int i = 0; i < size; ++i) {
|
||||
const HighlightDefinitionMetaData &downloadData = *m_definitionsMetaData.at(i);
|
||||
const HighlightDefinitionMetaData &downloadData = *definitionsMetaData.at(i);
|
||||
|
||||
// Look for this definition in the current path specified by the user, not the one
|
||||
// stored in the settings. So the manager should not be queried for this information.
|
||||
@@ -87,6 +85,7 @@ void ManageDefinitionsDialog::populateDefinitionsWidget()
|
||||
QTableWidgetItem *item = new QTableWidgetItem;
|
||||
if (j == 0) {
|
||||
item->setText(downloadData.name);
|
||||
item->setData(Qt::UserRole, downloadData.url);
|
||||
} else if (j == 1) {
|
||||
item->setText(dirVersion);
|
||||
item->setTextAlignment(Qt::AlignCenter);
|
||||
@@ -110,8 +109,10 @@ void ManageDefinitionsDialog::downloadDefinitions()
|
||||
}
|
||||
|
||||
QList<QUrl> urls;
|
||||
foreach (const QModelIndex &index, ui.definitionsTable->selectionModel()->selectedRows())
|
||||
urls.append(m_definitionsMetaData.at(index.row())->url);
|
||||
foreach (const QModelIndex &index, ui.definitionsTable->selectionModel()->selectedRows()) {
|
||||
const QVariant url = ui.definitionsTable->item(index.row(), 0)->data(Qt::UserRole);
|
||||
urls.append(url.toUrl());
|
||||
}
|
||||
Manager::instance()->downloadDefinitions(urls, m_path);
|
||||
accept();
|
||||
}
|
||||
|
@@ -34,8 +34,6 @@
|
||||
#include "ui_managedefinitionsdialog.h"
|
||||
#include "highlightdefinitionmetadata.h"
|
||||
|
||||
#include <QList>
|
||||
|
||||
namespace TextEditor {
|
||||
namespace Internal {
|
||||
|
||||
@@ -48,16 +46,13 @@ public:
|
||||
const QString &path,
|
||||
QWidget *parent = 0);
|
||||
|
||||
private slots:
|
||||
private:
|
||||
void downloadDefinitions();
|
||||
void selectAll();
|
||||
void clearSelection();
|
||||
void invertSelection();
|
||||
void populateDefinitionsWidget(const QList<DefinitionMetaDataPtr> &definitionsMetaData);
|
||||
|
||||
private:
|
||||
void populateDefinitionsWidget();
|
||||
|
||||
QList<DefinitionMetaDataPtr> m_definitionsMetaData;
|
||||
QString m_path;
|
||||
Ui::ManageDefinitionsDialog ui;
|
||||
};
|
||||
|
Reference in New Issue
Block a user