From b9d429355255d10541fd14799c419a1b5aeeb128 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Petr=20Mr=C3=A1zek?= Date: Thu, 11 Jul 2019 01:01:47 +0200 Subject: NOISSUE update component buttons some more when the versions change --- application/pages/instance/VersionPage.cpp | 60 +++++++++++++----------------- application/pages/instance/VersionPage.h | 1 - 2 files changed, 26 insertions(+), 35 deletions(-) (limited to 'application/pages') diff --git a/application/pages/instance/VersionPage.cpp b/application/pages/instance/VersionPage.cpp index 6f1b9206..f27d562a 100644 --- a/application/pages/instance/VersionPage.cpp +++ b/application/pages/instance/VersionPage.cpp @@ -109,25 +109,18 @@ VersionPage::VersionPage(MinecraftInstance *inst, QWidget *parent) reloadComponentList(); - if (m_profile) - { - auto proxy = new IconProxy(ui->packageView); - proxy->setSourceModel(m_profile.get()); - ui->packageView->setModel(proxy); - ui->packageView->installEventFilter(this); - ui->packageView->setSelectionMode(QAbstractItemView::SingleSelection); - connect(ui->packageView->selectionModel(), &QItemSelectionModel::currentChanged, this, &VersionPage::versionCurrent); - auto smodel = ui->packageView->selectionModel(); - connect(smodel, &QItemSelectionModel::currentChanged, this, &VersionPage::packageCurrent); - updateVersionControls(); - // select first item. - preselect(0); - } - else - { - disableVersionControls(); - } - connect(m_inst, &MinecraftInstance::versionReloaded, this, &VersionPage::updateVersionControls); + auto proxy = new IconProxy(ui->packageView); + proxy->setSourceModel(m_profile.get()); + ui->packageView->setModel(proxy); + ui->packageView->installEventFilter(this); + ui->packageView->setSelectionMode(QAbstractItemView::SingleSelection); + connect(ui->packageView->selectionModel(), &QItemSelectionModel::currentChanged, this, &VersionPage::versionCurrent); + auto smodel = ui->packageView->selectionModel(); + connect(smodel, &QItemSelectionModel::currentChanged, this, &VersionPage::packageCurrent); + + updateVersionControls(); + preselect(0); + connect(m_profile.get(), &ComponentList::minecraftChanged, this, &VersionPage::updateVersionControls); } VersionPage::~VersionPage() @@ -181,21 +174,20 @@ void VersionPage::packageCurrent(const QModelIndex ¤t, const QModelIndex & void VersionPage::updateVersionControls() { // FIXME: this is a dirty hack - auto minecraftVersion = Version(m_profile->getComponentVersion("net.minecraft")); - bool newCraft = minecraftVersion >= Version("1.14"); - bool oldCraft = minecraftVersion <= Version("1.12.2"); - ui->fabricBtn->setEnabled(newCraft); - ui->forgeBtn->setEnabled(oldCraft); - ui->liteloaderBtn->setEnabled(oldCraft); - updateButtons(); -} - -void VersionPage::disableVersionControls() -{ - ui->fabricBtn->setEnabled(false); - ui->forgeBtn->setEnabled(false); - ui->liteloaderBtn->setEnabled(false); - ui->reloadBtn->setEnabled(false); + if(m_profile) { + auto minecraftVersion = Version(m_profile->getComponentVersion("net.minecraft")); + bool newCraft = minecraftVersion >= Version("1.14"); + bool oldCraft = minecraftVersion <= Version("1.12.2"); + ui->fabricBtn->setEnabled(newCraft); + ui->forgeBtn->setEnabled(oldCraft); + ui->liteloaderBtn->setEnabled(oldCraft); + } + else { + ui->fabricBtn->setEnabled(false); + ui->forgeBtn->setEnabled(false); + ui->liteloaderBtn->setEnabled(false); + ui->reloadBtn->setEnabled(false); + } updateButtons(); } diff --git a/application/pages/instance/VersionPage.h b/application/pages/instance/VersionPage.h index 4957c9ea..2d64120a 100644 --- a/application/pages/instance/VersionPage.h +++ b/application/pages/instance/VersionPage.h @@ -66,7 +66,6 @@ private slots: void on_downloadBtn_clicked(); void updateVersionControls(); - void disableVersionControls(); void on_changeVersionBtn_clicked(); private: -- cgit v1.2.3