summaryrefslogtreecommitdiffstats
path: root/backend-shared/plannershared.h
diff options
context:
space:
mode:
authorGravatar jan Iversen <jan@casacondor.com>2019-12-14 23:12:26 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2019-12-24 08:44:23 +0900
commit7751ec1c78642ffcc470ad8714a87851fd5b069d (patch)
tree9846edde60477f36d95839c4f7383de380e3f497 /backend-shared/plannershared.h
parent9c52aaf043753dbb594c7420f776c836215dd6d2 (diff)
downloadsubsurface-7751ec1c78642ffcc470ad8714a87851fd5b069d.tar.gz
build-system: move plannerShared to backend-shared
WARNING: multi directory commit, needed to secure it builds. move the core/plannerShared.* to backend-shared. update CMakeLists.txt to include backend-shared lib in link process. update ios project to reflect new directory Signed-off-by: Jan Iversen <jan@casacondor.com>
Diffstat (limited to 'backend-shared/plannershared.h')
-rw-r--r--backend-shared/plannershared.h55
1 files changed, 55 insertions, 0 deletions
diff --git a/backend-shared/plannershared.h b/backend-shared/plannershared.h
new file mode 100644
index 000000000..136eb9cdf
--- /dev/null
+++ b/backend-shared/plannershared.h
@@ -0,0 +1,55 @@
+// SPDX-License-Identifier: GPL-2.0
+#ifndef PLANNERSHARED_H
+#define PLANNERSHARED_H
+#include <QObject>
+
+// This is a shared class (mobile/desktop), and contains the core of the diveplanner
+// without UI entanglement.
+// It make variables and functions available to QML, these are referenced directly
+// in the desktop version
+//
+// The mobile diveplanner shows all diveplans, but the editing functionality is
+// limited to keep the UI simpler.
+
+class plannerShared: public QObject {
+ Q_OBJECT
+
+ // Ascend/Descend data, converted to meter/feet depending on user selection
+ // Settings these will automatically update the corresponding qPrefDivePlanner
+ // Variables
+ Q_PROPERTY(int ascratelast6m READ ascratelast6m WRITE set_ascratelast6m NOTIFY ascratelast6mChanged);
+ Q_PROPERTY(int ascratestops READ ascratestops WRITE set_ascratestops NOTIFY ascratestopsChanged);
+ Q_PROPERTY(int ascrate50 READ ascrate50 WRITE set_ascrate50 NOTIFY ascrate50Changed);
+ Q_PROPERTY(int ascrate75 READ ascrate75 WRITE set_ascrate75 NOTIFY ascrate75Changed);
+ Q_PROPERTY(int descrate READ descrate WRITE set_descrate NOTIFY descrateChanged);
+public:
+ static plannerShared *instance();
+
+ // Ascend/Descend data, converted to meter/feet depending on user selection
+ static int ascratelast6m();
+ static int ascratestops();
+ static int ascrate50();
+ static int ascrate75();
+ static int descrate();
+
+public slots:
+ // Ascend/Descend data, converted to meter/feet depending on user selection
+ static void set_ascratelast6m(int value);
+ static void set_ascratestops(int value);
+ static void set_ascrate50(int value);
+ static void set_ascrate75(int value);
+ static void set_descrate(int value);
+
+signals:
+ // Ascend/Descend data, converted to meter/feet depending on user selection
+ void ascratelast6mChanged(int value);
+ void ascratestopsChanged(int value);
+ void ascrate50Changed(int value);
+ void ascrate75Changed(int value);
+ void descrateChanged(int value);
+
+private:
+ plannerShared() {}
+};
+
+#endif // PLANNERSHARED_H