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:
parent
90910cbfe1
commit
42a9534b24
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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"),
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user