From e118b1f9901d8d006dbe268b4b4047de27e4531d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Petr=20Mr=C3=A1zek?= Date: Mon, 19 May 2014 02:22:09 +0200 Subject: Implement adding jar mods, break saving library order. --- gui/dialogs/InstanceEditDialog.cpp | 47 ++++++++++++++++++++++++-------------- gui/dialogs/InstanceEditDialog.h | 2 +- 2 files changed, 31 insertions(+), 18 deletions(-) (limited to 'gui/dialogs') diff --git a/gui/dialogs/InstanceEditDialog.cpp b/gui/dialogs/InstanceEditDialog.cpp index 48657c71..496d6973 100644 --- a/gui/dialogs/InstanceEditDialog.cpp +++ b/gui/dialogs/InstanceEditDialog.cpp @@ -35,7 +35,7 @@ #include "InstanceSettings.h" #include "logic/ModList.h" -#include "logic/minecraft/VersionFinal.h" +#include "logic/minecraft/InstanceVersion.h" #include "logic/EnabledItemFilter.h" #include "logic/forge/ForgeVersionList.h" #include "logic/forge/ForgeInstaller.h" @@ -175,21 +175,34 @@ void InstanceEditDialog::on_removeLibraryBtn_clicked() void InstanceEditDialog::on_jarmodBtn_clicked() { QFileDialog w; - w.setFileMode(QFileDialog::AnyFile); - // w.setOption(QFileDialog::DontUseNativeDialog, true); - QListView *l = w.findChild("listView"); - if (l) + QSet locations; + QString modsFolder = MMC->settings()->get("CentralModsDir").toString(); + auto f = [&](QStandardPaths::StandardLocation l) { - l->setSelectionMode(QAbstractItemView::ExtendedSelection); - } - QTreeView *t = w.findChild(); - if (t) - { - t->setSelectionMode(QAbstractItemView::ExtendedSelection); - } - int result = w.exec(); - auto list = w.selectedFiles(); - QLOG_INFO() << list.join(" "); + QString location = QStandardPaths::writableLocation(l); + if(!QFileInfo::exists(location)) + return; + locations.insert(location); + }; + f(QStandardPaths::DesktopLocation); + f(QStandardPaths::DocumentsLocation); + f(QStandardPaths::DownloadLocation); + f(QStandardPaths::HomeLocation); + QList urls; + for(auto location: locations) + { + urls.append(QUrl::fromLocalFile(location)); + } + urls.append(QUrl::fromLocalFile(modsFolder)); + + w.setFileMode(QFileDialog::ExistingFiles); + w.setAcceptMode(QFileDialog::AcceptOpen); + w.setNameFilter(tr("Minecraft jar mods (*.zip *.jar)")); + w.setDirectory(modsFolder); + w.setSidebarUrls(urls); + + if(w.exec()); + m_version->installJarMods(w.selectedFiles()); } void InstanceEditDialog::on_resetLibraryOrderBtn_clicked() @@ -214,7 +227,7 @@ void InstanceEditDialog::on_moveLibraryUpBtn_clicked() { const int row = ui->libraryTreeView->selectionModel()->selectedRows().first().row(); const int newRow = 0; - m_version->move(row, VersionFinal::MoveUp); + m_version->move(row, InstanceVersion::MoveUp); // ui->libraryTreeView->selectionModel()->setCurrentIndex(m_version->index(newRow), // QItemSelectionModel::ClearAndSelect); } @@ -234,7 +247,7 @@ void InstanceEditDialog::on_moveLibraryDownBtn_clicked() { const int row = ui->libraryTreeView->selectionModel()->selectedRows().first().row(); const int newRow = 0; - m_version->move(row, VersionFinal::MoveDown); + m_version->move(row, InstanceVersion::MoveDown); // ui->libraryTreeView->selectionModel()->setCurrentIndex(m_version->index(newRow), // QItemSelectionModel::ClearAndSelect); } diff --git a/gui/dialogs/InstanceEditDialog.h b/gui/dialogs/InstanceEditDialog.h index e99899be..7661ff7f 100644 --- a/gui/dialogs/InstanceEditDialog.h +++ b/gui/dialogs/InstanceEditDialog.h @@ -80,7 +80,7 @@ protected: private: Ui::InstanceEditDialog *ui; - std::shared_ptr m_version; + std::shared_ptr m_version; std::shared_ptr m_mods; std::shared_ptr m_coremods; std::shared_ptr m_jarmods; -- cgit v1.2.3