diff options
author | Sky <git@bunnies.cc> | 2013-11-27 22:51:45 +0000 |
---|---|---|
committer | Sky <git@bunnies.cc> | 2013-11-27 22:51:45 +0000 |
commit | d32cb1c95d5c1a50c322085cdfe4bf3f991431e7 (patch) | |
tree | 8a31c6ed1c2da0513596d8bb82dc439101a7aec9 /gui/dialogs/AccountSelectDialog.cpp | |
parent | 70973d111a35c65072b9431420d3d854bd82e8f5 (diff) | |
parent | a4c5f0135ef8e3671f54cf56b1aa8766ee4b4a20 (diff) | |
download | MultiMC-d32cb1c95d5c1a50c322085cdfe4bf3f991431e7.tar MultiMC-d32cb1c95d5c1a50c322085cdfe4bf3f991431e7.tar.gz MultiMC-d32cb1c95d5c1a50c322085cdfe4bf3f991431e7.tar.lz MultiMC-d32cb1c95d5c1a50c322085cdfe4bf3f991431e7.tar.xz MultiMC-d32cb1c95d5c1a50c322085cdfe4bf3f991431e7.zip |
Merge remote-tracking branch 'upstream/feature_yggdrasil' into develop
Diffstat (limited to 'gui/dialogs/AccountSelectDialog.cpp')
-rw-r--r-- | gui/dialogs/AccountSelectDialog.cpp | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/gui/dialogs/AccountSelectDialog.cpp b/gui/dialogs/AccountSelectDialog.cpp new file mode 100644 index 00000000..1da6d84f --- /dev/null +++ b/gui/dialogs/AccountSelectDialog.cpp @@ -0,0 +1,89 @@ +/* Copyright 2013 MultiMC Contributors + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "AccountSelectDialog.h" +#include "ui_AccountSelectDialog.h" + +#include <QItemSelectionModel> + +#include <logger/QsLog.h> + +#include <logic/auth/AuthenticateTask.h> + +#include <gui/dialogs/LoginDialog.h> +#include <gui/dialogs/ProgressDialog.h> + +#include <MultiMC.h> + +AccountSelectDialog::AccountSelectDialog(const QString& message, int flags, QWidget *parent) : + QDialog(parent), + ui(new Ui::AccountSelectDialog) +{ + ui->setupUi(this); + + m_accounts = MMC->accounts(); + ui->listView->setModel(m_accounts.get()); + ui->listView->hideColumn(MojangAccountList::ActiveColumn); + + // Set the message label. + ui->msgLabel->setVisible(!message.isEmpty()); + ui->msgLabel->setText(message); + + // Flags... + ui->globalDefaultCheck->setVisible(flags & GlobalDefaultCheckbox); + ui->instDefaultCheck->setVisible(flags & InstanceDefaultCheckbox); + QLOG_DEBUG() << flags; + + // Select the first entry in the list. + ui->listView->setCurrentIndex(ui->listView->model()->index(0, 0)); +} + +AccountSelectDialog::~AccountSelectDialog() +{ + delete ui; +} + +MojangAccountPtr AccountSelectDialog::selectedAccount() const +{ + return m_selected; +} + +bool AccountSelectDialog::useAsGlobalDefault() const +{ + return ui->globalDefaultCheck->isChecked(); +} + +bool AccountSelectDialog::useAsInstDefaullt() const +{ + return ui->instDefaultCheck->isChecked(); +} + +void AccountSelectDialog::on_buttonBox_accepted() +{ + QModelIndexList selection = ui->listView->selectionModel()->selectedIndexes(); + if (selection.size() > 0) + { + QModelIndex selected = selection.first(); + MojangAccountPtr account = selected.data(MojangAccountList::PointerRole).value<MojangAccountPtr>(); + m_selected = account; + } + close(); +} + +void AccountSelectDialog::on_buttonBox_rejected() +{ + close(); +} + |