Double-click to install/change version

Signed-off-by: TheKodeToad <TheKodeToad@proton.me>
This commit is contained in:
TheKodeToad 2023-07-01 19:32:04 +01:00
parent 284e374ae8
commit 9f9b5254a2
4 changed files with 27 additions and 17 deletions

View File

@ -33,13 +33,12 @@
class InstallLoaderPage : public VersionSelectWidget, public BasePage { class InstallLoaderPage : public VersionSelectWidget, public BasePage {
public: public:
InstallLoaderPage(const QString& id, InstallLoaderPage(const QString& id,
const QString& icon, const QString& icon,
const QString& name, const QString& name,
// "lightweight" loaders are independent to any game version // "lightweight" loaders are independent to any game version
const bool lightweight, const bool lightweight,
const std::shared_ptr<PackProfile> profile, const std::shared_ptr<PackProfile> profile)
QWidget* parent = nullptr) : VersionSelectWidget(nullptr), m_id(id), m_icon(icon), m_name(name)
: VersionSelectWidget(parent), m_id(id), m_icon(icon), m_name(name)
{ {
const QString minecraftVersion = profile->getComponentVersion("net.minecraft"); const QString minecraftVersion = profile->getComponentVersion("net.minecraft");
setEmptyString(tr("No versions are currently available for Minecraft %1").arg(minecraftVersion)); setEmptyString(tr("No versions are currently available for Minecraft %1").arg(minecraftVersion));
@ -67,6 +66,12 @@ class InstallLoaderPage : public VersionSelectWidget, public BasePage {
m_loaded = true; m_loaded = true;
} }
void setParentContainer(BasePageContainer* container) override
{
auto dialog = dynamic_cast<QDialog*>(dynamic_cast<PageContainer*>(container)->parent());
connect(view(), &QAbstractItemView::doubleClicked, dialog, &QDialog::accept);
}
private: private:
const QString m_id; const QString m_id;
const QString m_icon; const QString m_icon;
@ -82,7 +87,7 @@ InstallLoaderPage* pageCast(BasePage* page)
} }
InstallLoaderDialog::InstallLoaderDialog(std::shared_ptr<PackProfile> profile, const QString& uid, QWidget* parent) InstallLoaderDialog::InstallLoaderDialog(std::shared_ptr<PackProfile> profile, const QString& uid, QWidget* parent)
: QDialog(parent), m_profile(profile), m_container(new PageContainer(this)), m_buttons(new QDialogButtonBox(this)) : QDialog(parent), m_profile(profile), m_container(new PageContainer(this, QString(), this)), m_buttons(new QDialogButtonBox(this))
{ {
auto layout = new QVBoxLayout(this); auto layout = new QVBoxLayout(this);
@ -92,9 +97,7 @@ InstallLoaderDialog::InstallLoaderDialog(std::shared_ptr<PackProfile> profile, c
auto buttonLayout = new QHBoxLayout(this); auto buttonLayout = new QHBoxLayout(this);
auto refreshButton = new QPushButton(tr("&Refresh"), this); auto refreshButton = new QPushButton(tr("&Refresh"), this);
connect(refreshButton, &QPushButton::pressed, this, [this] { connect(refreshButton, &QPushButton::pressed, this, [this] { pageCast(m_container->selectedPage())->loadList(); });
pageCast(m_container->selectedPage())->loadList();
});
buttonLayout->addWidget(refreshButton); buttonLayout->addWidget(refreshButton);
m_buttons->setOrientation(Qt::Horizontal); m_buttons->setOrientation(Qt::Horizontal);
@ -117,13 +120,13 @@ InstallLoaderDialog::InstallLoaderDialog(std::shared_ptr<PackProfile> profile, c
QList<BasePage*> InstallLoaderDialog::getPages() QList<BasePage*> InstallLoaderDialog::getPages()
{ {
return { // Forge return { // Forge
new InstallLoaderPage("net.minecraftforge", "forge", tr("Forge"), false, m_profile, this), new InstallLoaderPage("net.minecraftforge", "forge", tr("Forge"), false, m_profile),
// Fabric // Fabric
new InstallLoaderPage("net.fabricmc.fabric-loader", "fabricmc-small", tr("Fabric"), true, m_profile, this), new InstallLoaderPage("net.fabricmc.fabric-loader", "fabricmc-small", tr("Fabric"), true, m_profile),
// Quilt // Quilt
new InstallLoaderPage("org.quiltmc.quilt-loader", "quiltmc", tr("Quilt"), true, m_profile, this), new InstallLoaderPage("org.quiltmc.quilt-loader", "quiltmc", tr("Quilt"), true, m_profile),
// LiteLoader // LiteLoader
new InstallLoaderPage("com.mumfrey.liteloader", "liteloader", tr("LiteLoader"), false, m_profile, this) new InstallLoaderPage("com.mumfrey.liteloader", "liteloader", tr("LiteLoader"), false, m_profile)
}; };
} }

View File

@ -75,8 +75,9 @@ VersionSelectDialog::VersionSelectDialog(BaseVersionList *vlist, QString title,
retranslate(); retranslate();
QObject::connect(m_buttonBox, SIGNAL(accepted()), this, SLOT(accept())); connect(m_buttonBox, &QDialogButtonBox::accepted, this, &QDialog::accept);
QObject::connect(m_buttonBox, SIGNAL(rejected()), this, SLOT(reject())); connect(m_versionWidget->view(), &QAbstractItemView::doubleClicked, this, &QDialog::accept);
connect(m_buttonBox, &QDialogButtonBox::rejected, this, &QDialog::reject);
QMetaObject::connectSlotsByName(this); QMetaObject::connectSlotsByName(this);
setWindowModality(Qt::WindowModal); setWindowModality(Qt::WindowModal);

View File

@ -210,6 +210,11 @@ void VersionSelectWidget::selectSearch()
search->setFocus(); search->setFocus();
} }
VersionListView* VersionSelectWidget::view()
{
return listView;
}
void VersionSelectWidget::selectRecommended() void VersionSelectWidget::selectRecommended()
{ {
auto idx = m_proxyModel->getRecommended(); auto idx = m_proxyModel->getRecommended();

View File

@ -65,6 +65,7 @@ public:
void selectRecommended(); void selectRecommended();
void selectCurrent(); void selectCurrent();
void selectSearch(); void selectSearch();
VersionListView* view();
void setCurrentVersion(const QString & version); void setCurrentVersion(const QString & version);
void setFuzzyFilter(BaseVersionList::ModelRoles role, QString filter); void setFuzzyFilter(BaseVersionList::ModelRoles role, QString filter);