diff --git a/desktop-widgets/preferences.cpp b/desktop-widgets/preferences.cpp
index 6450c41cb..cb19ce759 100644
--- a/desktop-widgets/preferences.cpp
+++ b/desktop-widgets/preferences.cpp
@@ -118,12 +118,8 @@ void PreferencesDialog::cloudPinNeeded()
ui.cloud_storage_new_passwd_label->setVisible(prefs.cloud_verification_status == CS_VERIFIED);
if (prefs.cloud_verification_status == CS_VERIFIED) {
ui.cloudStorageGroupBox->setTitle(tr("Subsurface cloud storage (credentials verified)"));
- ui.cloudDefaultFile->setEnabled(true);
} else {
ui.cloudStorageGroupBox->setTitle(tr("Subsurface cloud storage"));
- if (ui.cloudDefaultFile->isChecked())
- ui.noDefaultFile->setChecked(true);
- ui.cloudDefaultFile->setEnabled(false);
}
MainWindow::instance()->enableDisableCloudActions();
}
@@ -186,24 +182,11 @@ void PreferencesDialog::setUiFromPrefs()
ui.kg->setChecked(prefs.units.weight == units::KG);
ui.lbs->setChecked(prefs.units.weight == units::LBS);
- ui.font->setCurrentFont(QString(prefs.divelist_font));
- ui.fontsize->setValue(prefs.font_size);
- ui.defaultfilename->setText(prefs.default_filename);
- ui.noDefaultFile->setChecked(prefs.default_file_behavior == NO_DEFAULT_FILE);
- ui.cloudDefaultFile->setChecked(prefs.default_file_behavior == CLOUD_DEFAULT_FILE);
- ui.localDefaultFile->setChecked(prefs.default_file_behavior == LOCAL_DEFAULT_FILE);
- ui.default_cylinder->clear();
- for (int i = 0; tank_info[i].name != NULL; i++) {
- ui.default_cylinder->addItem(tank_info[i].name);
- if (prefs.default_cylinder && strcmp(tank_info[i].name, prefs.default_cylinder) == 0)
- ui.default_cylinder->setCurrentIndex(i);
- }
- ui.displayinvalid->setChecked(prefs.display_invalid_dives);
ui.display_unused_tanks->setChecked(prefs.display_unused_tanks);
ui.show_average_depth->setChecked(prefs.show_average_depth);
ui.vertical_speed_minutes->setChecked(prefs.units.vertical_speed_time == units::MINUTES);
ui.vertical_speed_seconds->setChecked(prefs.units.vertical_speed_time == units::SECONDS);
- ui.velocitySlider->setValue(prefs.animation_speed);
+
QSortFilterProxyModel *filterModel = new QSortFilterProxyModel();
filterModel->setSourceModel(LanguageModel::instance());
@@ -232,7 +215,7 @@ void PreferencesDialog::setUiFromPrefs()
ui.proxyUsername->setText(prefs.proxy_user);
ui.proxyPassword->setText(prefs.proxy_pass);
ui.proxyType->setCurrentIndex(ui.proxyType->findData(prefs.proxy_type));
- ui.btnUseDefaultFile->setChecked(prefs.use_default_file);
+
ui.cloud_storage_email->setText(prefs.cloud_storage_email);
ui.cloud_storage_password->setText(prefs.cloud_storage_password);
@@ -302,27 +285,11 @@ void PreferencesDialog::syncSettings()
// Defaults
s.beginGroup("GeneralSettings");
- s.setValue("default_filename", ui.defaultfilename->text());
- s.setValue("default_cylinder", ui.default_cylinder->currentText());
- s.setValue("use_default_file", ui.btnUseDefaultFile->isChecked());
- if (ui.noDefaultFile->isChecked())
- s.setValue("default_file_behavior", NO_DEFAULT_FILE);
- else if (ui.localDefaultFile->isChecked())
- s.setValue("default_file_behavior", LOCAL_DEFAULT_FILE);
- else if (ui.cloudDefaultFile->isChecked())
- s.setValue("default_file_behavior", CLOUD_DEFAULT_FILE);
s.setValue("defaultsetpoint", rint(ui.defaultSetpoint->value() * 1000.0));
s.setValue("o2consumption", rint(ui.psro2rate->value() *1000.0));
s.setValue("pscr_ratio", rint(1000.0 / ui.pscrfactor->value()));
s.endGroup();
- s.beginGroup("Display");
- SAVE_OR_REMOVE_SPECIAL("divelist_font", system_divelist_default_font, ui.font->currentFont().toString(), ui.font->currentFont());
- SAVE_OR_REMOVE("font_size", system_divelist_default_font_size, ui.fontsize->value());
- s.setValue("displayinvalid", ui.displayinvalid->isChecked());
- s.endGroup();
- s.sync();
-
// Locale
QLocale loc;
s.beginGroup("Language");
@@ -336,11 +303,6 @@ void PreferencesDialog::syncSettings()
s.setValue("UiLanguage", ui.languageView->currentIndex().data(Qt::UserRole));
s.endGroup();
- // Animation
- s.beginGroup("Animations");
- s.setValue("animation_speed", ui.velocitySlider->value());
- s.endGroup();
-
s.beginGroup("Network");
s.setValue("proxy_type", ui.proxyType->itemData(ui.proxyType->currentIndex()).toInt());
s.setValue("proxy_host", ui.proxyHost->text());
@@ -445,10 +407,6 @@ void PreferencesDialog::loadSettings()
ui.save_uid_local->setChecked(s.value("save_uid_local").toBool());
ui.default_uid->setText(s.value("subsurface_webservice_uid").toString().toUpper());
-
- ui.defaultfilename->setEnabled(prefs.default_file_behavior == LOCAL_DEFAULT_FILE);
- ui.btnUseDefaultFile->setEnabled(prefs.default_file_behavior == LOCAL_DEFAULT_FILE);
- ui.chooseFile->setEnabled(prefs.default_file_behavior == LOCAL_DEFAULT_FILE);
}
void PreferencesDialog::buttonClicked(QAbstractButton *button)
@@ -472,15 +430,6 @@ void PreferencesDialog::buttonClicked(QAbstractButton *button)
}
#undef SB
-void PreferencesDialog::on_chooseFile_clicked()
-{
- QFileInfo fi(system_default_filename());
- QString choosenFileName = QFileDialog::getOpenFileName(this, tr("Open default log file"), fi.absolutePath(), tr("Subsurface XML files (*.ssrf *.xml *.XML)"));
-
- if (!choosenFileName.isEmpty())
- ui.defaultfilename->setText(choosenFileName);
-}
-
void PreferencesDialog::on_resetSettings_clicked()
{
QSettings s;
@@ -529,31 +478,3 @@ void PreferencesDialog::proxyType_changed(int idx)
ui.proxyPassword->setEnabled(hpEnabled & ui.proxyAuthRequired->isChecked());
ui.proxyAuthRequired->setChecked(ui.proxyAuthRequired->isChecked());
}
-
-void PreferencesDialog::on_btnUseDefaultFile_toggled(bool toggle)
-{
- if (toggle) {
- ui.defaultfilename->setText(system_default_filename());
- ui.defaultfilename->setEnabled(false);
- } else {
- ui.defaultfilename->setEnabled(true);
- }
-}
-
-void PreferencesDialog::on_noDefaultFile_toggled(bool toggle)
-{
- prefs.default_file_behavior = NO_DEFAULT_FILE;
-}
-
-void PreferencesDialog::on_localDefaultFile_toggled(bool toggle)
-{
- ui.defaultfilename->setEnabled(toggle);
- ui.btnUseDefaultFile->setEnabled(toggle);
- ui.chooseFile->setEnabled(toggle);
- prefs.default_file_behavior = LOCAL_DEFAULT_FILE;
-}
-
-void PreferencesDialog::on_cloudDefaultFile_toggled(bool toggle)
-{
- prefs.default_file_behavior = CLOUD_DEFAULT_FILE;
-}
diff --git a/desktop-widgets/preferences.h b/desktop-widgets/preferences.h
index 326b1f964..c05145611 100644
--- a/desktop-widgets/preferences.h
+++ b/desktop-widgets/preferences.h
@@ -24,7 +24,6 @@ signals:
public
slots:
void buttonClicked(QAbstractButton *button);
- void on_chooseFile_clicked();
void on_resetSettings_clicked();
void syncSettings();
void loadSettings();
@@ -33,10 +32,6 @@ slots:
void gflowChanged(int gf);
void gfhighChanged(int gf);
void proxyType_changed(int idx);
- void on_btnUseDefaultFile_toggled(bool toggle);
- void on_noDefaultFile_toggled(bool toggle);
- void on_localDefaultFile_toggled(bool toggle);
- void on_cloudDefaultFile_toggled(bool toggle);
void facebookLoggedIn();
void facebookDisconnect();
void cloudPinNeeded();
diff --git a/desktop-widgets/preferences.ui b/desktop-widgets/preferences.ui
index de2d79b91..aa5dc4cb5 100644
--- a/desktop-widgets/preferences.ui
+++ b/desktop-widgets/preferences.ui
@@ -164,7 +164,7 @@
- 4
+ 0
@@ -180,232 +180,6 @@
5
- -
-
-
- Lists and tables
-
-
-
- 5
-
-
-
-
-
- Font
-
-
-
- -
-
-
- -
-
-
- Font size
-
-
-
- -
-
-
-
-
-
- -
-
-
- Dives
-
-
-
- 5
-
-
- 5
-
-
- 5
-
-
-
-
-
- Default dive log file
-
-
-
- -
-
-
-
-
-
- No default file
-
-
- defaultFileGroup
-
-
-
- -
-
-
- &Local default file
-
-
- defaultFileGroup
-
-
-
- -
-
-
- Clo&ud storage default file
-
-
- defaultFileGroup
-
-
-
-
-
- -
-
-
- Local dive log file
-
-
-
- -
-
-
-
-
-
- -
-
-
- Use default
-
-
- true
-
-
-
- -
-
-
- ...
-
-
-
-
-
- -
-
-
- Display invalid
-
-
-
- -
-
-
-
-
-
-
-
-
-
- -
-
-
- Default cylinder
-
-
-
- 5
-
-
- 5
-
-
- 5
-
-
-
-
-
- Use default cylinder
-
-
-
- -
-
-
-
-
-
-
-
-
-
-
- -
-
-
- Animations
-
-
-
- 5
-
-
-
-
-
- Speed
-
-
-
- -
-
-
- 500
-
-
- Qt::Horizontal
-
-
-
- -
-
-
- 500
-
-
-
-
-
-
- -
-
-
- Clear all settings
-
-
-
- 5
-
-
- 5
-
-
-
-
-
- Reset all settings to their default value
-
-
-
-
-
-
-
@@ -1788,38 +1562,6 @@
-
- velocitySlider
- valueChanged(int)
- velocitySpinBox
- setValue(int)
-
-
- 236
- 52
-
-
- 236
- 52
-
-
-
-
- velocitySpinBox
- valueChanged(int)
- velocitySlider
- setValue(int)
-
-
- 236
- 52
-
-
- 236
- 52
-
-
-
proxyAuthRequired
toggled(bool)
@@ -1852,22 +1594,6 @@
-
- btnUseDefaultFile
- toggled(bool)
- chooseFile
- setHidden(bool)
-
-
- 236
- 44
-
-
- 236
- 44
-
-
-
diff --git a/desktop-widgets/preferences/CMakeLists.txt b/desktop-widgets/preferences/CMakeLists.txt
index 4eb2f7d23..c55d7b881 100644
--- a/desktop-widgets/preferences/CMakeLists.txt
+++ b/desktop-widgets/preferences/CMakeLists.txt
@@ -14,6 +14,7 @@ set(SUBSURFACE_PREFERENCES_LIB_SRCS
preferencesdialog.cpp
preferences_language.cpp
preferences_georeference.cpp
+ preferences_defaults.cpp
)
source_group("Subsurface Preferences" FILES ${SUBSURFACE_PREFERENCES_LIB_SRCS})
diff --git a/desktop-widgets/preferences/preferences_defaults.cpp b/desktop-widgets/preferences/preferences_defaults.cpp
new file mode 100644
index 000000000..637117105
--- /dev/null
+++ b/desktop-widgets/preferences/preferences_defaults.cpp
@@ -0,0 +1,115 @@
+#include "preferences_defaults.h"
+#include "ui_preferences_defaults.h"
+#include "dive.h"
+#include "subsurface-core/prefs-macros.h"
+
+#include
+#include
+
+PreferencesDefaults::PreferencesDefaults(): AbstractPreferencesWidget(tr("Defaults"), QIcon(":defaults"), 0 ), ui(new Ui::PreferencesDefaults())
+{
+ ui->setupUi(this);
+}
+
+PreferencesDefaults::~PreferencesDefaults()
+{
+ delete ui;
+}
+
+void PreferencesDefaults::on_chooseFile_clicked()
+{
+ QFileInfo fi(system_default_filename());
+ QString choosenFileName = QFileDialog::getOpenFileName(this, tr("Open default log file"), fi.absolutePath(), tr("Subsurface XML files (*.ssrf *.xml *.XML)"));
+
+ if (!choosenFileName.isEmpty())
+ ui->defaultfilename->setText(choosenFileName);
+}
+
+
+void PreferencesDefaults::on_btnUseDefaultFile_toggled(bool toggle)
+{
+ if (toggle) {
+ ui->defaultfilename->setText(system_default_filename());
+ ui->defaultfilename->setEnabled(false);
+ } else {
+ ui->defaultfilename->setEnabled(true);
+ }
+}
+
+void PreferencesDefaults::on_noDefaultFile_toggled(bool toggle)
+{
+ prefs.default_file_behavior = NO_DEFAULT_FILE;
+}
+
+void PreferencesDefaults::on_localDefaultFile_toggled(bool toggle)
+{
+ ui->defaultfilename->setEnabled(toggle);
+ ui->btnUseDefaultFile->setEnabled(toggle);
+ ui->chooseFile->setEnabled(toggle);
+ prefs.default_file_behavior = LOCAL_DEFAULT_FILE;
+}
+
+void PreferencesDefaults::on_cloudDefaultFile_toggled(bool toggle)
+{
+ prefs.default_file_behavior = CLOUD_DEFAULT_FILE;
+}
+
+void PreferencesDefaults::refreshSettings()
+{
+ ui->font->setCurrentFont(QString(prefs.divelist_font));
+ ui->fontsize->setValue(prefs.font_size);
+ ui->defaultfilename->setText(prefs.default_filename);
+ ui->noDefaultFile->setChecked(prefs.default_file_behavior == NO_DEFAULT_FILE);
+ ui->cloudDefaultFile->setChecked(prefs.default_file_behavior == CLOUD_DEFAULT_FILE);
+ ui->localDefaultFile->setChecked(prefs.default_file_behavior == LOCAL_DEFAULT_FILE);
+
+ ui->default_cylinder->clear();
+ for (int i = 0; tank_info[i].name != NULL; i++) {
+ ui->default_cylinder->addItem(tank_info[i].name);
+ if (prefs.default_cylinder && strcmp(tank_info[i].name, prefs.default_cylinder) == 0)
+ ui->default_cylinder->setCurrentIndex(i);
+ }
+ ui->displayinvalid->setChecked(prefs.display_invalid_dives);
+ ui->velocitySlider->setValue(prefs.animation_speed);
+ ui->btnUseDefaultFile->setChecked(prefs.use_default_file);
+
+ if (prefs.cloud_verification_status == CS_VERIFIED) {
+ ui->cloudDefaultFile->setEnabled(true);
+ } else {
+ if (ui->cloudDefaultFile->isChecked())
+ ui->noDefaultFile->setChecked(true);
+ ui->cloudDefaultFile->setEnabled(false);
+ }
+
+ ui->defaultfilename->setEnabled(prefs.default_file_behavior == LOCAL_DEFAULT_FILE);
+ ui->btnUseDefaultFile->setEnabled(prefs.default_file_behavior == LOCAL_DEFAULT_FILE);
+ ui->chooseFile->setEnabled(prefs.default_file_behavior == LOCAL_DEFAULT_FILE);
+}
+
+void PreferencesDefaults::syncSettings()
+{
+ QSettings s;
+ s.beginGroup("GeneralSettings");
+ s.setValue("default_filename", ui->defaultfilename->text());
+ s.setValue("default_cylinder", ui->default_cylinder->currentText());
+ s.setValue("use_default_file", ui->btnUseDefaultFile->isChecked());
+ if (ui->noDefaultFile->isChecked())
+ s.setValue("default_file_behavior", NO_DEFAULT_FILE);
+ else if (ui->localDefaultFile->isChecked())
+ s.setValue("default_file_behavior", LOCAL_DEFAULT_FILE);
+ else if (ui->cloudDefaultFile->isChecked())
+ s.setValue("default_file_behavior", CLOUD_DEFAULT_FILE);
+ s.endGroup();
+
+ s.beginGroup("Display");
+ SAVE_OR_REMOVE_SPECIAL("divelist_font", system_divelist_default_font, ui->font->currentFont().toString(), ui->font->currentFont());
+ SAVE_OR_REMOVE("font_size", system_divelist_default_font_size, ui->fontsize->value());
+ s.setValue("displayinvalid", ui->displayinvalid->isChecked());
+ s.endGroup();
+ s.sync();
+
+ // Animation
+ s.beginGroup("Animations");
+ s.setValue("animation_speed", ui->velocitySlider->value());
+ s.endGroup();
+}
diff --git a/desktop-widgets/preferences/preferences_defaults.h b/desktop-widgets/preferences/preferences_defaults.h
new file mode 100644
index 000000000..94de8b28a
--- /dev/null
+++ b/desktop-widgets/preferences/preferences_defaults.h
@@ -0,0 +1,30 @@
+#ifndef PREFERENCES_DEFAULTS_H
+#define PREFERENCES_DEFAULTS_H
+
+#include "abstractpreferenceswidget.h"
+#include "subsurface-core/pref.h"
+
+namespace Ui {
+ class PreferencesDefaults;
+}
+
+class PreferencesDefaults : public AbstractPreferencesWidget {
+ Q_OBJECT
+public:
+ PreferencesDefaults();
+ virtual ~PreferencesDefaults();
+ virtual void refreshSettings();
+ virtual void syncSettings();
+public slots:
+ void on_chooseFile_clicked();
+ void on_btnUseDefaultFile_toggled(bool toggled);
+ void on_noDefaultFile_toggled(bool toggled);
+ void on_localDefaultFile_toggled(bool toggled);
+ void on_cloudDefaultFile_toggled(bool toggled);
+
+private:
+ Ui::PreferencesDefaults *ui;
+};
+
+
+#endif
\ No newline at end of file
diff --git a/desktop-widgets/preferences/preferences_defaults.ui b/desktop-widgets/preferences/preferences_defaults.ui
new file mode 100644
index 000000000..632e82763
--- /dev/null
+++ b/desktop-widgets/preferences/preferences_defaults.ui
@@ -0,0 +1,251 @@
+
+
+ PreferencesDefaults
+
+
+
+ 0
+ 0
+ 555
+ 558
+
+
+
+ Form
+
+
+
-
+
+
+ Lists and tables
+
+
+
+ 5
+
+
-
+
+
+ Font
+
+
+
+ -
+
+
+ -
+
+
+ Font size
+
+
+
+ -
+
+
+
+
+
+ -
+
+
+ Dives
+
+
+
+ 5
+
+
+ 5
+
+
+ 5
+
+
-
+
+
+ Default dive log file
+
+
+
+ -
+
+
-
+
+
+ No default file
+
+
+
+ -
+
+
+ &Local default file
+
+
+
+ -
+
+
+ Clo&ud storage default file
+
+
+
+
+
+ -
+
+
+ Local dive log file
+
+
+
+ -
+
+
-
+
+
+ -
+
+
+ Use default
+
+
+ true
+
+
+
+ -
+
+
+ ...
+
+
+
+
+
+ -
+
+
+ Display invalid
+
+
+
+ -
+
+
+
+
+
+
+
+
+
+ -
+
+
+ Default cylinder
+
+
+
+ 5
+
+
+ 5
+
+
+ 5
+
+
-
+
+
+ Use default cylinder
+
+
+
+ -
+
+
-
+
+
+
+
+
+
+
+ -
+
+
+ Animations
+
+
+
+ 5
+
+
-
+
+
+ Speed
+
+
+
+ -
+
+
+ 500
+
+
+ Qt::Horizontal
+
+
+
+ -
+
+
+ 500
+
+
+
+
+
+
+ -
+
+
+ Clear all settings
+
+
+
+ 5
+
+
+ 5
+
+
-
+
+
+ Reset all settings to their default value
+
+
+
+
+
+
+ -
+
+
+ Qt::Vertical
+
+
+
+ 0
+ 195
+
+
+
+
+
+
+
+
+
diff --git a/desktop-widgets/preferences/preferencesdialog.cpp b/desktop-widgets/preferences/preferencesdialog.cpp
index 3975994a9..6f66d856d 100644
--- a/desktop-widgets/preferences/preferencesdialog.cpp
+++ b/desktop-widgets/preferences/preferencesdialog.cpp
@@ -3,6 +3,7 @@
#include "abstractpreferenceswidget.h"
#include "preferences_language.h"
#include "preferences_georeference.h"
+#include "preferences_defaults.h"
#include
#include
@@ -35,6 +36,7 @@ PreferencesDialogV2::PreferencesDialogV2()
addPreferencePage(new PreferencesLanguage());
addPreferencePage(new PreferencesGeoreference());
+ addPreferencePage(new PreferencesDefaults());
refreshPages();
connect(pagesList, &QListWidget::currentRowChanged,