diff --git a/src/qt/qt_vmmanager_details.cpp b/src/qt/qt_vmmanager_details.cpp
index c6d5631e1..40d0fb185 100644
--- a/src/qt/qt_vmmanager_details.cpp
+++ b/src/qt/qt_vmmanager_details.cpp
@@ -93,21 +93,12 @@ VMManagerDetails::VMManagerDetails(QWidget *parent)
// Set the icons for the screenshot navigation buttons
ui->screenshotNext->setIcon(QApplication::style()->standardIcon(QStyle::SP_ArrowRight));
ui->screenshotPrevious->setIcon(QApplication::style()->standardIcon(QStyle::SP_ArrowLeft));
- ui->screenshotNextTB->setIcon(QApplication::style()->standardIcon(QStyle::SP_ArrowRight));
- ui->screenshotPreviousTB->setIcon(QApplication::style()->standardIcon(QStyle::SP_ArrowLeft));
// Disabled by default
ui->screenshotNext->setEnabled(false);
ui->screenshotPrevious->setEnabled(false);
- ui->screenshotNextTB->setEnabled(false);
- ui->screenshotPreviousTB->setEnabled(false);
// Connect their signals
- connect(ui->screenshotNext, &QPushButton::clicked, this, &VMManagerDetails::nextScreenshot);
- connect(ui->screenshotNextTB, &QToolButton::clicked, this, &VMManagerDetails::nextScreenshot);
- connect(ui->screenshotPreviousTB, &QToolButton::clicked, this, &VMManagerDetails::previousScreenshot);
- connect(ui->screenshotPrevious, &QPushButton::clicked, this, &VMManagerDetails::previousScreenshot);
- // These push buttons can be taken out if the tool buttons stay
- ui->screenshotNext->setVisible(false);
- ui->screenshotPrevious->setVisible(false);
+ connect(ui->screenshotNext, &QToolButton::clicked, this, &VMManagerDetails::nextScreenshot);
+ connect(ui->screenshotPrevious, &QToolButton::clicked, this, &VMManagerDetails::previousScreenshot);
QString toolButtonStyleSheet;
// Simple method to try and determine if light mode is enabled
#ifdef Q_OS_WINDOWS
@@ -207,8 +198,6 @@ VMManagerDetails::reset()
ui->screenshotNext->setEnabled(false);
ui->screenshotPrevious->setEnabled(false);
- ui->screenshotNextTB->setEnabled(false);
- ui->screenshotPreviousTB->setEnabled(false);
ui->screenshot->setPixmap(QString());
ui->screenshot->setFixedSize(240, 160);
ui->screenshot->setFrameStyle(QFrame::Box | QFrame::Sunken);
@@ -384,8 +373,6 @@ VMManagerDetails::updateScreenshots(VMManagerSystem *passed_sysconfig)
// Disable screenshot navigation buttons by default
ui->screenshotNext->setEnabled(false);
ui->screenshotPrevious->setEnabled(false);
- ui->screenshotNextTB->setEnabled(false);
- ui->screenshotPreviousTB->setEnabled(false);
// Different actions are taken depending on the existence and number of screenshots
screenshots = passed_sysconfig->getScreenshots();
@@ -395,8 +382,6 @@ VMManagerDetails::updateScreenshots(VMManagerSystem *passed_sysconfig)
if (screenshots.size() > 1) {
ui->screenshotNext->setEnabled(true);
ui->screenshotPrevious->setEnabled(true);
- ui->screenshotNextTB->setEnabled(true);
- ui->screenshotPreviousTB->setEnabled(true);
}
#ifdef Q_OS_WINDOWS
ui->screenshot->setStyleSheet("");
@@ -409,8 +394,6 @@ VMManagerDetails::updateScreenshots(VMManagerSystem *passed_sysconfig)
} else {
ui->screenshotNext->setEnabled(false);
ui->screenshotPrevious->setEnabled(false);
- ui->screenshotNextTB->setEnabled(false);
- ui->screenshotPreviousTB->setEnabled(false);
ui->screenshot->setPixmap(QString());
ui->screenshot->setFixedSize(240, 160);
ui->screenshot->setFrameStyle(QFrame::Box | QFrame::Sunken);
diff --git a/src/qt/qt_vmmanager_details.ui b/src/qt/qt_vmmanager_details.ui
index 162fb20ee..0722dd3f5 100644
--- a/src/qt/qt_vmmanager_details.ui
+++ b/src/qt/qt_vmmanager_details.ui
@@ -146,22 +146,6 @@
- -
-
-
-
- 0
- 0
-
-
-
-
-
-
- false
-
-
-
-
@@ -178,14 +162,14 @@
0
-
-
+
…
-
-
+
…
@@ -197,19 +181,6 @@
- -
-
-
-
- 0
- 0
-
-
-
-
-
-
-
-
diff --git a/src/qt/qt_vmmanager_main.cpp b/src/qt/qt_vmmanager_main.cpp
index f1ca7d595..317bd0f2b 100644
--- a/src/qt/qt_vmmanager_main.cpp
+++ b/src/qt/qt_vmmanager_main.cpp
@@ -288,6 +288,7 @@ illegal_chars:
// Get the index of the newly-created system and select it
const QModelIndex mapped_index = proxy_model->mapFromSource(created_object);
ui->listView->setCurrentIndex(mapped_index);
+ modelDataChange();
} else {
QDir(dstPath).removeRecursively();
QMessageBox::critical(this, tr("Clone"), tr("Failed to clone VM."), QMessageBox::Ok);
@@ -764,6 +765,7 @@ VMManagerMain::addNewSystem(const QString &name, const QString &dir, const QStri
const QModelIndex mapped_index = proxy_model->mapFromSource(created_object);
ui->listView->setCurrentIndex(mapped_index);
delete new_system;
+ modelDataChange();
});
}
diff --git a/src/qt/qt_vmmanager_preferences.cpp b/src/qt/qt_vmmanager_preferences.cpp
index 77d5d1657..df30aec6c 100644
--- a/src/qt/qt_vmmanager_preferences.cpp
+++ b/src/qt/qt_vmmanager_preferences.cpp
@@ -29,6 +29,7 @@ extern WindowsDarkModeFilter *vmm_dark_mode_filter;
extern "C" {
#include <86box/86box.h>
#include <86box/config.h>
+#include <86box/plat.h>
#include <86box/version.h>
}
@@ -53,6 +54,7 @@ VMManagerPreferences::
if (machinesRunning) {
ui->systemDirectory->setEnabled(false);
ui->dirSelectButton->setEnabled(false);
+ ui->pushButtonDefaultSystemDir->setEnabled(false);
ui->dirSelectButton->setToolTip(tr("To change the system directory, stop all running machines."));
}
@@ -97,6 +99,14 @@ VMManagerPreferences::chooseDirectoryLocation()
ui->systemDirectory->setText(QDir::toNativeSeparators(directory));
}
+void
+VMManagerPreferences::on_pushButtonDefaultSystemDir_released()
+{
+ char temp[1024];
+ plat_get_vmm_dir(temp, sizeof(temp));
+ ui->systemDirectory->setText(QDir::toNativeSeparators(QDir(temp).path()));
+}
+
void
VMManagerPreferences::on_pushButtonLanguage_released()
{
diff --git a/src/qt/qt_vmmanager_preferences.hpp b/src/qt/qt_vmmanager_preferences.hpp
index 1ddeedb51..cbb7c5f61 100644
--- a/src/qt/qt_vmmanager_preferences.hpp
+++ b/src/qt/qt_vmmanager_preferences.hpp
@@ -34,6 +34,7 @@ private:
QString settingsFile;
private slots:
void chooseDirectoryLocation();
+ void on_pushButtonDefaultSystemDir_released();
void on_pushButtonLanguage_released();
protected:
diff --git a/src/qt/qt_vmmanager_preferences.ui b/src/qt/qt_vmmanager_preferences.ui
index 7206b79bf..a4d526f8c 100644
--- a/src/qt/qt_vmmanager_preferences.ui
+++ b/src/qt/qt_vmmanager_preferences.ui
@@ -56,6 +56,36 @@
+ -
+
+
+ 0
+
+
+ 0
+
+
-
+
+
+ Qt::Horizontal
+
+
+
+ 40
+ 20
+
+
+
+
+ -
+
+
+ Default
+
+
+
+
+
-
@@ -170,6 +200,7 @@
dirSelectButton
+ pushButtonDefaultSystemDir
comboBoxLanguage
pushButtonLanguage
rememberSizePositionCheckBox