Add selectable message box helper, use it, make login GUI error label selectable
This commit is contained in:
		| @@ -217,6 +217,8 @@ gui/EditNotesDialog.h | ||||
| gui/EditNotesDialog.cpp | ||||
| gui/MCModInfoFrame.h | ||||
| gui/MCModInfoFrame.cpp | ||||
| gui/CustomMessageBox.h | ||||
| gui/CustomMessageBox.cpp | ||||
|  | ||||
| # Base classes and infrastructure | ||||
| logic/BaseVersion.h | ||||
|   | ||||
							
								
								
									
										19
									
								
								gui/CustomMessageBox.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								gui/CustomMessageBox.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| #include "CustomMessageBox.h" | ||||
|  | ||||
| namespace CustomMessageBox | ||||
| { | ||||
| 	QMessageBox *selectable(QWidget *parent, const QString &title, const QString &text, | ||||
| 							QMessageBox::Icon icon,	QMessageBox::StandardButtons buttons, | ||||
| 							QMessageBox::StandardButton defaultButton) | ||||
| 	{ | ||||
| 		QMessageBox *messageBox = new QMessageBox(parent); | ||||
| 		messageBox->setWindowTitle(title); | ||||
| 		messageBox->setText(text); | ||||
| 		messageBox->setStandardButtons(buttons); | ||||
| 		messageBox->setDefaultButton(defaultButton); | ||||
| 		messageBox->setTextInteractionFlags(Qt::TextSelectableByMouse); | ||||
| 		messageBox->setIcon(icon); | ||||
|  | ||||
| 		return messageBox; | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										11
									
								
								gui/CustomMessageBox.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								gui/CustomMessageBox.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <QMessageBox> | ||||
|  | ||||
| namespace CustomMessageBox | ||||
| { | ||||
| 	QMessageBox *selectable(QWidget *parent, const QString &title, const QString &text, | ||||
| 							QMessageBox::Icon icon = QMessageBox::NoIcon, | ||||
| 							QMessageBox::StandardButtons buttons = QMessageBox::Ok, | ||||
| 							QMessageBox::StandardButton defaultButton = QMessageBox::NoButton); | ||||
| } | ||||
| @@ -20,7 +20,7 @@ LabeledToolButton::LabeledToolButton(QWidget * parent) | ||||
| 	m_label->setWordWrap(true); | ||||
| 	m_label->setMouseTracking(false); | ||||
| 	m_label->setAlignment(Qt::AlignCenter); | ||||
| 	m_label->setTextInteractionFlags(Qt::NoTextInteraction); | ||||
| 	m_label->setTextInteractionFlags(Qt::TextSelectableByMouse); | ||||
| 	// somehow, this makes word wrap work in the QLabel. yay. | ||||
| 	m_label->setMinimumWidth(100); | ||||
| } | ||||
| @@ -69,4 +69,4 @@ void LabeledToolButton::resizeEvent(QResizeEvent * event) | ||||
| { | ||||
| 	m_label->setGeometry(QRect(4, 4, width()-8, height()-8)); | ||||
| 	QWidget::resizeEvent(event); | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -15,6 +15,7 @@ | ||||
|  | ||||
| #include "MCModInfoFrame.h" | ||||
| #include "ui_MCModInfoFrame.h" | ||||
| #include "CustomMessageBox.h" | ||||
| #include <QMessageBox> | ||||
| #include <QtGui> | ||||
| void MCModInfoFrame::updateWithMod(Mod &m) | ||||
| @@ -104,7 +105,5 @@ void MCModInfoFrame::setModDescription(QString text) | ||||
| } | ||||
| void MCModInfoFrame::modDescEllipsisHandler(const QString &link) | ||||
| { | ||||
| 	QMessageBox msgbox; | ||||
| 	msgbox.setText(desc); | ||||
| 	msgbox.exec(); | ||||
| 	CustomMessageBox::selectable(this, tr(""), desc)->show(); | ||||
| } | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| #include "ModEditDialogCommon.h" | ||||
| #include "CustomMessageBox.h" | ||||
| #include <QDesktopServices> | ||||
| #include <QMessageBox> | ||||
| #include <QString> | ||||
| @@ -33,8 +34,8 @@ void showWebsiteForMod(QWidget *parentDlg, Mod &m) | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		QMessageBox::warning( | ||||
| 			parentDlg, parentDlg->tr("How sad!"), | ||||
| 			parentDlg->tr("The mod author didn't provide a website link for this mod.")); | ||||
| 		CustomMessageBox::selectable(parentDlg, parentDlg->tr("How sad!"), | ||||
| 									 parentDlg->tr("The mod author didn't provide a website link for this mod."), | ||||
| 									 QMessageBox::Warning); | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -23,6 +23,7 @@ | ||||
| #include "logic/ForgeInstaller.h" | ||||
| #include "gui/versionselectdialog.h" | ||||
| #include "gui/platform.h" | ||||
| #include "gui/CustomMessageBox.h" | ||||
| #include "ProgressDialog.h" | ||||
|  | ||||
| #include <pathutils.h> | ||||
| @@ -110,11 +111,11 @@ void OneSixModEditDialog::on_customizeBtn_clicked() | ||||
|  | ||||
| void OneSixModEditDialog::on_revertBtn_clicked() | ||||
| { | ||||
| 	auto reply = QMessageBox::question( | ||||
| 		this, tr("Revert?"), tr("Do you want to revert the " | ||||
| 								"version of this instance to its original configuration?"), | ||||
| 		QMessageBox::Yes | QMessageBox::No); | ||||
| 	if (reply == QMessageBox::Yes) | ||||
| 	auto response = CustomMessageBox::selectable(this, tr("Revert?"), | ||||
| 												tr("Do you want to revert the " | ||||
| 												"version of this instance to its original configuration?"), | ||||
| 												QMessageBox::Question, QMessageBox::Yes | QMessageBox::No)->exec(); | ||||
| 	if (response == QMessageBox::Yes) | ||||
| 	{ | ||||
| 		if (m_inst->revertCustomVersion()) | ||||
| 		{ | ||||
|   | ||||
| @@ -5,6 +5,7 @@ | ||||
| #include <QMessageBox> | ||||
|  | ||||
| #include <gui/platform.h> | ||||
| #include <gui/CustomMessageBox.h> | ||||
|  | ||||
| ConsoleWindow::ConsoleWindow(MinecraftProcess *mcproc, QWidget *parent) : | ||||
| 	QDialog(parent), | ||||
| @@ -96,17 +97,13 @@ void ConsoleWindow::closeEvent(QCloseEvent * event) | ||||
| void ConsoleWindow::on_btnKillMinecraft_clicked() | ||||
| { | ||||
| 	ui->btnKillMinecraft->setEnabled(false); | ||||
| 	QMessageBox r_u_sure; | ||||
| 	//: Main question of the kill confirmation dialog | ||||
| 	r_u_sure.setText(tr("Kill Minecraft?")); | ||||
| 	r_u_sure.setInformativeText(tr("This can cause the instance to get corrupted and should only be used if Minecraft is frozen for some reason")); | ||||
| 	r_u_sure.setStandardButtons(QMessageBox::Yes | QMessageBox::No); | ||||
| 	r_u_sure.setDefaultButton(QMessageBox::Yes); | ||||
| 	if (r_u_sure.exec() == QMessageBox::Yes) | ||||
| 	auto response = CustomMessageBox::selectable(this, tr("Kill Minecraft?"), | ||||
| 												 tr("This can cause the instance to get corrupted and should only be used if Minecraft is frozen for some reason"), | ||||
| 												 QMessageBox::Question, QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes)->exec(); | ||||
| 	if (response == QMessageBox::Yes) | ||||
| 		proc->killMinecraft(); | ||||
| 	else | ||||
| 		ui->btnKillMinecraft->setEnabled(true); | ||||
| 	r_u_sure.close(); | ||||
| } | ||||
|  | ||||
| void ConsoleWindow::onEnded(BaseInstance *instance) | ||||
|   | ||||
| @@ -19,6 +19,9 @@ | ||||
|      <property name="text"> | ||||
|       <string><span style=" color:#ff0000;">Error</span></string> | ||||
|      </property> | ||||
|      <property name="textInteractionFlags"> | ||||
|       <set>Qt::LinksAccessibleByMouse|Qt::TextSelectableByMouse</set> | ||||
|      </property> | ||||
|     </widget> | ||||
|    </item> | ||||
|    <item> | ||||
|   | ||||
| @@ -50,6 +50,7 @@ | ||||
| #include "gui/consolewindow.h" | ||||
| #include "gui/instancesettings.h" | ||||
| #include "gui/platform.h" | ||||
| #include "gui/CustomMessageBox.h" | ||||
|  | ||||
| #include "logic/lists/InstanceList.h" | ||||
| #include "logic/lists/MinecraftVersionList.h" | ||||
| @@ -281,20 +282,26 @@ void MainWindow::on_actionAddInstance_triggered() | ||||
| 		return; | ||||
|  | ||||
| 	case InstanceFactory::InstExists: | ||||
| 	{ | ||||
| 		errorMsg += "An instance with the given directory name already exists."; | ||||
| 		QMessageBox::warning(this, "Error", errorMsg); | ||||
| 		CustomMessageBox::selectable(this, tr("Error"), errorMsg, QMessageBox::Warning)->show(); | ||||
| 		break; | ||||
| 	} | ||||
|  | ||||
| 	case InstanceFactory::CantCreateDir: | ||||
| 	{ | ||||
| 		errorMsg += "Failed to create the instance directory."; | ||||
| 		QMessageBox::warning(this, "Error", errorMsg); | ||||
| 		CustomMessageBox::selectable(this, tr("Error"), errorMsg, QMessageBox::Warning)->show(); | ||||
| 		break; | ||||
| 	} | ||||
|  | ||||
| 	default: | ||||
| 	{ | ||||
| 		errorMsg += QString("Unknown instance loader error %1").arg(error); | ||||
| 		QMessageBox::warning(this, "Error", errorMsg); | ||||
| 		CustomMessageBox::selectable(this, tr("Error"), errorMsg, QMessageBox::Warning)->show(); | ||||
| 		break; | ||||
| 	} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| void MainWindow::on_actionChangeInstIcon_triggered() | ||||
| @@ -387,9 +394,10 @@ void MainWindow::on_actionDeleteInstance_triggered() | ||||
| { | ||||
| 	if (m_selectedInstance) | ||||
| 	{ | ||||
| 		int response = QMessageBox::question( | ||||
| 			this, "CAREFUL", QString("This is permanent! Are you sure?\nAbout to delete: ") + | ||||
| 								 m_selectedInstance->name()); | ||||
| 		auto response = CustomMessageBox::selectable(this, tr("CAREFUL"), | ||||
| 													 tr("This is permanent! Are you sure?\nAbout to delete: ") | ||||
| 													 + m_selectedInstance->name(), | ||||
| 													 QMessageBox::Question, QMessageBox::Yes | QMessageBox::No)->exec(); | ||||
| 		if (response == QMessageBox::Yes) | ||||
| 		{ | ||||
| 			m_selectedInstance->nuke(); | ||||
| @@ -626,7 +634,7 @@ void MainWindow::onGameUpdateComplete() | ||||
|  | ||||
| void MainWindow::onGameUpdateError(QString error) | ||||
| { | ||||
| 	QMessageBox::warning(this, "Error updating instance", error); | ||||
| 	CustomMessageBox::selectable(this, tr("Error updating instance"), error, QMessageBox::Warning)->show(); | ||||
| } | ||||
|  | ||||
| void MainWindow::launchInstance(BaseInstance *instance, LoginResponse response) | ||||
| @@ -695,9 +703,9 @@ void MainWindow::on_actionMakeDesktopShortcut_triggered() | ||||
| 						 QStringList() << "-dl" << QDir::currentPath() << "test", name, | ||||
| 						 "application-x-octet-stream"); | ||||
|  | ||||
| 	QMessageBox::warning( | ||||
| 		this, tr("Not useful"), | ||||
| 		tr("A Dummy Shortcut was created. it will not do anything productive")); | ||||
| 	CustomMessageBox::selectable(this, tr("Not useful"), | ||||
| 								 tr("A Dummy Shortcut was created. it will not do anything productive"), | ||||
| 								 QMessageBox::Warning)->show(); | ||||
| } | ||||
|  | ||||
| // BrowserDialog | ||||
| @@ -718,11 +726,11 @@ void MainWindow::on_actionChangeInstMCVersion_triggered() | ||||
| 	{ | ||||
| 		if (m_selectedInstance->versionIsCustom()) | ||||
| 		{ | ||||
| 			auto result = QMessageBox::warning( | ||||
| 				this, tr("Are you sure?"), | ||||
| 				tr("This will remove any library/version customization you did previously. " | ||||
| 				   "This includes things like Forge install and similar."), | ||||
| 				QMessageBox::Ok, QMessageBox::Abort); | ||||
| 			auto result = CustomMessageBox::selectable(this, tr("Are you sure?"), | ||||
| 										 tr("This will remove any library/version customization you did previously. " | ||||
| 											"This includes things like Forge install and similar."), | ||||
| 										 QMessageBox::Warning, QMessageBox::Ok, QMessageBox::Abort)->exec(); | ||||
|  | ||||
| 			if (result != QMessageBox::Ok) | ||||
| 				return; | ||||
| 		} | ||||
| @@ -853,10 +861,12 @@ void MainWindow::checkSetDefaultJava() | ||||
| 			java = std::dynamic_pointer_cast<JavaVersion>(vselect.selectedVersion()); | ||||
| 		else | ||||
| 		{ | ||||
| 			QMessageBox::warning(this, tr("Invalid version selected"), | ||||
| 								 tr("You didn't select a valid Java version, so MultiMC will " | ||||
| 									"select the default. " | ||||
| 									"You can change this in the settings dialog.")); | ||||
| 			CustomMessageBox::selectable(this, tr("Invalid version selected"), | ||||
| 										 tr("You didn't select a valid Java version, so MultiMC will " | ||||
| 											"select the default. " | ||||
| 											"You can change this in the settings dialog."), | ||||
| 										 QMessageBox::Warning)->show(); | ||||
|  | ||||
| 			JavaUtils ju; | ||||
| 			java = ju.GetDefaultJava(); | ||||
| 		} | ||||
|   | ||||
| @@ -19,6 +19,7 @@ | ||||
| #include "logic/JavaUtils.h" | ||||
| #include "gui/versionselectdialog.h" | ||||
| #include "gui/platform.h" | ||||
| #include "gui/CustomMessageBox.h" | ||||
| #include "logic/lists/JavaVersionList.h" | ||||
|  | ||||
| #include <settingsobject.h> | ||||
| @@ -113,10 +114,10 @@ void SettingsDialog::applySettings(SettingsObject *s) | ||||
| 	} | ||||
| 	else if (!s->get("UseDevBuilds").toBool()) | ||||
| 	{ | ||||
| 		int response = QMessageBox::question( | ||||
| 			this, tr("Development builds"), | ||||
| 			tr("Development builds contain experimental features " | ||||
| 			   "and may be unstable. Are you sure you want to enable them?")); | ||||
| 		auto response = CustomMessageBox::selectable(this, tr("Development builds"), | ||||
| 													 tr("Development builds contain experimental features " | ||||
| 														"and may be unstable. Are you sure you want to enable them?"), | ||||
| 													 QMessageBox::Question, QMessageBox::Yes | QMessageBox::No)->exec(); | ||||
| 		if (response == QMessageBox::Yes) | ||||
| 		{ | ||||
| 			s->set("UseDevBuilds", true); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Sky
					Sky