make instance settings account selector a comboBox
Signed-off-by: leo78913 <leo3758@riseup.net>
This commit is contained in:
parent
d5c6a1b4d1
commit
7537ea1ef5
@ -60,15 +60,13 @@ InstanceSettingsPage::InstanceSettingsPage(BaseInstance *inst, QWidget *parent)
|
|||||||
m_settings = inst->settings();
|
m_settings = inst->settings();
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
|
||||||
accountMenu = new QMenu(this);
|
|
||||||
// Use undocumented property... https://stackoverflow.com/questions/7121718/create-a-scrollbar-in-a-submenu-qt
|
|
||||||
accountMenu->setStyleSheet("QMenu { menu-scrollable: 1; }");
|
|
||||||
ui->instanceAccountSelector->setMenu(accountMenu);
|
|
||||||
|
|
||||||
connect(ui->openGlobalJavaSettingsButton, &QCommandLinkButton::clicked, this, &InstanceSettingsPage::globalSettingsButtonClicked);
|
connect(ui->openGlobalJavaSettingsButton, &QCommandLinkButton::clicked, this, &InstanceSettingsPage::globalSettingsButtonClicked);
|
||||||
connect(APPLICATION, &Application::globalSettingsAboutToOpen, this, &InstanceSettingsPage::applySettings);
|
connect(APPLICATION, &Application::globalSettingsAboutToOpen, this, &InstanceSettingsPage::applySettings);
|
||||||
connect(APPLICATION, &Application::globalSettingsClosed, this, &InstanceSettingsPage::loadSettings);
|
connect(APPLICATION, &Application::globalSettingsClosed, this, &InstanceSettingsPage::loadSettings);
|
||||||
|
connect(ui->instanceAccountSelector, QOverload<int>::of(&QComboBox::currentIndexChanged), this, &InstanceSettingsPage::changeInstanceAccount);
|
||||||
loadSettings();
|
loadSettings();
|
||||||
|
|
||||||
|
|
||||||
updateThresholds();
|
updateThresholds();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -454,36 +452,17 @@ void InstanceSettingsPage::on_javaTestBtn_clicked()
|
|||||||
|
|
||||||
void InstanceSettingsPage::updateAccountsMenu()
|
void InstanceSettingsPage::updateAccountsMenu()
|
||||||
{
|
{
|
||||||
accountMenu->clear();
|
ui->instanceAccountSelector->clear();
|
||||||
|
|
||||||
auto accounts = APPLICATION->accounts();
|
auto accounts = APPLICATION->accounts();
|
||||||
int accountIndex = accounts->findAccountByProfileId(m_settings->get("InstanceAccountId").toString());
|
int accountIndex = accounts->findAccountByProfileId(m_settings->get("InstanceAccountId").toString());
|
||||||
MinecraftAccountPtr defaultAccount = accounts->defaultAccount();
|
|
||||||
|
|
||||||
if (accountIndex != -1 && accounts->at(accountIndex)) {
|
|
||||||
defaultAccount = accounts->at(accountIndex);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (defaultAccount) {
|
|
||||||
ui->instanceAccountSelector->setText(defaultAccount->profileName());
|
|
||||||
ui->instanceAccountSelector->setIcon(getFaceForAccount(defaultAccount));
|
|
||||||
} else {
|
|
||||||
ui->instanceAccountSelector->setText(tr("No default account"));
|
|
||||||
ui->instanceAccountSelector->setIcon(APPLICATION->getThemedIcon("noaccount"));
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int i = 0; i < accounts->count(); i++) {
|
for (int i = 0; i < accounts->count(); i++) {
|
||||||
MinecraftAccountPtr account = accounts->at(i);
|
MinecraftAccountPtr account = accounts->at(i);
|
||||||
QAction* action = new QAction(account->profileName(), this);
|
ui->instanceAccountSelector->addItem(getFaceForAccount(account), account->profileName(), i);
|
||||||
action->setData(i);
|
if (i == accountIndex)
|
||||||
action->setCheckable(true);
|
ui->instanceAccountSelector->setCurrentIndex(i);
|
||||||
if (accountIndex == i) {
|
|
||||||
action->setChecked(true);
|
|
||||||
}
|
|
||||||
action->setIcon(getFaceForAccount(account));
|
|
||||||
accountMenu->addAction(action);
|
|
||||||
connect(action, SIGNAL(triggered(bool)), this, SLOT(changeInstanceAccount()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QIcon InstanceSettingsPage::getFaceForAccount(MinecraftAccountPtr account)
|
QIcon InstanceSettingsPage::getFaceForAccount(MinecraftAccountPtr account)
|
||||||
@ -495,20 +474,13 @@ QIcon InstanceSettingsPage::getFaceForAccount(MinecraftAccountPtr account)
|
|||||||
return APPLICATION->getThemedIcon("noaccount");
|
return APPLICATION->getThemedIcon("noaccount");
|
||||||
}
|
}
|
||||||
|
|
||||||
void InstanceSettingsPage::changeInstanceAccount()
|
void InstanceSettingsPage::changeInstanceAccount(int index)
|
||||||
{
|
{
|
||||||
QAction* sAction = (QAction*)sender();
|
|
||||||
|
|
||||||
Q_ASSERT(sAction->data().type() == QVariant::Type::Int);
|
|
||||||
|
|
||||||
QVariant data = sAction->data();
|
|
||||||
int index = data.toInt();
|
|
||||||
auto accounts = APPLICATION->accounts();
|
auto accounts = APPLICATION->accounts();
|
||||||
|
if (index != -1 && accounts->at(index) && ui->instanceAccountGroupBox->isChecked()) {
|
||||||
auto account = accounts->at(index);
|
auto account = accounts->at(index);
|
||||||
m_settings->set("InstanceAccountId", account->profileId());
|
m_settings->set("InstanceAccountId", account->profileId());
|
||||||
|
}
|
||||||
ui->instanceAccountSelector->setText(account->profileName());
|
|
||||||
ui->instanceAccountSelector->setIcon(getFaceForAccount(account));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void InstanceSettingsPage::on_maxMemSpinBox_valueChanged(int i)
|
void InstanceSettingsPage::on_maxMemSpinBox_valueChanged(int i)
|
||||||
|
@ -95,12 +95,11 @@ private slots:
|
|||||||
|
|
||||||
void updateAccountsMenu();
|
void updateAccountsMenu();
|
||||||
QIcon getFaceForAccount(MinecraftAccountPtr account);
|
QIcon getFaceForAccount(MinecraftAccountPtr account);
|
||||||
void changeInstanceAccount();
|
void changeInstanceAccount(int index);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::InstanceSettingsPage *ui;
|
Ui::InstanceSettingsPage *ui;
|
||||||
BaseInstance *m_instance;
|
BaseInstance *m_instance;
|
||||||
SettingsObjectPtr m_settings;
|
SettingsObjectPtr m_settings;
|
||||||
unique_qobject_ptr<JavaCommon::TestCheck> checker;
|
unique_qobject_ptr<JavaCommon::TestCheck> checker;
|
||||||
QMenu *accountMenu = nullptr;
|
|
||||||
};
|
};
|
||||||
|
@ -636,14 +636,7 @@
|
|||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="0" column="1">
|
<item row="0" column="1">
|
||||||
<widget class="QToolButton" name="instanceAccountSelector">
|
<widget class="QComboBox" name="instanceAccountSelector"/>
|
||||||
<property name="popupMode">
|
|
||||||
<enum>QToolButton::InstantPopup</enum>
|
|
||||||
</property>
|
|
||||||
<property name="toolButtonStyle">
|
|
||||||
<enum>Qt::ToolButtonTextBesideIcon</enum>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user