mirror of
https://github.com/MultiMC/MultiMC5.git
synced 2025-01-27 06:35:17 +00:00
Allow users to filter out MCNostalgia and Snapshots from the version list.
Resolves JIRA issue MMC-9: https://jira.forkk.net/browse/MMC-9
This commit is contained in:
parent
857a4e4dbe
commit
74133bb172
@ -18,6 +18,8 @@
|
|||||||
|
|
||||||
#include <QHeaderView>
|
#include <QHeaderView>
|
||||||
|
|
||||||
|
#include <QDebug>
|
||||||
|
|
||||||
#include <gui/taskdialog.h>
|
#include <gui/taskdialog.h>
|
||||||
|
|
||||||
#include <instversionlist.h>
|
#include <instversionlist.h>
|
||||||
@ -31,9 +33,18 @@ VersionSelectDialog::VersionSelectDialog(InstVersionList *vlist, QWidget *parent
|
|||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
|
||||||
m_vlist = vlist;
|
m_vlist = vlist;
|
||||||
ui->listView->setModel(m_vlist);
|
|
||||||
|
m_proxyModel = new QSortFilterProxyModel(this);
|
||||||
|
m_proxyModel->setSourceModel(vlist);
|
||||||
|
|
||||||
|
ui->listView->setModel(m_proxyModel);
|
||||||
ui->listView->header()->setSectionResizeMode(QHeaderView::ResizeToContents);
|
ui->listView->header()->setSectionResizeMode(QHeaderView::ResizeToContents);
|
||||||
ui->listView->header()->setSectionResizeMode(0, QHeaderView::Stretch);
|
ui->listView->header()->setSectionResizeMode(0, QHeaderView::Stretch);
|
||||||
|
|
||||||
|
connect(ui->filterSnapshotsCheckbox, SIGNAL(clicked()), SLOT(updateFilterState()));
|
||||||
|
connect(ui->filterMCNostalgiaCheckbox, SIGNAL(clicked()), SLOT(updateFilterState()));
|
||||||
|
|
||||||
|
updateFilterState();
|
||||||
}
|
}
|
||||||
|
|
||||||
VersionSelectDialog::~VersionSelectDialog()
|
VersionSelectDialog::~VersionSelectDialog()
|
||||||
@ -60,13 +71,32 @@ void VersionSelectDialog::loadList()
|
|||||||
const InstVersion *VersionSelectDialog::selectedVersion() const
|
const InstVersion *VersionSelectDialog::selectedVersion() const
|
||||||
{
|
{
|
||||||
const InstVersion *versionPtr = (const InstVersion *)
|
const InstVersion *versionPtr = (const InstVersion *)
|
||||||
m_vlist->data(ui->listView->selectionModel()->currentIndex(),
|
m_proxyModel->data(ui->listView->selectionModel()->currentIndex(),
|
||||||
InstVersionList::VersionPointerRole).value<void *>();
|
InstVersionList::VersionPointerRole).value<void *>();
|
||||||
|
|
||||||
return versionPtr;
|
return versionPtr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void VersionSelectDialog::on_refreshButton_clicked()
|
void VersionSelectDialog::on_refreshButton_clicked()
|
||||||
{
|
{
|
||||||
loadList();
|
loadList();
|
||||||
|
}
|
||||||
|
|
||||||
|
void VersionSelectDialog::updateFilterState()
|
||||||
|
{
|
||||||
|
m_proxyModel->setFilterKeyColumn(InstVersionList::TypeColumn);
|
||||||
|
|
||||||
|
QStringList filteredTypes;
|
||||||
|
if (!ui->filterSnapshotsCheckbox->isChecked())
|
||||||
|
filteredTypes += "Snapshot";
|
||||||
|
if (!ui->filterMCNostalgiaCheckbox->isChecked())
|
||||||
|
filteredTypes += "MCNostalgia";
|
||||||
|
|
||||||
|
QString regexStr = "^.*$";
|
||||||
|
if (filteredTypes.length() > 0)
|
||||||
|
regexStr = QString("^((?!%1).)*$").arg(filteredTypes.join('|'));
|
||||||
|
|
||||||
|
qDebug() << "Filter:" << regexStr;
|
||||||
|
|
||||||
|
m_proxyModel->setFilterRegExp(regexStr);
|
||||||
}
|
}
|
||||||
|
@ -18,6 +18,8 @@
|
|||||||
|
|
||||||
#include <QDialog>
|
#include <QDialog>
|
||||||
|
|
||||||
|
#include <QSortFilterProxyModel>
|
||||||
|
|
||||||
class InstVersionList;
|
class InstVersionList;
|
||||||
class InstVersion;
|
class InstVersion;
|
||||||
|
|
||||||
@ -44,10 +46,14 @@ public:
|
|||||||
private slots:
|
private slots:
|
||||||
void on_refreshButton_clicked();
|
void on_refreshButton_clicked();
|
||||||
|
|
||||||
|
void updateFilterState();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::VersionSelectDialog *ui;
|
Ui::VersionSelectDialog *ui;
|
||||||
|
|
||||||
InstVersionList *m_vlist;
|
InstVersionList *m_vlist;
|
||||||
|
|
||||||
|
QSortFilterProxyModel *m_proxyModel;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // VERSIONSELECTDIALOG_H
|
#endif // VERSIONSELECTDIALOG_H
|
||||||
|
@ -36,6 +36,24 @@
|
|||||||
</attribute>
|
</attribute>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item>
|
||||||
|
<layout class="QHBoxLayout" name="filterCheckboxLayout1">
|
||||||
|
<item>
|
||||||
|
<widget class="QCheckBox" name="filterSnapshotsCheckbox">
|
||||||
|
<property name="text">
|
||||||
|
<string>Show &snapshots?</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QCheckBox" name="filterMCNostalgiaCheckbox">
|
||||||
|
<property name="text">
|
||||||
|
<string>Show MC&Nostalgia?</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout">
|
<layout class="QHBoxLayout" name="horizontalLayout">
|
||||||
<item>
|
<item>
|
||||||
|
@ -46,6 +46,18 @@ public:
|
|||||||
VersionPointerRole = 0x34B1CB48
|
VersionPointerRole = 0x34B1CB48
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum VListColumns
|
||||||
|
{
|
||||||
|
// First column - Name
|
||||||
|
NameColumn = 0,
|
||||||
|
|
||||||
|
// Second column - Type
|
||||||
|
TypeColumn,
|
||||||
|
|
||||||
|
// Third column - Timestamp
|
||||||
|
TimeColumn
|
||||||
|
};
|
||||||
|
|
||||||
explicit InstVersionList(QObject *parent = 0);
|
explicit InstVersionList(QObject *parent = 0);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -39,22 +39,6 @@ const InstVersion *InstVersionList::getLatestStable()
|
|||||||
return at(0);
|
return at(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Column Enum
|
|
||||||
enum VListColumns
|
|
||||||
{
|
|
||||||
// First column - Name
|
|
||||||
NameColumn = 0,
|
|
||||||
|
|
||||||
// Second column - Type
|
|
||||||
TypeColumn,
|
|
||||||
|
|
||||||
// Third column - Timestamp
|
|
||||||
TimeColumn,
|
|
||||||
|
|
||||||
// Column count
|
|
||||||
ColCount
|
|
||||||
};
|
|
||||||
|
|
||||||
QVariant InstVersionList::data(const QModelIndex &index, int role) const
|
QVariant InstVersionList::data(const QModelIndex &index, int role) const
|
||||||
{
|
{
|
||||||
if (!index.isValid())
|
if (!index.isValid())
|
||||||
@ -141,5 +125,5 @@ int InstVersionList::rowCount(const QModelIndex &parent) const
|
|||||||
|
|
||||||
int InstVersionList::columnCount(const QModelIndex &parent) const
|
int InstVersionList::columnCount(const QModelIndex &parent) const
|
||||||
{
|
{
|
||||||
return ColCount;
|
return 2;
|
||||||
}
|
}
|
||||||
|
@ -63,7 +63,7 @@ QString MinecraftVersion::typeName() const
|
|||||||
switch (versionType())
|
switch (versionType())
|
||||||
{
|
{
|
||||||
case OldSnapshot:
|
case OldSnapshot:
|
||||||
return "Old Snapshot";
|
return "Snapshot";
|
||||||
|
|
||||||
case Stable:
|
case Stable:
|
||||||
return "Stable";
|
return "Stable";
|
||||||
|
Loading…
x
Reference in New Issue
Block a user