summaryrefslogtreecommitdiffstats
path: root/gui/dialogs/AccountSelectDialog.cpp
diff options
context:
space:
mode:
authorSky <git@bunnies.cc>2013-11-27 22:51:45 +0000
committerSky <git@bunnies.cc>2013-11-27 22:51:45 +0000
commitd32cb1c95d5c1a50c322085cdfe4bf3f991431e7 (patch)
tree8a31c6ed1c2da0513596d8bb82dc439101a7aec9 /gui/dialogs/AccountSelectDialog.cpp
parent70973d111a35c65072b9431420d3d854bd82e8f5 (diff)
parenta4c5f0135ef8e3671f54cf56b1aa8766ee4b4a20 (diff)
downloadMultiMC-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.cpp89
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();
+}
+