summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar jan Iversen <jan@casacondor.com>2020-01-18 23:12:32 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2020-01-20 09:49:05 -0800
commit25a5be0fe901910c632cd422e4fa556b2c4c83ec (patch)
tree72ff68403f8646254b6321111b9a8812deb0052a
parent52b390d32a5239d41ed8c1b0e1f5e9211d9c8588 (diff)
downloadsubsurface-25a5be0fe901910c632cd422e4fa556b2c4c83ec.tar.gz
mobile-widgets: allow qPrefUnit strongly typed in QML
Add qPrefUnit Q_PROPERTY but using QMLInterface enums, that way all variables become strongly typed in QML. Signed-off-by: jan Iversen <jan@casacondor.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--mobile-widgets/qmlinterface.cpp16
-rw-r--r--mobile-widgets/qmlinterface.h33
2 files changed, 49 insertions, 0 deletions
diff --git a/mobile-widgets/qmlinterface.cpp b/mobile-widgets/qmlinterface.cpp
index 2f470bba4..e4f2dd6e5 100644
--- a/mobile-widgets/qmlinterface.cpp
+++ b/mobile-widgets/qmlinterface.cpp
@@ -20,4 +20,20 @@ void QMLInterface::setup(QQmlContext *ct)
// relink signals to QML
connect(qPrefCloudStorage::instance(), &qPrefCloudStorage::cloud_verification_statusChanged,
[=] (int value) { emit instance()->cloud_verification_statusChanged(CLOUD_STATUS(value)); });
+ connect(qPrefUnits::instance(), &qPrefUnits::duration_unitsChanged,
+ [=] (int value) { emit instance()->duration_unitsChanged(DURATION(value)); });
+ connect(qPrefUnits::instance(), &qPrefUnits::lengthChanged,
+ [=] (int value) { emit instance()->lengthChanged(LENGTH(value)); });
+ connect(qPrefUnits::instance(), &qPrefUnits::pressureChanged,
+ [=] (int value) { emit instance()->pressureChanged(PRESSURE(value)); });
+ connect(qPrefUnits::instance(), &qPrefUnits::temperatureChanged,
+ [=] (int value) { emit instance()->temperatureChanged(TEMPERATURE(value)); });
+ connect(qPrefUnits::instance(), &qPrefUnits::unit_systemChanged,
+ [=] (int value) { emit instance()->unit_systemChanged(UNIT_SYSTEM(value)); });
+ connect(qPrefUnits::instance(), &qPrefUnits::vertical_speed_timeChanged,
+ [=] (int value) { emit instance()->vertical_speed_timeChanged(TIME(value)); });
+ connect(qPrefUnits::instance(), &qPrefUnits::volumeChanged,
+ [=] (int value) { emit instance()->volumeChanged(VOLUME(value)); });
+ connect(qPrefUnits::instance(), &qPrefUnits::weightChanged,
+ [=] (int value) { emit instance()->weightChanged(WEIGHT(value)); });
}
diff --git a/mobile-widgets/qmlinterface.h b/mobile-widgets/qmlinterface.h
index a76781109..fca87260e 100644
--- a/mobile-widgets/qmlinterface.h
+++ b/mobile-widgets/qmlinterface.h
@@ -2,6 +2,7 @@
#ifndef QMLINTERFACE_H
#define QMLINTERFACE_H
#include "core/settings/qPrefCloudStorage.h"
+#include "core/settings/qPrefUnit.h"
#include <QObject>
#include <QQmlContext>
@@ -25,6 +26,14 @@ class QMLInterface : public QObject {
// Q_PROPERTY used in QML
Q_PROPERTY(CLOUD_STATUS cloud_verification_status READ cloud_verification_status WRITE set_cloud_verification_status NOTIFY cloud_verification_statusChanged)
+ Q_PROPERTY(DURATION duration_units READ duration_units WRITE set_duration_units NOTIFY duration_unitsChanged)
+ Q_PROPERTY(LENGTH length READ length WRITE set_length NOTIFY lengthChanged)
+ Q_PROPERTY(PRESSURE pressure READ pressure WRITE set_pressure NOTIFY pressureChanged)
+ Q_PROPERTY(TEMPERATURE temperature READ temperature WRITE set_temperature NOTIFY temperatureChanged)
+ Q_PROPERTY(UNIT_SYSTEM unit_system READ unit_system WRITE set_unit_system NOTIFY unit_systemChanged)
+ Q_PROPERTY(TIME vertical_speed_time READ vertical_speed_time WRITE set_vertical_speed_time NOTIFY vertical_speed_timeChanged)
+ Q_PROPERTY(VOLUME volume READ volume WRITE set_volume NOTIFY volumeChanged)
+ Q_PROPERTY(WEIGHT weight READ weight WRITE set_weight NOTIFY weightChanged)
public:
static QMLInterface *instance();
@@ -102,12 +111,36 @@ public:
public:
CLOUD_STATUS cloud_verification_status() { return (CLOUD_STATUS)prefs.cloud_verification_status; }
+ DURATION duration_units() { return (DURATION)prefs.units.duration_units; }
+ LENGTH length() { return (LENGTH)prefs.units.length; }
+ PRESSURE pressure() { return (PRESSURE)prefs.units.pressure; }
+ TEMPERATURE temperature() { return (TEMPERATURE)prefs.units.temperature; }
+ UNIT_SYSTEM unit_system() { return (UNIT_SYSTEM)prefs.unit_system; }
+ TIME vertical_speed_time() { return (TIME)prefs.units.vertical_speed_time; }
+ VOLUME volume() { return (VOLUME)prefs.units.volume; }
+ WEIGHT weight() { return (WEIGHT)prefs.units.weight; }
public slots:
void set_cloud_verification_status(CLOUD_STATUS value) { qPrefCloudStorage::set_cloud_verification_status(value); }
+ void set_duration_units(DURATION value) { qPrefUnits::set_duration_units((units::DURATION)value); }
+ void set_length(LENGTH value) { qPrefUnits::set_length((units::LENGTH)value); }
+ void set_pressure(PRESSURE value) { qPrefUnits::set_pressure((units::PRESSURE)value); }
+ void set_temperature(TEMPERATURE value) { qPrefUnits::set_temperature((units::TEMPERATURE)value); }
+ void set_unit_system(UNIT_SYSTEM value) { qPrefUnits::set_unit_system((unit_system_values)value); }
+ void set_vertical_speed_time(TIME value) { qPrefUnits::set_vertical_speed_time((units::TIME)value); }
+ void set_volume(VOLUME value) { qPrefUnits::set_volume((units::VOLUME)value); }
+ void set_weight(WEIGHT value) { qPrefUnits::set_weight((units::WEIGHT)value); }
signals:
void cloud_verification_statusChanged(CLOUD_STATUS);
+ void duration_unitsChanged(DURATION);
+ void lengthChanged(LENGTH);
+ void pressureChanged(PRESSURE);
+ void temperatureChanged(TEMPERATURE);
+ void unit_systemChanged(UNIT_SYSTEM);
+ void vertical_speed_timeChanged(TIME);
+ void volumeChanged(VOLUME);
+ void weightChanged(WEIGHT);
private:
QMLInterface() {}