Merge pull request #481 from ryanccn/import-resource-pack-dialog-uwu
This commit is contained in:
commit
fa98bf1ee7
@ -915,13 +915,13 @@ bool Application::createSetupWizard()
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Application::event(QEvent* event) {
|
bool Application::event(QEvent* event)
|
||||||
|
{
|
||||||
#ifdef Q_OS_MACOS
|
#ifdef Q_OS_MACOS
|
||||||
if (event->type() == QEvent::ApplicationStateChange) {
|
if (event->type() == QEvent::ApplicationStateChange) {
|
||||||
auto ev = static_cast<QApplicationStateChangeEvent*>(event);
|
auto ev = static_cast<QApplicationStateChangeEvent*>(event);
|
||||||
|
|
||||||
if (m_prevAppState == Qt::ApplicationActive
|
if (m_prevAppState == Qt::ApplicationActive && ev->applicationState() == Qt::ApplicationActive) {
|
||||||
&& ev->applicationState() == Qt::ApplicationActive) {
|
|
||||||
emit clickedOnDock();
|
emit clickedOnDock();
|
||||||
}
|
}
|
||||||
m_prevAppState = ev->applicationState();
|
m_prevAppState = ev->applicationState();
|
||||||
|
@ -796,6 +796,8 @@ SET(LAUNCHER_SOURCES
|
|||||||
ui/dialogs/ExportInstanceDialog.h
|
ui/dialogs/ExportInstanceDialog.h
|
||||||
ui/dialogs/IconPickerDialog.cpp
|
ui/dialogs/IconPickerDialog.cpp
|
||||||
ui/dialogs/IconPickerDialog.h
|
ui/dialogs/IconPickerDialog.h
|
||||||
|
ui/dialogs/ImportResourcePackDialog.cpp
|
||||||
|
ui/dialogs/ImportResourcePackDialog.h
|
||||||
ui/dialogs/LoginDialog.cpp
|
ui/dialogs/LoginDialog.cpp
|
||||||
ui/dialogs/LoginDialog.h
|
ui/dialogs/LoginDialog.h
|
||||||
ui/dialogs/MSALoginDialog.cpp
|
ui/dialogs/MSALoginDialog.cpp
|
||||||
@ -944,6 +946,7 @@ qt_wrap_ui(LAUNCHER_UI
|
|||||||
ui/dialogs/SkinUploadDialog.ui
|
ui/dialogs/SkinUploadDialog.ui
|
||||||
ui/dialogs/ExportInstanceDialog.ui
|
ui/dialogs/ExportInstanceDialog.ui
|
||||||
ui/dialogs/IconPickerDialog.ui
|
ui/dialogs/IconPickerDialog.ui
|
||||||
|
ui/dialogs/ImportResourcePackDialog.ui
|
||||||
ui/dialogs/MSALoginDialog.ui
|
ui/dialogs/MSALoginDialog.ui
|
||||||
ui/dialogs/OfflineLoginDialog.ui
|
ui/dialogs/OfflineLoginDialog.ui
|
||||||
ui/dialogs/AboutDialog.ui
|
ui/dialogs/AboutDialog.ui
|
||||||
|
@ -15,7 +15,7 @@ static const QMap<int, std::pair<Version, Version>> s_pack_format_versions = {
|
|||||||
{ 3, { Version("1.11"), Version("1.12.2") } }, { 4, { Version("1.13"), Version("1.14.4") } },
|
{ 3, { Version("1.11"), Version("1.12.2") } }, { 4, { Version("1.13"), Version("1.14.4") } },
|
||||||
{ 5, { Version("1.15"), Version("1.16.1") } }, { 6, { Version("1.16.2"), Version("1.16.5") } },
|
{ 5, { Version("1.15"), Version("1.16.1") } }, { 6, { Version("1.16.2"), Version("1.16.5") } },
|
||||||
{ 7, { Version("1.17"), Version("1.17.1") } }, { 8, { Version("1.18"), Version("1.18.2") } },
|
{ 7, { Version("1.17"), Version("1.17.1") } }, { 8, { Version("1.18"), Version("1.18.2") } },
|
||||||
{ 9, { Version("1.19"), Version("1.19.2") } },
|
{ 9, { Version("1.19"), Version("1.19.2") } }, { 11, { Version("1.19.3"), Version("1.19.3") } },
|
||||||
};
|
};
|
||||||
|
|
||||||
void ResourcePack::setPackFormat(int new_format_id)
|
void ResourcePack::setPackFormat(int new_format_id)
|
||||||
@ -114,3 +114,8 @@ bool ResourcePack::applyFilter(QRegularExpression filter) const
|
|||||||
|
|
||||||
return Resource::applyFilter(filter);
|
return Resource::applyFilter(filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool ResourcePack::valid() const
|
||||||
|
{
|
||||||
|
return m_pack_format != 0;
|
||||||
|
}
|
||||||
|
@ -42,6 +42,8 @@ class ResourcePack : public Resource {
|
|||||||
/** Thread-safe. */
|
/** Thread-safe. */
|
||||||
void setImage(QImage new_image);
|
void setImage(QImage new_image);
|
||||||
|
|
||||||
|
bool valid() const override;
|
||||||
|
|
||||||
[[nodiscard]] auto compare(Resource const& other, SortType type) const -> std::pair<int, bool> override;
|
[[nodiscard]] auto compare(Resource const& other, SortType type) const -> std::pair<int, bool> override;
|
||||||
[[nodiscard]] bool applyFilter(QRegularExpression filter) const override;
|
[[nodiscard]] bool applyFilter(QRegularExpression filter) const override;
|
||||||
|
|
||||||
|
@ -62,3 +62,8 @@ QPixmap TexturePack::image(QSize size)
|
|||||||
TexturePackUtils::process(*this);
|
TexturePackUtils::process(*this);
|
||||||
return image(size);
|
return image(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool TexturePack::valid() const
|
||||||
|
{
|
||||||
|
return m_description != nullptr;
|
||||||
|
}
|
||||||
|
@ -48,6 +48,8 @@ class TexturePack : public Resource {
|
|||||||
/** Thread-safe. */
|
/** Thread-safe. */
|
||||||
void setImage(QImage new_image);
|
void setImage(QImage new_image);
|
||||||
|
|
||||||
|
bool valid() const override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
mutable QMutex m_data_lock;
|
mutable QMutex m_data_lock;
|
||||||
|
|
||||||
|
@ -28,14 +28,14 @@
|
|||||||
|
|
||||||
namespace ResourcePackUtils {
|
namespace ResourcePackUtils {
|
||||||
|
|
||||||
bool process(ResourcePack& pack)
|
bool process(ResourcePack& pack, ProcessingLevel level)
|
||||||
{
|
{
|
||||||
switch (pack.type()) {
|
switch (pack.type()) {
|
||||||
case ResourceType::FOLDER:
|
case ResourceType::FOLDER:
|
||||||
ResourcePackUtils::processFolder(pack);
|
ResourcePackUtils::processFolder(pack, level);
|
||||||
return true;
|
return true;
|
||||||
case ResourceType::ZIPFILE:
|
case ResourceType::ZIPFILE:
|
||||||
ResourcePackUtils::processZIP(pack);
|
ResourcePackUtils::processZIP(pack, level);
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
qWarning() << "Invalid type for resource pack parse task!";
|
qWarning() << "Invalid type for resource pack parse task!";
|
||||||
@ -43,7 +43,7 @@ bool process(ResourcePack& pack)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void processFolder(ResourcePack& pack)
|
void processFolder(ResourcePack& pack, ProcessingLevel level)
|
||||||
{
|
{
|
||||||
Q_ASSERT(pack.type() == ResourceType::FOLDER);
|
Q_ASSERT(pack.type() == ResourceType::FOLDER);
|
||||||
|
|
||||||
@ -60,6 +60,9 @@ void processFolder(ResourcePack& pack)
|
|||||||
mcmeta_file.close();
|
mcmeta_file.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (level == ProcessingLevel::BasicInfoOnly)
|
||||||
|
return;
|
||||||
|
|
||||||
QFileInfo image_file_info(FS::PathCombine(pack.fileinfo().filePath(), "pack.png"));
|
QFileInfo image_file_info(FS::PathCombine(pack.fileinfo().filePath(), "pack.png"));
|
||||||
if (image_file_info.isFile()) {
|
if (image_file_info.isFile()) {
|
||||||
QFile mcmeta_file(image_file_info.filePath());
|
QFile mcmeta_file(image_file_info.filePath());
|
||||||
@ -74,7 +77,7 @@ void processFolder(ResourcePack& pack)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void processZIP(ResourcePack& pack)
|
void processZIP(ResourcePack& pack, ProcessingLevel level)
|
||||||
{
|
{
|
||||||
Q_ASSERT(pack.type() == ResourceType::ZIPFILE);
|
Q_ASSERT(pack.type() == ResourceType::ZIPFILE);
|
||||||
|
|
||||||
@ -98,6 +101,11 @@ void processZIP(ResourcePack& pack)
|
|||||||
file.close();
|
file.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (level == ProcessingLevel::BasicInfoOnly) {
|
||||||
|
zip.close();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (zip.setCurrentFile("pack.png")) {
|
if (zip.setCurrentFile("pack.png")) {
|
||||||
if (!file.open(QIODevice::ReadOnly)) {
|
if (!file.open(QIODevice::ReadOnly)) {
|
||||||
qCritical() << "Failed to open file in zip.";
|
qCritical() << "Failed to open file in zip.";
|
||||||
@ -138,6 +146,13 @@ void processPackPNG(ResourcePack& pack, QByteArray&& raw_data)
|
|||||||
qWarning() << "Failed to parse pack.png.";
|
qWarning() << "Failed to parse pack.png.";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool validate(QFileInfo file)
|
||||||
|
{
|
||||||
|
ResourcePack rp{ file };
|
||||||
|
return ResourcePackUtils::process(rp, ProcessingLevel::BasicInfoOnly) && rp.valid();
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace ResourcePackUtils
|
} // namespace ResourcePackUtils
|
||||||
|
|
||||||
LocalResourcePackParseTask::LocalResourcePackParseTask(int token, ResourcePack& rp)
|
LocalResourcePackParseTask::LocalResourcePackParseTask(int token, ResourcePack& rp)
|
||||||
@ -152,8 +167,6 @@ bool LocalResourcePackParseTask::abort()
|
|||||||
|
|
||||||
void LocalResourcePackParseTask::executeTask()
|
void LocalResourcePackParseTask::executeTask()
|
||||||
{
|
{
|
||||||
Q_ASSERT(m_resource_pack.valid());
|
|
||||||
|
|
||||||
if (!ResourcePackUtils::process(m_resource_pack))
|
if (!ResourcePackUtils::process(m_resource_pack))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -26,13 +26,19 @@
|
|||||||
#include "tasks/Task.h"
|
#include "tasks/Task.h"
|
||||||
|
|
||||||
namespace ResourcePackUtils {
|
namespace ResourcePackUtils {
|
||||||
bool process(ResourcePack& pack);
|
|
||||||
|
|
||||||
void processZIP(ResourcePack& pack);
|
enum class ProcessingLevel { Full, BasicInfoOnly };
|
||||||
void processFolder(ResourcePack& pack);
|
|
||||||
|
bool process(ResourcePack& pack, ProcessingLevel level = ProcessingLevel::Full);
|
||||||
|
|
||||||
|
void processZIP(ResourcePack& pack, ProcessingLevel level = ProcessingLevel::Full);
|
||||||
|
void processFolder(ResourcePack& pack, ProcessingLevel level = ProcessingLevel::Full);
|
||||||
|
|
||||||
void processMCMeta(ResourcePack& pack, QByteArray&& raw_data);
|
void processMCMeta(ResourcePack& pack, QByteArray&& raw_data);
|
||||||
void processPackPNG(ResourcePack& pack, QByteArray&& raw_data);
|
void processPackPNG(ResourcePack& pack, QByteArray&& raw_data);
|
||||||
|
|
||||||
|
/** Checks whether a file is valid as a resource pack or not. */
|
||||||
|
bool validate(QFileInfo file);
|
||||||
} // namespace ResourcePackUtils
|
} // namespace ResourcePackUtils
|
||||||
|
|
||||||
class LocalResourcePackParseTask : public Task {
|
class LocalResourcePackParseTask : public Task {
|
||||||
|
@ -28,14 +28,14 @@
|
|||||||
|
|
||||||
namespace TexturePackUtils {
|
namespace TexturePackUtils {
|
||||||
|
|
||||||
bool process(TexturePack& pack)
|
bool process(TexturePack& pack, ProcessingLevel level)
|
||||||
{
|
{
|
||||||
switch (pack.type()) {
|
switch (pack.type()) {
|
||||||
case ResourceType::FOLDER:
|
case ResourceType::FOLDER:
|
||||||
TexturePackUtils::processFolder(pack);
|
TexturePackUtils::processFolder(pack, level);
|
||||||
return true;
|
return true;
|
||||||
case ResourceType::ZIPFILE:
|
case ResourceType::ZIPFILE:
|
||||||
TexturePackUtils::processZIP(pack);
|
TexturePackUtils::processZIP(pack, level);
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
qWarning() << "Invalid type for resource pack parse task!";
|
qWarning() << "Invalid type for resource pack parse task!";
|
||||||
@ -43,7 +43,7 @@ bool process(TexturePack& pack)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void processFolder(TexturePack& pack)
|
void processFolder(TexturePack& pack, ProcessingLevel level)
|
||||||
{
|
{
|
||||||
Q_ASSERT(pack.type() == ResourceType::FOLDER);
|
Q_ASSERT(pack.type() == ResourceType::FOLDER);
|
||||||
|
|
||||||
@ -60,6 +60,9 @@ void processFolder(TexturePack& pack)
|
|||||||
mcmeta_file.close();
|
mcmeta_file.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (level == ProcessingLevel::BasicInfoOnly)
|
||||||
|
return;
|
||||||
|
|
||||||
QFileInfo image_file_info(FS::PathCombine(pack.fileinfo().filePath(), "pack.png"));
|
QFileInfo image_file_info(FS::PathCombine(pack.fileinfo().filePath(), "pack.png"));
|
||||||
if (image_file_info.isFile()) {
|
if (image_file_info.isFile()) {
|
||||||
QFile mcmeta_file(image_file_info.filePath());
|
QFile mcmeta_file(image_file_info.filePath());
|
||||||
@ -74,7 +77,7 @@ void processFolder(TexturePack& pack)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void processZIP(TexturePack& pack)
|
void processZIP(TexturePack& pack, ProcessingLevel level)
|
||||||
{
|
{
|
||||||
Q_ASSERT(pack.type() == ResourceType::ZIPFILE);
|
Q_ASSERT(pack.type() == ResourceType::ZIPFILE);
|
||||||
|
|
||||||
@ -98,6 +101,11 @@ void processZIP(TexturePack& pack)
|
|||||||
file.close();
|
file.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (level == ProcessingLevel::BasicInfoOnly) {
|
||||||
|
zip.close();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (zip.setCurrentFile("pack.png")) {
|
if (zip.setCurrentFile("pack.png")) {
|
||||||
if (!file.open(QIODevice::ReadOnly)) {
|
if (!file.open(QIODevice::ReadOnly)) {
|
||||||
qCritical() << "Failed to open file in zip.";
|
qCritical() << "Failed to open file in zip.";
|
||||||
@ -129,6 +137,13 @@ void processPackPNG(TexturePack& pack, QByteArray&& raw_data)
|
|||||||
qWarning() << "Failed to parse pack.png.";
|
qWarning() << "Failed to parse pack.png.";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool validate(QFileInfo file)
|
||||||
|
{
|
||||||
|
TexturePack rp{ file };
|
||||||
|
return TexturePackUtils::process(rp, ProcessingLevel::BasicInfoOnly) && rp.valid();
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace TexturePackUtils
|
} // namespace TexturePackUtils
|
||||||
|
|
||||||
LocalTexturePackParseTask::LocalTexturePackParseTask(int token, TexturePack& rp)
|
LocalTexturePackParseTask::LocalTexturePackParseTask(int token, TexturePack& rp)
|
||||||
@ -143,8 +158,6 @@ bool LocalTexturePackParseTask::abort()
|
|||||||
|
|
||||||
void LocalTexturePackParseTask::executeTask()
|
void LocalTexturePackParseTask::executeTask()
|
||||||
{
|
{
|
||||||
Q_ASSERT(m_texture_pack.valid());
|
|
||||||
|
|
||||||
if (!TexturePackUtils::process(m_texture_pack))
|
if (!TexturePackUtils::process(m_texture_pack))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -27,13 +27,19 @@
|
|||||||
#include "tasks/Task.h"
|
#include "tasks/Task.h"
|
||||||
|
|
||||||
namespace TexturePackUtils {
|
namespace TexturePackUtils {
|
||||||
bool process(TexturePack& pack);
|
|
||||||
|
|
||||||
void processZIP(TexturePack& pack);
|
enum class ProcessingLevel { Full, BasicInfoOnly };
|
||||||
void processFolder(TexturePack& pack);
|
|
||||||
|
bool process(TexturePack& pack, ProcessingLevel level = ProcessingLevel::Full);
|
||||||
|
|
||||||
|
void processZIP(TexturePack& pack, ProcessingLevel level = ProcessingLevel::Full);
|
||||||
|
void processFolder(TexturePack& pack, ProcessingLevel level = ProcessingLevel::Full);
|
||||||
|
|
||||||
void processPackTXT(TexturePack& pack, QByteArray&& raw_data);
|
void processPackTXT(TexturePack& pack, QByteArray&& raw_data);
|
||||||
void processPackPNG(TexturePack& pack, QByteArray&& raw_data);
|
void processPackPNG(TexturePack& pack, QByteArray&& raw_data);
|
||||||
|
|
||||||
|
/** Checks whether a file is valid as a texture pack or not. */
|
||||||
|
bool validate(QFileInfo file);
|
||||||
} // namespace TexturePackUtils
|
} // namespace TexturePackUtils
|
||||||
|
|
||||||
class LocalTexturePackParseTask : public Task {
|
class LocalTexturePackParseTask : public Task {
|
||||||
|
@ -72,6 +72,7 @@
|
|||||||
|
|
||||||
#include <BaseInstance.h>
|
#include <BaseInstance.h>
|
||||||
#include <InstanceList.h>
|
#include <InstanceList.h>
|
||||||
|
#include <minecraft/MinecraftInstance.h>
|
||||||
#include <MMCZip.h>
|
#include <MMCZip.h>
|
||||||
#include <icons/IconList.h>
|
#include <icons/IconList.h>
|
||||||
#include <java/JavaUtils.h>
|
#include <java/JavaUtils.h>
|
||||||
@ -107,8 +108,14 @@
|
|||||||
#include "ui/dialogs/UpdateDialog.h"
|
#include "ui/dialogs/UpdateDialog.h"
|
||||||
#include "ui/dialogs/EditAccountDialog.h"
|
#include "ui/dialogs/EditAccountDialog.h"
|
||||||
#include "ui/dialogs/ExportInstanceDialog.h"
|
#include "ui/dialogs/ExportInstanceDialog.h"
|
||||||
|
#include "ui/dialogs/ImportResourcePackDialog.h"
|
||||||
#include "ui/themes/ITheme.h"
|
#include "ui/themes/ITheme.h"
|
||||||
|
|
||||||
|
#include <minecraft/mod/ResourcePackFolderModel.h>
|
||||||
|
#include <minecraft/mod/tasks/LocalResourcePackParseTask.h>
|
||||||
|
#include <minecraft/mod/TexturePackFolderModel.h>
|
||||||
|
#include <minecraft/mod/tasks/LocalTexturePackParseTask.h>
|
||||||
|
|
||||||
#include "UpdateController.h"
|
#include "UpdateController.h"
|
||||||
#include "KonamiCode.h"
|
#include "KonamiCode.h"
|
||||||
|
|
||||||
@ -1808,17 +1815,41 @@ void MainWindow::on_actionAddInstance_triggered()
|
|||||||
|
|
||||||
void MainWindow::droppedURLs(QList<QUrl> urls)
|
void MainWindow::droppedURLs(QList<QUrl> urls)
|
||||||
{
|
{
|
||||||
for(auto & url:urls)
|
// NOTE: This loop only processes one dropped file!
|
||||||
{
|
for (auto& url : urls) {
|
||||||
if(url.isLocalFile())
|
// The isLocalFile() check below doesn't work as intended without an explicit scheme.
|
||||||
{
|
if (url.scheme().isEmpty())
|
||||||
addInstance(url.toLocalFile());
|
url.setScheme("file");
|
||||||
}
|
|
||||||
else
|
if (!url.isLocalFile()) { // probably instance/modpack
|
||||||
{
|
|
||||||
addInstance(url.toString());
|
addInstance(url.toString());
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
// Only process one dropped file...
|
|
||||||
|
auto localFileName = url.toLocalFile();
|
||||||
|
QFileInfo localFileInfo(localFileName);
|
||||||
|
|
||||||
|
bool isResourcePack = ResourcePackUtils::validate(localFileInfo);
|
||||||
|
bool isTexturePack = TexturePackUtils::validate(localFileInfo);
|
||||||
|
|
||||||
|
if (!isResourcePack && !isTexturePack) { // probably instance/modpack
|
||||||
|
addInstance(localFileName);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
ImportResourcePackDialog dlg(this);
|
||||||
|
|
||||||
|
if (dlg.exec() != QDialog::Accepted)
|
||||||
|
break;
|
||||||
|
|
||||||
|
qDebug() << "Adding resource/texture pack" << localFileName << "to" << dlg.selectedInstanceKey;
|
||||||
|
|
||||||
|
auto inst = APPLICATION->instances()->getInstanceById(dlg.selectedInstanceKey);
|
||||||
|
auto minecraftInst = std::dynamic_pointer_cast<MinecraftInstance>(inst);
|
||||||
|
if (isResourcePack)
|
||||||
|
minecraftInst->resourcePackList()->installResource(localFileName);
|
||||||
|
else if (isTexturePack)
|
||||||
|
minecraftInst->texturePackList()->installResource(localFileName);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
66
launcher/ui/dialogs/ImportResourcePackDialog.cpp
Normal file
66
launcher/ui/dialogs/ImportResourcePackDialog.cpp
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
#include "ImportResourcePackDialog.h"
|
||||||
|
#include "ui_ImportResourcePackDialog.h"
|
||||||
|
|
||||||
|
#include <QFileDialog>
|
||||||
|
#include <QPushButton>
|
||||||
|
|
||||||
|
#include "Application.h"
|
||||||
|
#include "InstanceList.h"
|
||||||
|
|
||||||
|
#include <InstanceList.h>
|
||||||
|
#include "ui/instanceview/InstanceProxyModel.h"
|
||||||
|
#include "ui/instanceview/InstanceDelegate.h"
|
||||||
|
|
||||||
|
ImportResourcePackDialog::ImportResourcePackDialog(QWidget* parent) : QDialog(parent), ui(new Ui::ImportResourcePackDialog)
|
||||||
|
{
|
||||||
|
ui->setupUi(this);
|
||||||
|
setWindowModality(Qt::WindowModal);
|
||||||
|
|
||||||
|
auto contentsWidget = ui->instanceView;
|
||||||
|
contentsWidget->setViewMode(QListView::ListMode);
|
||||||
|
contentsWidget->setFlow(QListView::LeftToRight);
|
||||||
|
contentsWidget->setIconSize(QSize(48, 48));
|
||||||
|
contentsWidget->setMovement(QListView::Static);
|
||||||
|
contentsWidget->setResizeMode(QListView::Adjust);
|
||||||
|
contentsWidget->setSelectionMode(QAbstractItemView::SingleSelection);
|
||||||
|
contentsWidget->setSpacing(5);
|
||||||
|
contentsWidget->setWordWrap(true);
|
||||||
|
contentsWidget->setWrapping(true);
|
||||||
|
// NOTE: We can't have uniform sizes because the text may wrap if it's too long. If we set this, it will cut off the wrapped text.
|
||||||
|
contentsWidget->setUniformItemSizes(false);
|
||||||
|
contentsWidget->setVerticalScrollMode(QAbstractItemView::ScrollPerPixel);
|
||||||
|
contentsWidget->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOn);
|
||||||
|
contentsWidget->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
|
||||||
|
contentsWidget->setItemDelegate(new ListViewDelegate());
|
||||||
|
|
||||||
|
proxyModel = new InstanceProxyModel(this);
|
||||||
|
proxyModel->setSourceModel(APPLICATION->instances().get());
|
||||||
|
proxyModel->sort(0);
|
||||||
|
contentsWidget->setModel(proxyModel);
|
||||||
|
|
||||||
|
connect(contentsWidget, SIGNAL(doubleClicked(QModelIndex)), SLOT(activated(QModelIndex)));
|
||||||
|
connect(contentsWidget->selectionModel(), SIGNAL(selectionChanged(QItemSelection, QItemSelection)),
|
||||||
|
SLOT(selectionChanged(QItemSelection, QItemSelection)));
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImportResourcePackDialog::activated(QModelIndex index)
|
||||||
|
{
|
||||||
|
selectedInstanceKey = index.data(InstanceList::InstanceIDRole).toString();
|
||||||
|
accept();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ImportResourcePackDialog::selectionChanged(QItemSelection selected, QItemSelection deselected)
|
||||||
|
{
|
||||||
|
if (selected.empty())
|
||||||
|
return;
|
||||||
|
|
||||||
|
QString key = selected.first().indexes().first().data(InstanceList::InstanceIDRole).toString();
|
||||||
|
if (!key.isEmpty()) {
|
||||||
|
selectedInstanceKey = key;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ImportResourcePackDialog::~ImportResourcePackDialog()
|
||||||
|
{
|
||||||
|
delete ui;
|
||||||
|
}
|
27
launcher/ui/dialogs/ImportResourcePackDialog.h
Normal file
27
launcher/ui/dialogs/ImportResourcePackDialog.h
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QDialog>
|
||||||
|
#include <QItemSelection>
|
||||||
|
|
||||||
|
#include "ui/instanceview/InstanceProxyModel.h"
|
||||||
|
|
||||||
|
namespace Ui {
|
||||||
|
class ImportResourcePackDialog;
|
||||||
|
}
|
||||||
|
|
||||||
|
class ImportResourcePackDialog : public QDialog {
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
explicit ImportResourcePackDialog(QWidget* parent = 0);
|
||||||
|
~ImportResourcePackDialog();
|
||||||
|
InstanceProxyModel* proxyModel;
|
||||||
|
QString selectedInstanceKey;
|
||||||
|
|
||||||
|
private:
|
||||||
|
Ui::ImportResourcePackDialog* ui;
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
void selectionChanged(QItemSelection, QItemSelection);
|
||||||
|
void activated(QModelIndex);
|
||||||
|
};
|
74
launcher/ui/dialogs/ImportResourcePackDialog.ui
Normal file
74
launcher/ui/dialogs/ImportResourcePackDialog.ui
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<ui version="4.0">
|
||||||
|
<class>ImportResourcePackDialog</class>
|
||||||
|
<widget class="QDialog" name="ImportResourcePackDialog">
|
||||||
|
<property name="geometry">
|
||||||
|
<rect>
|
||||||
|
<x>0</x>
|
||||||
|
<y>0</y>
|
||||||
|
<width>676</width>
|
||||||
|
<height>555</height>
|
||||||
|
</rect>
|
||||||
|
</property>
|
||||||
|
<property name="windowTitle">
|
||||||
|
<string>Choose instance to import</string>
|
||||||
|
</property>
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
|
<item>
|
||||||
|
<widget class="QLabel" name="label">
|
||||||
|
<property name="text">
|
||||||
|
<string>Choose the instance you would like to import this resource pack to.</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QListView" name="instanceView"/>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QDialogButtonBox" name="buttonBox">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="standardButtons">
|
||||||
|
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
|
<resources/>
|
||||||
|
<connections>
|
||||||
|
<connection>
|
||||||
|
<sender>buttonBox</sender>
|
||||||
|
<signal>accepted()</signal>
|
||||||
|
<receiver>ImportResourcePackDialog</receiver>
|
||||||
|
<slot>accept()</slot>
|
||||||
|
<hints>
|
||||||
|
<hint type="sourcelabel">
|
||||||
|
<x>248</x>
|
||||||
|
<y>254</y>
|
||||||
|
</hint>
|
||||||
|
<hint type="destinationlabel">
|
||||||
|
<x>157</x>
|
||||||
|
<y>274</y>
|
||||||
|
</hint>
|
||||||
|
</hints>
|
||||||
|
</connection>
|
||||||
|
<connection>
|
||||||
|
<sender>buttonBox</sender>
|
||||||
|
<signal>rejected()</signal>
|
||||||
|
<receiver>ImportResourcePackDialog</receiver>
|
||||||
|
<slot>reject()</slot>
|
||||||
|
<hints>
|
||||||
|
<hint type="sourcelabel">
|
||||||
|
<x>316</x>
|
||||||
|
<y>260</y>
|
||||||
|
</hint>
|
||||||
|
<hint type="destinationlabel">
|
||||||
|
<x>286</x>
|
||||||
|
<y>274</y>
|
||||||
|
</hint>
|
||||||
|
</hints>
|
||||||
|
</connection>
|
||||||
|
</connections>
|
||||||
|
</ui>
|
Loading…
Reference in New Issue
Block a user