1
0
mirror of https://github.com/qTox/qTox.git synced 2024-03-22 14:00:36 +08:00

fix(ui): Use native file picker dialog

The original reason that the Qt picker was used instead of the native
picker was that the native option would cause Nautilus/GNOME-based
pickers to hang.

This turned out to be due with a Qt bug with parenting Gtk windows. As a
result the parent of each file dialog window has been set to NULL,
eliminating the crash. As far as tests have shown, this produces no
adverse effects on either floating or tiling wms.

Fixes #3494
This commit is contained in:
Andrew Morgan 2017-07-05 16:45:56 +00:00 committed by Andrew (anoa)
parent 90910cbfe1
commit 42a9534b24
No known key found for this signature in database
GPG Key ID: 174BEAB009FD176D
7 changed files with 27 additions and 29 deletions

View File

@ -502,11 +502,11 @@ void FileTransferWidget::handleButton(QPushButton* btn)
Core::getInstance()->pauseResumeFileRecv(fileInfo.friendId, fileInfo.fileNum); Core::getInstance()->pauseResumeFileRecv(fileInfo.friendId, fileInfo.fileNum);
else if (btn->objectName() == "accept") { else if (btn->objectName() == "accept") {
QString path = QString path =
QFileDialog::getSaveFileName(parentWidget(), QFileDialog::getSaveFileName(Q_NULLPTR,
tr("Save a file", "Title of the file saving dialog"), tr("Save a file", "Title of the file saving dialog"),
Settings::getInstance().getGlobalAutoAcceptDir() + "/" Settings::getInstance().getGlobalAutoAcceptDir() + "/"
+ fileInfo.fileName, + fileInfo.fileName,
0, 0, QFileDialog::DontUseNativeDialog); 0, 0);
acceptTransfer(path); acceptTransfer(path);
} }
} }

View File

@ -64,9 +64,8 @@ void AboutUser::onAutoAcceptDirClicked()
Settings::getInstance().setAutoAcceptDir(this->friendPk, ""); Settings::getInstance().setAutoAcceptDir(this->friendPk, "");
ui->selectSaveDir->setText(tr("Auto accept for this contact is disabled")); ui->selectSaveDir->setText(tr("Auto accept for this contact is disabled"));
} else if (ui->autoacceptfile->isChecked()) { } else if (ui->autoacceptfile->isChecked()) {
dir = QFileDialog::getExistingDirectory(this, tr("Choose an auto accept directory", dir = QFileDialog::getExistingDirectory(Q_NULLPTR, tr("Choose an auto accept directory",
"popup title"), "popup title"), dir);
dir, QFileDialog::DontUseNativeDialog);
if (dir.isEmpty()) { if (dir.isEmpty()) {
ui->autoacceptfile->setChecked(false); ui->autoacceptfile->setChecked(false);
return; // user canellced return; // user canellced
@ -98,9 +97,9 @@ void AboutUser::onAutoGroupInvite()
void AboutUser::onSelectDirClicked() void AboutUser::onSelectDirClicked()
{ {
QString dir; QString dir;
dir = QFileDialog::getExistingDirectory(this, dir = QFileDialog::getExistingDirectory(Q_NULLPTR,
tr("Choose an auto accept directory", "popup title"), tr("Choose an auto accept directory", "popup title"),
dir, QFileDialog::DontUseNativeDialog); dir);
ui->autoacceptfile->setChecked(true); ui->autoacceptfile->setChecked(true);
Settings::getInstance().setAutoAcceptDir(this->friendPk, dir); Settings::getInstance().setAutoAcceptDir(this->friendPk, dir);
Settings::getInstance().savePersonal(); Settings::getInstance().savePersonal();

View File

@ -245,8 +245,8 @@ void ChatForm::onTextEditChanged()
void ChatForm::onAttachClicked() void ChatForm::onAttachClicked()
{ {
QStringList paths = QFileDialog::getOpenFileNames(this, tr("Send a file"), QDir::homePath(), 0, QStringList paths = QFileDialog::getOpenFileNames(Q_NULLPTR, tr("Send a file"), QDir::homePath(), 0, 0);
0, QFileDialog::DontUseNativeDialog);
if (paths.isEmpty()) { if (paths.isEmpty()) {
return; return;
} }

View File

@ -265,13 +265,12 @@ void ProfileForm::onAvatarClicked()
return bytes; return bytes;
}; };
QString filename = QFileDialog::getOpenFileName(this, tr("Choose a profile picture"), QString path = QFileDialog::getOpenFileName(Q_NULLPTR, tr("Choose a profile picture"),
QDir::homePath(), Nexus::getSupportedImageFilter(), QDir::homePath(), Nexus::getSupportedImageFilter(), 0);
0, QFileDialog::DontUseNativeDialog); if (path.isEmpty())
if (filename.isEmpty())
return; return;
QFile file(filename); QFile file(path);
file.open(QIODevice::ReadOnly); file.open(QIODevice::ReadOnly);
if (!file.isOpen()) { if (!file.isOpen()) {
GUI::showError(tr("Error"), tr("Unable to open this file.")); GUI::showError(tr("Error"), tr("Unable to open this file."));
@ -335,10 +334,9 @@ void ProfileForm::onRenameClicked()
void ProfileForm::onExportClicked() void ProfileForm::onExportClicked()
{ {
QString current = Nexus::getProfile()->getName() + Core::TOX_EXT; QString current = Nexus::getProfile()->getName() + Core::TOX_EXT;
QString path = QFileDialog::getSaveFileName(this, tr("Export profile", "save dialog title"), QString path = QFileDialog::getSaveFileName(Q_NULLPTR, tr("Export profile", "save dialog title"),
QDir::home().filePath(current), QDir::home().filePath(current),
tr("Tox save file (*.tox)", "save dialog filter"), tr("Tox save file (*.tox)", "save dialog filter"), 0);
0, QFileDialog::DontUseNativeDialog);
if (!path.isEmpty()) { if (!path.isEmpty()) {
if (!Nexus::tryRemoveFile(path)) { if (!Nexus::tryRemoveFile(path)) {
GUI::showWarning(tr("Location not writable", "Title of permissions popup"), GUI::showWarning(tr("Location not writable", "Title of permissions popup"),
@ -406,10 +404,9 @@ void ProfileForm::onCopyQrClicked()
void ProfileForm::onSaveQrClicked() void ProfileForm::onSaveQrClicked()
{ {
QString current = Nexus::getProfile()->getName() + ".png"; QString current = Nexus::getProfile()->getName() + ".png";
QString path = QFileDialog::getSaveFileName(this, tr("Save", "save qr image"), QString path = QFileDialog::getSaveFileName(Q_NULLPTR, tr("Save", "save qr image"),
QDir::home().filePath(current), QDir::home().filePath(current),
tr("Save QrCode (*.png)", "save dialog filter"), 0, tr("Save QrCode (*.png)", "save dialog filter"), 0);
QFileDialog::DontUseNativeDialog);
if (!path.isEmpty()) { if (!path.isEmpty()) {
if (!Nexus::tryRemoveFile(path)) { if (!Nexus::tryRemoveFile(path)) {
GUI::showWarning(tr("Location not writable", "Title of permissions popup"), GUI::showWarning(tr("Location not writable", "Title of permissions popup"),

View File

@ -258,10 +258,9 @@ void GeneralForm::on_autoSaveFilesDir_clicked()
{ {
QString previousDir = Settings::getInstance().getGlobalAutoAcceptDir(); QString previousDir = Settings::getInstance().getGlobalAutoAcceptDir();
QString directory = QString directory =
QFileDialog::getExistingDirectory(0, tr("Choose an auto accept directory", QFileDialog::getExistingDirectory(Q_NULLPTR,
"popup title"), // opens in home directory tr("Choose an auto accept directory", "popup title"),
QDir::homePath(), QDir::homePath());
QFileDialog::DontUseNativeDialog);
if (directory.isEmpty()) // cancel was pressed if (directory.isEmpty()) // cancel was pressed
directory = previousDir; directory = previousDir;

View File

@ -223,9 +223,9 @@ void FriendWidget::onContextMenuCalled(QContextMenuEvent* event)
autoAccept->setChecked(false); autoAccept->setChecked(false);
Settings::getInstance().setAutoAcceptDir(id, ""); Settings::getInstance().setAutoAcceptDir(id, "");
} else if (autoAccept->isChecked()) { } else if (autoAccept->isChecked()) {
dir = QFileDialog::getExistingDirectory(0, tr("Choose an auto accept directory", dir = QFileDialog::getExistingDirectory(Q_NULLPTR,
"popup title"), tr("Choose an auto accept directory", "popup title"),
dir, QFileDialog::DontUseNativeDialog); dir);
autoAccept->setChecked(true); autoAccept->setChecked(true);
qDebug() << "Setting auto accept dir for" << friendId << "to" << dir; qDebug() << "Setting auto accept dir for" << friendId << "to" << dir;

View File

@ -49,8 +49,11 @@ bool ProfileImporter::importProfile()
QString title = tr("Import profile", "import dialog title"); QString title = tr("Import profile", "import dialog title");
QString filter = tr("Tox save file (*.tox)", "import dialog filter"); QString filter = tr("Tox save file (*.tox)", "import dialog filter");
QString dir = QDir::homePath(); QString dir = QDir::homePath();
QString path =
QFileDialog::getOpenFileName(this, title, dir, filter, 0, QFileDialog::DontUseNativeDialog); // TODO: Change all QFileDialog instances across project to use
// this instead of Q_NULLPTR. Possibly requires >Qt 5.9 due to:
// https://bugreports.qt.io/browse/QTBUG-59184
QString path = QFileDialog::getOpenFileName(Q_NULLPTR, title, dir, filter, 0);
return importProfile(path); return importProfile(path);
} }