GH-922 improve version select dialogs
This commit is contained in:
parent
4fc4a17256
commit
5779ffd664
@ -12,7 +12,6 @@
|
|||||||
#include <QDesktopServices>
|
#include <QDesktopServices>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
|
|
||||||
#include "dialogs/VersionSelectDialog.h"
|
|
||||||
#include "InstanceList.h"
|
#include "InstanceList.h"
|
||||||
#include "auth/MojangAccountList.h"
|
#include "auth/MojangAccountList.h"
|
||||||
#include "icons/IconList.h"
|
#include "icons/IconList.h"
|
||||||
|
@ -21,8 +21,6 @@
|
|||||||
#include "ui_CopyInstanceDialog.h"
|
#include "ui_CopyInstanceDialog.h"
|
||||||
|
|
||||||
#include "Platform.h"
|
#include "Platform.h"
|
||||||
#include "dialogs/VersionSelectDialog.h"
|
|
||||||
#include "dialogs/ProgressDialog.h"
|
|
||||||
#include "dialogs/IconPickerDialog.h"
|
#include "dialogs/IconPickerDialog.h"
|
||||||
|
|
||||||
#include "BaseVersion.h"
|
#include "BaseVersion.h"
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include <QHeaderView>
|
#include <QHeaderView>
|
||||||
|
|
||||||
#include <dialogs/ProgressDialog.h>
|
#include <dialogs/ProgressDialog.h>
|
||||||
|
#include "CustomMessageBox.h"
|
||||||
#include "Platform.h"
|
#include "Platform.h"
|
||||||
|
|
||||||
#include <BaseVersion.h>
|
#include <BaseVersion.h>
|
||||||
@ -46,6 +47,7 @@ VersionSelectDialog::VersionSelectDialog(BaseVersionList *vlist, QString title,
|
|||||||
ui->listView->setModel(m_proxyModel);
|
ui->listView->setModel(m_proxyModel);
|
||||||
ui->listView->header()->setSectionResizeMode(QHeaderView::ResizeToContents);
|
ui->listView->header()->setSectionResizeMode(QHeaderView::ResizeToContents);
|
||||||
ui->listView->header()->setSectionResizeMode(resizeOnColumn, QHeaderView::Stretch);
|
ui->listView->header()->setSectionResizeMode(resizeOnColumn, QHeaderView::Stretch);
|
||||||
|
ui->sneakyProgressBar->setHidden(true);
|
||||||
|
|
||||||
if (!cancelable)
|
if (!cancelable)
|
||||||
{
|
{
|
||||||
@ -58,6 +60,11 @@ void VersionSelectDialog::setEmptyString(QString emptyString)
|
|||||||
ui->listView->setEmptyString(emptyString);
|
ui->listView->setEmptyString(emptyString);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VersionSelectDialog::setEmptyErrorString(QString emptyErrorString)
|
||||||
|
{
|
||||||
|
ui->listView->setEmptyErrorString(emptyErrorString);
|
||||||
|
}
|
||||||
|
|
||||||
VersionSelectDialog::~VersionSelectDialog()
|
VersionSelectDialog::~VersionSelectDialog()
|
||||||
{
|
{
|
||||||
delete ui;
|
delete ui;
|
||||||
@ -77,26 +84,89 @@ int VersionSelectDialog::exec()
|
|||||||
{
|
{
|
||||||
loadList();
|
loadList();
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (m_proxyModel->rowCount() == 0)
|
||||||
|
{
|
||||||
|
ui->listView->setEmptyMode(VersionListView::String);
|
||||||
|
}
|
||||||
|
preselect();
|
||||||
|
}
|
||||||
|
return QDialog::exec();
|
||||||
|
}
|
||||||
|
|
||||||
|
void VersionSelectDialog::closeEvent(QCloseEvent * event)
|
||||||
|
{
|
||||||
|
if(loadTask)
|
||||||
|
{
|
||||||
|
loadTask->abort();
|
||||||
|
loadTask->deleteLater();
|
||||||
|
loadTask = nullptr;
|
||||||
|
}
|
||||||
|
QDialog::closeEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
void VersionSelectDialog::loadList()
|
||||||
|
{
|
||||||
|
if(loadTask)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
loadTask = m_vlist->getLoadTask();
|
||||||
|
if (!loadTask)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
connect(loadTask, &Task::finished, this, &VersionSelectDialog::onTaskFinished);
|
||||||
|
connect(loadTask, &Task::progress, this, &VersionSelectDialog::changeProgress);
|
||||||
|
loadTask->start();
|
||||||
|
ui->sneakyProgressBar->setHidden(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
void VersionSelectDialog::onTaskFinished()
|
||||||
|
{
|
||||||
|
if (!loadTask->successful())
|
||||||
|
{
|
||||||
|
CustomMessageBox::selectable(this, tr("Error"),
|
||||||
|
tr("List update failed:\n%1").arg(loadTask->failReason()),
|
||||||
|
QMessageBox::Warning)->show();
|
||||||
|
if (m_proxyModel->rowCount() == 0)
|
||||||
|
{
|
||||||
|
ui->listView->setEmptyMode(VersionListView::ErrorString);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (m_proxyModel->rowCount() == 0)
|
||||||
|
{
|
||||||
|
ui->listView->setEmptyMode(VersionListView::String);
|
||||||
|
}
|
||||||
|
ui->sneakyProgressBar->setHidden(true);
|
||||||
|
loadTask->deleteLater();
|
||||||
|
loadTask = nullptr;
|
||||||
|
preselect();
|
||||||
|
}
|
||||||
|
|
||||||
|
void VersionSelectDialog::changeProgress(qint64 current, qint64 total)
|
||||||
|
{
|
||||||
|
ui->sneakyProgressBar->setMaximum(total);
|
||||||
|
ui->sneakyProgressBar->setValue(current);
|
||||||
|
}
|
||||||
|
|
||||||
|
void VersionSelectDialog::preselect()
|
||||||
|
{
|
||||||
|
if(preselectedAlready)
|
||||||
|
return;
|
||||||
|
preselectedAlready = true;
|
||||||
|
selectRecommended();
|
||||||
|
}
|
||||||
|
|
||||||
|
void VersionSelectDialog::selectRecommended()
|
||||||
|
{
|
||||||
auto idx = m_proxyModel->getRecommended();
|
auto idx = m_proxyModel->getRecommended();
|
||||||
if(idx.isValid())
|
if(idx.isValid())
|
||||||
{
|
{
|
||||||
ui->listView->selectionModel()->setCurrentIndex(idx,QItemSelectionModel::SelectCurrent | QItemSelectionModel::Rows);
|
ui->listView->selectionModel()->setCurrentIndex(idx,QItemSelectionModel::SelectCurrent | QItemSelectionModel::Rows);
|
||||||
ui->listView->scrollTo(idx, QAbstractItemView::PositionAtCenter);
|
ui->listView->scrollTo(idx, QAbstractItemView::PositionAtCenter);
|
||||||
}
|
}
|
||||||
return QDialog::exec();
|
|
||||||
}
|
|
||||||
|
|
||||||
void VersionSelectDialog::loadList()
|
|
||||||
{
|
|
||||||
Task *loadTask = m_vlist->getLoadTask();
|
|
||||||
if (!loadTask)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
ProgressDialog *taskDlg = new ProgressDialog(this);
|
|
||||||
loadTask->setParent(taskDlg);
|
|
||||||
taskDlg->exec(loadTask);
|
|
||||||
delete taskDlg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
BaseVersionPtr VersionSelectDialog::selectedVersion() const
|
BaseVersionPtr VersionSelectDialog::selectedVersion() const
|
||||||
|
@ -46,19 +46,34 @@ public:
|
|||||||
void setFuzzyFilter(BaseVersionList::ModelRoles role, QString filter);
|
void setFuzzyFilter(BaseVersionList::ModelRoles role, QString filter);
|
||||||
void setExactFilter(BaseVersionList::ModelRoles role, QString filter);
|
void setExactFilter(BaseVersionList::ModelRoles role, QString filter);
|
||||||
void setEmptyString(QString emptyString);
|
void setEmptyString(QString emptyString);
|
||||||
|
void setEmptyErrorString(QString emptyErrorString);
|
||||||
void setResizeOn(int column);
|
void setResizeOn(int column);
|
||||||
void setUseLatest(const bool useLatest);
|
void setUseLatest(const bool useLatest);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual void closeEvent ( QCloseEvent* );
|
||||||
|
|
||||||
private
|
private
|
||||||
slots:
|
slots:
|
||||||
void on_refreshButton_clicked();
|
void on_refreshButton_clicked();
|
||||||
|
|
||||||
|
void onTaskFinished();
|
||||||
|
void changeProgress(qint64 current, qint64 total);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::VersionSelectDialog *ui;
|
void preselect();
|
||||||
|
void selectRecommended();
|
||||||
|
|
||||||
BaseVersionList *m_vlist;
|
private:
|
||||||
|
Ui::VersionSelectDialog *ui = nullptr;
|
||||||
|
|
||||||
VersionProxyModel *m_proxyModel;
|
BaseVersionList *m_vlist = nullptr;
|
||||||
|
|
||||||
|
VersionProxyModel *m_proxyModel = nullptr;
|
||||||
|
|
||||||
int resizeOnColumn = 0;
|
int resizeOnColumn = 0;
|
||||||
|
|
||||||
|
Task * loadTask = nullptr;
|
||||||
|
|
||||||
|
bool preselectedAlready = false;
|
||||||
};
|
};
|
||||||
|
@ -39,6 +39,16 @@
|
|||||||
</attribute>
|
</attribute>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QProgressBar" name="sneakyProgressBar">
|
||||||
|
<property name="value">
|
||||||
|
<number>24</number>
|
||||||
|
</property>
|
||||||
|
<property name="format">
|
||||||
|
<string notr="true">%p%</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout">
|
<layout class="QHBoxLayout" name="horizontalLayout">
|
||||||
<item>
|
<item>
|
||||||
|
@ -272,6 +272,7 @@ void VersionPage::on_forgeBtn_clicked()
|
|||||||
vselect.setExactFilter(BaseVersionList::ParentGameVersionRole, m_inst->currentVersionId());
|
vselect.setExactFilter(BaseVersionList::ParentGameVersionRole, m_inst->currentVersionId());
|
||||||
vselect.setEmptyString(tr("No Forge versions are currently available for Minecraft ") +
|
vselect.setEmptyString(tr("No Forge versions are currently available for Minecraft ") +
|
||||||
m_inst->currentVersionId());
|
m_inst->currentVersionId());
|
||||||
|
vselect.setEmptyErrorString(tr("Couldn't load or download the Forge version lists!"));
|
||||||
if (vselect.exec() && vselect.selectedVersion())
|
if (vselect.exec() && vselect.selectedVersion())
|
||||||
{
|
{
|
||||||
ProgressDialog dialog(this);
|
ProgressDialog dialog(this);
|
||||||
@ -287,6 +288,7 @@ void VersionPage::on_liteloaderBtn_clicked()
|
|||||||
vselect.setExactFilter(BaseVersionList::ParentGameVersionRole, m_inst->currentVersionId());
|
vselect.setExactFilter(BaseVersionList::ParentGameVersionRole, m_inst->currentVersionId());
|
||||||
vselect.setEmptyString(tr("No LiteLoader versions are currently available for Minecraft ") +
|
vselect.setEmptyString(tr("No LiteLoader versions are currently available for Minecraft ") +
|
||||||
m_inst->currentVersionId());
|
m_inst->currentVersionId());
|
||||||
|
vselect.setEmptyErrorString(tr("Couldn't load or download the LiteLoader version lists!"));
|
||||||
if (vselect.exec() && vselect.selectedVersion())
|
if (vselect.exec() && vselect.selectedVersion())
|
||||||
{
|
{
|
||||||
ProgressDialog dialog(this);
|
ProgressDialog dialog(this);
|
||||||
|
@ -65,6 +65,23 @@ void VersionListView::reset()
|
|||||||
void VersionListView::setEmptyString(QString emptyString)
|
void VersionListView::setEmptyString(QString emptyString)
|
||||||
{
|
{
|
||||||
m_emptyString = emptyString;
|
m_emptyString = emptyString;
|
||||||
|
updateEmptyViewPort();
|
||||||
|
}
|
||||||
|
|
||||||
|
void VersionListView::setEmptyErrorString(QString emptyErrorString)
|
||||||
|
{
|
||||||
|
m_emptyErrorString = emptyErrorString;
|
||||||
|
updateEmptyViewPort();
|
||||||
|
}
|
||||||
|
|
||||||
|
void VersionListView::setEmptyMode(VersionListView::EmptyMode mode)
|
||||||
|
{
|
||||||
|
m_emptyMode = mode;
|
||||||
|
updateEmptyViewPort();
|
||||||
|
}
|
||||||
|
|
||||||
|
void VersionListView::updateEmptyViewPort()
|
||||||
|
{
|
||||||
if(!m_itemCount)
|
if(!m_itemCount)
|
||||||
{
|
{
|
||||||
viewport()->update();
|
viewport()->update();
|
||||||
@ -85,6 +102,18 @@ void VersionListView::paintEvent(QPaintEvent *event)
|
|||||||
|
|
||||||
void VersionListView::paintInfoLabel(QPaintEvent *event)
|
void VersionListView::paintInfoLabel(QPaintEvent *event)
|
||||||
{
|
{
|
||||||
|
QString emptyString;
|
||||||
|
switch(m_emptyMode)
|
||||||
|
{
|
||||||
|
case VersionListView::Empty:
|
||||||
|
return;
|
||||||
|
case VersionListView::String:
|
||||||
|
emptyString = m_emptyString;
|
||||||
|
break;
|
||||||
|
case VersionListView::ErrorString:
|
||||||
|
emptyString = m_emptyErrorString;
|
||||||
|
break;
|
||||||
|
}
|
||||||
//calculate the rect for the overlay
|
//calculate the rect for the overlay
|
||||||
QPainter painter(viewport());
|
QPainter painter(viewport());
|
||||||
painter.setRenderHint(QPainter::Antialiasing, true);
|
painter.setRenderHint(QPainter::Antialiasing, true);
|
||||||
@ -93,7 +122,7 @@ void VersionListView::paintInfoLabel(QPaintEvent *event)
|
|||||||
|
|
||||||
QRect bounds = viewport()->geometry();
|
QRect bounds = viewport()->geometry();
|
||||||
bounds.moveTop(0);
|
bounds.moveTop(0);
|
||||||
QTextLayout layout(m_emptyString, font);
|
QTextLayout layout(emptyString, font);
|
||||||
qreal height = 0.0;
|
qreal height = 0.0;
|
||||||
qreal widthUsed = 0.0;
|
qreal widthUsed = 0.0;
|
||||||
QStringList lines = viewItemTextLayout(layout, bounds.width() - 20, height, widthUsed);
|
QStringList lines = viewItemTextLayout(layout, bounds.width() - 20, height, widthUsed);
|
||||||
|
@ -22,11 +22,22 @@ class VersionListView : public QTreeView
|
|||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
|
|
||||||
explicit VersionListView(QWidget *parent = 0);
|
explicit VersionListView(QWidget *parent = 0);
|
||||||
virtual void paintEvent(QPaintEvent *event) override;
|
virtual void paintEvent(QPaintEvent *event) override;
|
||||||
void setEmptyString(QString emptyString);
|
|
||||||
virtual void setModel ( QAbstractItemModel* model );
|
virtual void setModel ( QAbstractItemModel* model );
|
||||||
|
|
||||||
|
enum EmptyMode
|
||||||
|
{
|
||||||
|
Empty,
|
||||||
|
String,
|
||||||
|
ErrorString
|
||||||
|
};
|
||||||
|
|
||||||
|
void setEmptyString(QString emptyString);
|
||||||
|
void setEmptyErrorString(QString emptyErrorString);
|
||||||
|
void setEmptyMode(EmptyMode mode);
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
virtual void reset() override;
|
virtual void reset() override;
|
||||||
|
|
||||||
@ -36,8 +47,11 @@ protected slots:
|
|||||||
|
|
||||||
private: /* methods */
|
private: /* methods */
|
||||||
void paintInfoLabel(QPaintEvent *event);
|
void paintInfoLabel(QPaintEvent *event);
|
||||||
|
void updateEmptyViewPort();
|
||||||
|
|
||||||
private: /* variables */
|
private: /* variables */
|
||||||
int m_itemCount = 0;
|
int m_itemCount = 0;
|
||||||
QString m_emptyString;
|
QString m_emptyString;
|
||||||
|
QString m_emptyErrorString;
|
||||||
|
EmptyMode m_emptyMode = Empty;
|
||||||
};
|
};
|
||||||
|
@ -144,6 +144,11 @@ void ForgeListLoadTask::executeTask()
|
|||||||
listJob->start();
|
listJob->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ForgeListLoadTask::abort()
|
||||||
|
{
|
||||||
|
listJob->abort();
|
||||||
|
}
|
||||||
|
|
||||||
bool ForgeListLoadTask::parseForgeList(QList<BaseVersionPtr> &out)
|
bool ForgeListLoadTask::parseForgeList(QList<BaseVersionPtr> &out)
|
||||||
{
|
{
|
||||||
QByteArray data;
|
QByteArray data;
|
||||||
|
@ -66,6 +66,7 @@ public:
|
|||||||
explicit ForgeListLoadTask(ForgeVersionList *vlist);
|
explicit ForgeListLoadTask(ForgeVersionList *vlist);
|
||||||
|
|
||||||
virtual void executeTask();
|
virtual void executeTask();
|
||||||
|
virtual void abort();
|
||||||
|
|
||||||
protected
|
protected
|
||||||
slots:
|
slots:
|
||||||
|
@ -44,6 +44,7 @@ void Task::emitFailed(QString reason)
|
|||||||
m_failReason = reason;
|
m_failReason = reason;
|
||||||
qCritical() << "Task failed: " << reason;
|
qCritical() << "Task failed: " << reason;
|
||||||
emit failed(reason);
|
emit failed(reason);
|
||||||
|
emit finished();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Task::emitSucceeded()
|
void Task::emitSucceeded()
|
||||||
@ -53,6 +54,7 @@ void Task::emitSucceeded()
|
|||||||
m_succeeded = true;
|
m_succeeded = true;
|
||||||
qDebug() << "Task succeeded";
|
qDebug() << "Task succeeded";
|
||||||
emit succeeded();
|
emit succeeded();
|
||||||
|
emit finished();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Task::isRunning() const
|
bool Task::isRunning() const
|
||||||
|
@ -42,6 +42,7 @@ public:
|
|||||||
signals:
|
signals:
|
||||||
void started();
|
void started();
|
||||||
void progress(qint64 current, qint64 total);
|
void progress(qint64 current, qint64 total);
|
||||||
|
void finished();
|
||||||
void succeeded();
|
void succeeded();
|
||||||
void failed(QString reason);
|
void failed(QString reason);
|
||||||
void status(QString status);
|
void status(QString status);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user