summaryrefslogtreecommitdiffstats
path: root/core/settings/qPrefGeocoding.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'core/settings/qPrefGeocoding.cpp')
-rw-r--r--core/settings/qPrefGeocoding.cpp72
1 files changed, 72 insertions, 0 deletions
diff --git a/core/settings/qPrefGeocoding.cpp b/core/settings/qPrefGeocoding.cpp
new file mode 100644
index 000000000..7bb043e0f
--- /dev/null
+++ b/core/settings/qPrefGeocoding.cpp
@@ -0,0 +1,72 @@
+// SPDX-License-Identifier: GPL-2.0
+#include "qPrefGeocoding.h"
+#include "qPrefPrivate.h"
+
+static const QString group = QStringLiteral("geocoding");
+
+qPrefGeocoding::qPrefGeocoding(QObject *parent) : QObject(parent)
+{
+}
+qPrefGeocoding *qPrefGeocoding::instance()
+{
+ static qPrefGeocoding *self = new qPrefGeocoding;
+ return self;
+}
+
+void qPrefGeocoding::loadSync(bool doSync)
+{
+ disk_first_taxonomy_category(doSync);
+ disk_second_taxonomy_category(doSync);
+ disk_third_taxonomy_category(doSync);
+}
+
+
+void qPrefGeocoding::set_first_taxonomy_category(taxonomy_category value)
+{
+ if (value != prefs.geocoding.category[0]) {
+ prefs.geocoding.category[0] = value;
+ disk_first_taxonomy_category(true);
+ emit instance()->first_taxonomy_category_changed(value);
+ }
+}
+void qPrefGeocoding::disk_first_taxonomy_category(bool doSync)
+{
+ if (doSync)
+ qPrefPrivate::propSetValue(group + "/cat0", prefs.geocoding.category[0]);
+ else
+ prefs.geocoding.category[0] = (enum taxonomy_category)qPrefPrivate::propValue(group + "/cat0", default_prefs.geocoding.category[0]).toInt();
+}
+
+
+void qPrefGeocoding::set_second_taxonomy_category(taxonomy_category value)
+{
+ if (value != prefs.geocoding.category[1]) {
+ prefs.geocoding.category[1] = value;
+ disk_second_taxonomy_category(true);
+ emit instance()->second_taxonomy_category_changed(value);
+ }
+}
+void qPrefGeocoding::disk_second_taxonomy_category(bool doSync)
+{
+ if (doSync)
+ qPrefPrivate::propSetValue(group + "/cat1", prefs.geocoding.category[1]);
+ else
+ prefs.geocoding.category[1] = (enum taxonomy_category)qPrefPrivate::propValue(group + "/cat1", default_prefs.geocoding.category[1]).toInt();
+}
+
+
+void qPrefGeocoding::set_third_taxonomy_category(taxonomy_category value)
+{
+ if (value != prefs.geocoding.category[2]) {
+ prefs.geocoding.category[2] = value;
+ disk_third_taxonomy_category(true);
+ emit instance()->third_taxonomy_category_changed(value);
+ }
+}
+void qPrefGeocoding::disk_third_taxonomy_category(bool doSync)
+{
+ if (doSync)
+ qPrefPrivate::propSetValue(group + "/cat2", prefs.geocoding.category[2]);
+ else
+ prefs.geocoding.category[2] = (enum taxonomy_category)qPrefPrivate::propValue(group + "/cat2", default_prefs.geocoding.category[2]).toInt();
+}